MDN wants to learn about developers like you: https://qsurvey.mozilla.com/s3/MDN-dev-survey

この翻訳は不完全です。英語から この記事を翻訳 してください。

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ビットのベクトルです。

SIMD.float64x2

Figure 1: 128ビットレジスタ内のSIMD.float64x2

構文

SIMD.float64x2(x, y);

引数

x Optional
最初のレーンの値を指定するdouble値。デフォルトではNaNになります。
y Optional
2番目のレーンの値を指定するdouble値。デフォルトではNaNになります。

コンストラクタ

シンプルなコンストラクタに加えて、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 未サポート 未サポート 未サポート

関連情報

ドキュメントのタグと貢献者

 このページの貢献者: shide55
 最終更新者: shide55,