この記事は編集レビューを必要としています。ぜひご協力ください。
この翻訳は不完全です。英語から この記事を翻訳 してください。
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.int16x8
データ型は16ビットの符号付き整数値を格納する8レーンに分かれた128ビットのベクトルです。
Figure 1: 128ビットSIMDレジスタ内のSIMD.int16x8
構文
SIMD.int16x8(s0, s1, s2, s3, s4, s5, s6, s7);
引数
s[0-7]
Optional- レーンの値を指定する整数値。デフォルトでは0になります。
コンストラクタ
シンプルなコンストラクタに加えて、SIMD APIでは次のコンストラクタを提供します。別のSIMDデータ型からint16x8に変換することもできることに注意して下さい。
SIMD.int16x8.splat()
- 引数で与えられた値にすべて設定したレーン値をもつint16x8を生成します。
SIMD.int16x8.bool()
- boolean引数をもつint16x8を生成します。明示的な選択マスクを生成することができます。
演算
SIMD型で実際に何かするために、SIMDデータ型で動作するSIMD演算は必要です。
SIMD型を調べる
SIMD.int16x8.check()
- 引数が有効なint16x8データ型なら、新しいint16x8を返します。さもなければ、
TypeError
をスローします。
レーンへのアクセスおよび変異
SIMD.int16x8.extractLane()
- 与えられたレーンの値を返します。
SIMD.int16x8.replaceLane()
- 与えられ置き換えられたレーン値をもつ新しいint16x8を返します。
typed arraysからのロードと保存
SIMD.int16x8.load()
- typed arrayからロードされたレーン値をもつ新しいint16x8を返します。
SIMD.int16x8.store()
- int16x8をtyped arrayに保存します。
算術演算
SIMD.int16x8.add()
- 加算されたレーン値をもつ新しいint16x8を返します(
a + b
)。 SIMD.int16x8.mul()
- 乗算されたレーン値をもつ新しいint16x8を返します(
a * b
)。 SIMD.int16x8.neg()
- 否定レーン値をもつ新しいint16x8を返します。
SIMD.int16x8.sub()
- 減算されたレーン値をもつ新しいint16x8を返します(
a - b
)。 -
シャッフルと再順序付け
SIMD.int16x8.shuffle()
- シャッフルされたレーン値をもつ新しいint16x8を返します。
SIMD.int16x8.swizzle()
- 再順序付けされたレーン値をもつ新しいint16x8を返します。
選択
SIMD.int16x8.select()
- セレクタマスクに応じてレーンの混在になるレーン値をもつ新しいint16x8を返します。
SIMD.int16x8.selectBits()
- セレクタマスクに応じてビットの混在になるレーン値をもつ新しいint16x8を返します。
比較
SIMD.int16x8.equal()
a == b
に応じた選択マスクを返します。SIMD.int16x8.notEqual()
a != b
に応じた選択マスクを返します。SIMD.int16x8.lessThan()
a < b
に応じた選択マスクを返します。SIMD.int16x8.lessThanOrEqual()
a <= b
に応じた選択マスクを返します。SIMD.int16x8.greaterThan()
a > b
に応じた選択マスクを返します。SIMD.int16x8.greaterThanOrEqual()
a >= b
に応じた選択マスクを返します。
ビット単位の論理操作
SIMD.int16x8.and()
- レーン値の論理AND演算値をもつ新しいint16x8を返します(
a & b
)。 SIMD.int16x8.or()
- レーン値の論理OR演算値をもつ新しいint16x8を返します(
a | b
)。 SIMD.int16x8.xor()
- レーン値の論理XOR演算値をもつ新しいint16x8を返します(
a ^ b
)。 SIMD.int16x8.not()
- レーン値の論理NOT演算値をもつ新しいint16x8を返します(
~a
)。
ビット単位のシフト操作
SIMD.int16x8.shiftLeftByScalar()
- 引数で与えられたビット数で左へシフトされたレーン値をもつ新しいint16x8を返します(
a << bits
)。 SIMD.int16x8.shiftRightArithmeticByScalar()
- 引数で与えられたビット数で(算術)右シフトされたレーン値をもつ新しいint16x8を返します(
a >> bits
)。 SIMD.int16x8.shiftRightLogicalByScalar()
- 引数で与えられたビット数で論理右シフトされたレーン値をもつ新しいint16x8を返します(
a >>> bits
)。
データ変換 (パック / アンパック)
SIMD.int16x8.fromFloat32x4Bits()
- float32x4からビット単位にコピーされた新しいint16x8データ型を生成します。
SIMD.int16x8.fromFloat64x2Bits()
- float64x2からビット単位にコピーされた新しいint16x8データ型を生成します。
SIMD.int16x8.fromInt32x4Bits()
- int32x4からビット単位にコピーされた新しいint16x8データ型を生成します。
SIMD.int16x8.fromInt8x16Bits()
- int8x16からビット単位にコピーされた新しいint16x8データ型を生成します。
例
int16x8のコンストラクタ
SIMD.int16x8(1, 2, 3, 4, 5, 6, 7, 8); // int16x8[1,2,3,4,5,6,7,8] SIMD.int16x8(1, 2); // int16x8[1,2,0,0,0,0,0,0] SIMD.int16x8(); // int16x8[0,0,0,0,0,0,0,0]
仕様
SIMDはまだ公式規格文書やドラフトでサポートされていません。typed arraysに基づいた標準化作業や互換性実装のために、ecmascript_simd GitHub リポジトリを確かめて下さい。
ブラウザ実装状況
機能 | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
基本サポート | 未サポート | 未サポート | 未サポート | 未サポート | 未サポート |
機能 | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
基本サポート | 未サポート | 未サポート | 未サポート | 未サポート | 未サポート | 未サポート |