extmul_low_i16x8_s: Wasm SIMD-Arithmetikanweisung
Die extmul_low_i16x8_s SIMD-Arithmetikanweisung nimmt die Spuren 0–3 von zwei signierten v128 i16x8-Wertinterpretationen, multipliziert die Werte in den entsprechenden Spuren und gibt das Ergebnis dieser Operationen in einer i32x4-Wertinterpretation aus.
Probieren Sie es aus
(module
(import "console" "log" (func $log (param i32)))
(func $main
v128.const i16x8 3 3 3 3 6 6 6 6
v128.const i16x8 2 2 2 2 4 4 4 4
i32x4.extmul_low_i16x8_s
i32x4.extract_lane 3
call $log ;; log the result
)
(start $main)
)
WebAssembly.instantiateStreaming(fetch("{%wasm-url%}"), { console });
Im obigen Beispiel werden die Spuren 0–3 der beiden i16x8-Eingabewerte miteinander multipliziert, und die Produkte werden als i32x4 ausgegeben. Spur 0 des ersten Eingangs wird mit Spur 0 des zweiten Eingangs multipliziert, und das Produkt wird zu Spur 0 des Ausgangs, und so weiter. Als Ergebnis enthält jede Spur des Ausgangs den Wert 6 (3 * 2).
Die Anweisung extmul_low_i16x8_s ist eine leistungsfähigere Alternative zur Weitergabe der Ergebnisse von zwei extend_low_i16x8_s-Anweisungen in eine mul-Anweisung.
Mit anderen Worten:
(i32x4.extmul_low_i16x8_s
(input1)
(input2)
)
entspricht
(i32x4.mul
(i32x4.extend_low_i16x8_s
(input1)
)
(i32x4.extend_low_i16x8_s
(input2)
)
)
Syntax
i32x4.extmul_low_i16x8_s
i32x4.extmul_low_i16x8_s-
Die
i32x4.extmul_low_i16x8_s-Anweisung.
Typ
[input1, input2] -> [output]
Binärcodierung
| Anweisung | Binärformat | Beispieltext => Binär |
|---|---|---|
i32x4.extmul_low_i16x8_s |
0xfd 188:u32 |
i32x4.extmul_low_i16x8_s => 0xfd 0xbc 0x01 |