「4x4行列で3x3行列を代用する」の版間の差分

提供: MonoBook
ナビゲーションに移動 検索に移動
5行目: 5行目:
 
普通に考えれば最小16回の演算より最小9回の演算の方が速いのは当たり前である。
 
普通に考えれば最小16回の演算より最小9回の演算の方が速いのは当たり前である。
  
しかし[[プログラミング言語]]に標準装備されている算数系ライブラリは[[CPU]]の[[SIMD]]を直叩きしているものが多く、自作した3x3行列ライブラリではどうやっても標準搭載の4x4行列に勝てないことも多い。
+
しかし[[プログラミング言語]](とくに[[インタプリタ]]系)に標準装備されている算数系ライブラリは[[CPU]]の[[SIMD]]を直叩きしているものが多く、自作した3x3行列ライブラリではどうやっても標準搭載の4x4行列に勝てないことも多い。
  
 
極端な[[インタプリタ]]系の実行環境では「floatとfloatの乗算よりmatrix4x4とmatrix4x4の乗算の方が速い」「new float()している間にmatrix4x4の生成と乗算が終わっていた」などという意味不明なものすら存在する。
 
極端な[[インタプリタ]]系の実行環境では「floatとfloatの乗算よりmatrix4x4とmatrix4x4の乗算の方が速い」「new float()している間にmatrix4x4の生成と乗算が終わっていた」などという意味不明なものすら存在する。

2021年3月10日 (水) 01:56時点における版

プログラミング言語に標準装備されている算数系のライブラリには3x3行列が存在しないことが多い。これは3x3行列は4x4行列で代用できるためである。

速度

各種演算時の計算量的には4x4行列より3x3行列の方が圧倒的に有利に思える。 普通に考えれば最小16回の演算より最小9回の演算の方が速いのは当たり前である。

しかしプログラミング言語(とくにインタプリタ系)に標準装備されている算数系ライブラリはCPUSIMDを直叩きしているものが多く、自作した3x3行列ライブラリではどうやっても標準搭載の4x4行列に勝てないことも多い。

極端なインタプリタ系の実行環境では「floatとfloatの乗算よりmatrix4x4とmatrix4x4の乗算の方が速い」「new float()している間にmatrix4x4の生成と乗算が終わっていた」などという意味不明なものすら存在する。

基本形

「外側を0で埋めて、右下に1」が基本形である。