この記事は編集レビューを必要としています。ぜひご協力ください。
この翻訳は不完全です。英語から この記事を翻訳 してください。
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.
SIMD.int32x4
データ型は32ビットの符号付き整数値を格納する4レーンに分かれた128ビットのベクトルです。
Figure 1: 128ビットSIMDレジスタ内のSIMD.int32x4
構文
SIMD.int32x4(x, y, z, w);
引数
x
Optional- 最初のレーンの値を指定する整数値。デフォルトでは0になります。
y
Optional- 2番目のレーンの値を指定する整数値。デフォルトでは0になります。
z
Optional- 3番目のレーンの値を指定する整数値。デフォルトでは0になります。
w
Optional- 4番目のレーンの値を指定する整数値。デフォルトでは0になります。
コンストラクタ
シンプルなコンストラクタに加えて、SIMD APIでは次のコンストラクタを提供します。別のSIMDデータ型をint32x4に変換することもできることに注意して下さい。
SIMD.int32x4.splat()
- 引数で与えられた値にすべて設定したレーン値をもつint32x4を生成します。
SIMD.int32x4.bool()
- boolean引数をもつint32x4を生成します。明示的な選択マスクを生成することができます。
演算
SIMD型で実際に何かするために、SIMDデータ型で動作するSIMD演算は必要です。
SIMD型を調べる
SIMD.int32x4.check()
- 引数が有効なint32x4データ型なら、新しいint32x4を返します。さもなければ、
TypeError
をスローします。
レーンへのアクセスおよび変異
SIMD.%type%.extractLane()
- 与えられたレーンの値を返します。
SIMD.%type%.replaceLane()
- 与えられ置き換えられたレーン値をもつ新しいインスタンスを返します。
typed arraysからのロードと保存
SIMD.int32x4.load()
- typed arrayからロードされたレーン値をもつ新しいint32x4を返します。
SIMD.int32x4.store()
- int32x4をtyped arrayに保存します。
算術演算
SIMD.int32x4.add()
- 加算されたレーン値をもつ新しいint32x4を返します(
a + b
)。 SIMD.int32x4.mul()
- 乗算されたレーン値をもつ新しいint32x4を返します(
a * b
)。 SIMD.int32x4.neg()
- 否定レーン値をもつ新しいint32x4を返します。
SIMD.int32x4.sub()
- 減算されたレーン値をもつ新しいint32x4を返します(
a - b
)。 -
シャッフルと再順序付け
SIMD.int32x4.shuffle()
- シャッフルされたレーン値をもつ新しいint32x4を返します。
SIMD.int32x4.swizzle()
- 再順序付けされたレーン値をもつ新しいint32x4を返します。
選択
SIMD.int32x4.select()
- セレクタマスクに応じてレーンの混在になるレーン値をもつ新しいint32x4を返します。
SIMD.int32x4.selectBits()
- セレクタマスクに応じてビットの混在になるレーン値をもつ新しいint32x4を返します。
比較
SIMD.int32x4.equal()
a == b
に応じた選択マスクを返します。SIMD.int32x4.notEqual()
a != b
に応じた選択マスクを返します。SIMD.int32x4.lessThan()
a < b
に応じた選択マスクを返します。SIMD.int32x4.lessThanOrEqual()
a <= b
に応じた選択マスクを返します。SIMD.int32x4.greaterThan()
a > b
に応じた選択マスクを返します。SIMD.int32x4.greaterThanOrEqual()
a >= b
に応じた選択マスクを返します。
ビット単位の論理操作
SIMD.int32x4.and()
- レーン値の論理AND演算値をもつ新しいint32x4を返します(
a & b
)。 SIMD.int32x4.or()
- レーン値の論理OR演算値をもつ新しいint32x4を返します(
a | b
)。 SIMD.int32x4.xor()
- レーン値の論理XOR演算値をもつ新しいint32x4を返します(
a ^ b
)。 SIMD.int32x4.not()
- レーン値の論理NOT演算値をもつ新しいint32x4を返します(
~a
)。
ビット単位のシフト操作
SIMD.int32x4.shiftLeftByScalar()
- 引数で与えられたビット数で左へシフトされたレーン値をもつ新しいint32x4を返します(
a << bits
)。 SIMD.int32x4.shiftRightArithmeticByScalar()
- 引数で与えられたビット数で(算術)右シフトされたレーン値をもつ新しいint32x4を返します(
a >> bits
)。 SIMD.int32x4.shiftRightLogicalByScalar()
- 引数で与えられたビット数で論理右シフトされたレーン値をもつ新しいint32x4を返します(
a >>> bits
)。
データ変換 (パック / アンパック)
SIMD.int32x4.fromFloat32x4()
- float32x4からfloat変換された新しいint32x4データ型を生成します。
SIMD.int32x4.fromFloat32x4Bits()
- float32x4からビット単位にコピーされた新しいint32x4データ型を生成します。
SIMD.int32x4.fromFloat64x2()
- float64x2からfloat変換された新しいint32x4データ型を生成します。
SIMD.int32x4.fromFloat64x2Bits()
- float64x2からビット単位にコピーされた新しいint32x4データ型を生成します。
SIMD.int32x4.fromInt16x8Bits()
- int16x8からビット単位にコピーされた新しいint32x4データ型を生成します。
SIMD.int32x4.fromInt8x16Bits()
- int8x16からビット単位にコピーされた新しいint32x4データ型を生成します。
例
int32x4のコンストラクタ
SIMD.int32x4(1, 2, 3, 4); // int32x4[1,2,3,4] SIMD.int32x4(1, 2); // int32x4[1,2,0,0] SIMD.int32x4(); // int32x4[0,0,0,0]
仕様
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 | 未サポート | 未サポート | 未サポート |