この記事は編集レビューを必要としています。ぜひご協力ください。
この翻訳は不完全です。英語から この記事を翻訳 してください。
This is an experimental technology, part of the Harmony (ECMAScript 7) proposal.
Because this technology's specification has not stabilized, check the compatibility table for usage in various browsers. Also note that the syntax and behavior of an experimental technology is subject to change in future version of browsers as the spec changes.
The SIMD.float64x2
データ型は浮動小数点値倍精度を格納する2レーンに分割された128ビットのベクトルです。
Figure 1: 128ビットレジスタ内のSIMD.float64x2
構文
SIMD.float64x2(x, y);
引数
コンストラクタ
シンプルなコンストラクタに加えて、SIMD APIでは次のコンストラクタを提供します。別のSIMDデータ型からfloat64x2に変換することもできることに注意して下さい。
SIMD.float64x2.splat()
- 引数で与えられた値にすべて設定したレーン値をもつfloat64x2を生成します。
演算
SIMD型で実際に何かするために、SIMDデータ型で動作するSIMD演算は必要です。
SIMD型を調べる
SIMD.float64x2.check()
- 引数が有効なfloat64x2データ型なら、新しいfloat64x2を返します。さもなければ、
TypeError
をスローします。
レーンへのアクセスおよび変異
SIMD.float64x2.extractLane()
- 与えられたレーンの値を返します。
SIMD.float64x2.replaceLane()
- 与えられ置き換えられたレーン値をもつ新しいfloat64x2を返します。
typed arraysからのロードと保存
SIMD.float64x2.load()
- typed arrayからロードされたレーン値をもつ新しいfloat64x2を返します。
SIMD.float64x2.store()
- float64x2をtyped arrayに保存します。
算術演算
SIMD.float64x2.abs()
- 絶対値のレーン値をもつ新しいfloat64x2を返します。
SIMD.float64x2.add()
- 加算されたレーン値をもつ新しいfloat64x2を返します(
a + b
)。 SIMD.float64x2.div()
- 除算されたレーン値をもつ新しいfloat64x2を返します(
a / b
)。 SIMD.float64x2.mul()
- 乗算されたレーン値をもつ新しいfloat64x2を返します(
a * b
)。 SIMD.float64x2.neg()
- 否定レーン値をもつ新しいfloat64x2を返します。
SIMD.float64x2.reciprocalApproximation()
- 逆数のレーン値の近似値をもつ新しいfloat64x2を返します。
SIMD.float64x2.reciprocalSqrtApproximation()
- 平方根の逆数のレーン値の近似値をもつ新しいfloat64x2を返します。
SIMD.float64x2.sub()
- 減算されたレーン値をもつ新しいfloat64x2を返します(
a - b
)。 SIMD.float64x2.sqrt()
- レーン値の平方根をもつ新しいfloat64x2を返します。
シャッフルと再順序付け
SIMD.float64x2.shuffle()
- シャッフルされたレーン値をもつ新しいfloat64x2を返します。
SIMD.float64x2.swizzle()
- 再順序付けされたレーン値をもつ新しいfloat64x2を返します。
最小/最大とクランプ
SIMD.float64x2.clamp()
- 下限と上限の間に縮められたレーン値をもつ新しいfloat64x2を返します。
SIMD.float64x2.max()
- レーン値の最大値をもつ新しいfloat64x2を返します。
SIMD.float64x2.maxNum()
- レーン値の最大値をもつ新しいfloat64x2を返します。
NaN
より数値が選ばれます。 SIMD.float64x2.min()
- レーン値の最小値をもつ新しいfloat64x2を返します。
SIMD.float64x2.minNum()
- レーン値の最小値をもつ新しいfloat64x2を返します。
NaN
より数値が選ばれます。
選択
SIMD.float64x2.select()
- 選択マスクに応じてレーンの混在になるレーン値をもつ新しいfloat64x2を返します。
SIMD.float64x2.selectBits()
- 選択マスクに応じてビットの混在になるレーン値をもつ新しいfloat64x2を返します。
比較
SIMD.float64x2.equal()
a == b
に応じた選択マスクを返します。SIMD.float64x2.notEqual()
a != b
に応じた選択マスクを返します。SIMD.float64x2.lessThan()
a < b
に応じた選択マスクを返します。SIMD.float64x2.lessThanOrEqual()
a <= b
に応じた選択マスクを返します。SIMD.float64x2.greaterThan()
a > b
に応じた選択マスクを返します。SIMD.float64x2.greaterThanOrEqual()
a >= b
に応じた選択マスクを返します。
データ変換 (パック / アンパック)
SIMD.float64x2.fromInt32x4()
- int32x4からfloat変換された新しいfloat64x2データ型を生成します。
SIMD.float64x2.fromInt32x4Bits()
- int32x4からビット単位にコピーされた新しいfloat64x2データ型を生成します。
SIMD.float64x2.fromFloat32x4()
- float32x4からfloat変換された新しいfloat64x2データ型を生成します。
SIMD.float64x2.fromFloat32x4Bits()
- float32x4からビット単位にコピーされた新しいfloat64x2データ型を生成します。
SIMD.float64x2.fromInt16x8Bits()
- int16x8からビット単位にコピーされた新しいfloat64x2データ型を生成します。
SIMD.float64x2.fromInt8x16Bits()
- int8x16からビット単位にコピーされた新しいfloat64x2データ型を生成します。
例
float64x2のコンストラクタ
SIMD.float64x2(1, 2); // float64x2[1, 2] SIMD.float64x2(1); // float64x2[1, NaN] SIMD.float64x2(); // float64x2[NaN, NaN]
仕様
SIMDはまだ公式規格文書やドラフトでサポートされていません。typed arraysに基づいた標準化作業や互換性実装のために、ecmascript_simd GitHub リポジトリを確かめて下さい。
ブラウザ実装状況
機能 | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
基本サポート | 未サポート | Nightly build | 未サポート | 未サポート | 未サポート |
機能 | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
基本サポート | 未サポート | 未サポート | Nightly build | 未サポート | 未サポート | 未サポート |