extmul_low_i32x4_s: Wasm SIMD Arithmetik-Anweisung
Die extmul_low_i32x4_s SIMD Arithmetik-Anweisung nimmt die Lanes 0–1 von zwei signierten v128 i32x4-Wertinterpretationen, multipliziert die Werte in den entsprechenden Lanes und gibt das Ergebnis dieser Operationen in einer i64x2-Wertinterpretation aus.
Probieren Sie es aus
(module
(import "console" "log" (func $log (param i64)))
(func $main
v128.const i32x4 25 25 50 50
v128.const i32x4 20 20 40 40
i64x2.extmul_low_i32x4_s
i64x2.extract_lane 1
call $log ;; log the result
)
(start $main)
)
WebAssembly.instantiateStreaming(fetch("{%wasm-url%}"), { console });
Im obigen Beispiel werden die Lanes 0–1 der beiden i32x4-Eingabewerte miteinander multipliziert, und die Produkte als i64x2 ausgegeben. Die Lane 0 des ersten Eingangs wird mit der Lane 0 des zweiten Eingangs multipliziert, und das Produkt wird zu Lane 0 der Ausgabe, und so weiter. Als Ergebnis enthält jede Lane der Ausgabe den Wert 500 (25 * 20).
Die extmul_low_i32x4_s-Anweisung ist eine effizientere Entsprechung zur Übergabe der Ergebnisse von zwei extend_low_i32x4_s-Anweisungen an eine mul-Anweisung.
Mit anderen Worten:
(i64x2.extmul_low_i32x4_s
(input1)
(input2)
)
ist gleichwertig mit
(i64x2.mul
(i64x2.extend_low_i32x4_s
(input1)
)
(i64x2.extend_low_i32x4_s
(input2)
)
)
Syntax
i64x2.extmul_low_i32x4_s
i64x2.extmul_low_i32x4_s-
Die
i64x2.extmul_low_i32x4_s-Anweisung.
Typ
[input1, input2] -> [output]
Binärcode-Kodierung
| Anweisung | Binärformat | Beispieltext => Binärcode |
|---|---|---|
i64x2.extmul_low_i32x4_s |
0xfd 220:u32 |
i64x2.extmul_low_i32x4_s => 0xfd 0xdc 0x01 |