add: Wasm-Textanweisung
Die add Anweisung wird verwendet, um zwei Zahlen zu addieren, ähnlich wie der + Operator in anderen Sprachen.
Probieren Sie es aus
(module
(import "console" "log" (func $log (param i32)))
(func $main
;; load `10` and `3` onto the stack
i32.const 10
i32.const 3
i32.add ;; add up both numbers
call $log ;; log the result
)
(start $main)
)
const url = "{%wasm-url%}";
await WebAssembly.instantiateStreaming(fetch(url), { console });
Syntax
value_type.add
value_type-
Der Typ des Wertes, auf dem die Anweisung ausgeführt wird. Die folgenden Typen unterstützen
add:i32i64f32f64v128Interpretationen:i8x16i16x8i32x4i64x2f32x4f64x2
add-
Die
addAnweisung. Muss immer nach demvalue_typeund einem Punkt (.) stehen.
Typ
[input1, input2] -> [output]
input1-
Der erste zu addierende Wert.
input2-
Der zweite zu addierende Wert.
output-
Die Summe der beiden Eingabewerte.
Für eine nicht-SIMD add sind dies grundlegende numerische Werte wie 3 oder 3.5.
Für eine SIMD add sind dies v128 Wertinterpretationen, zum Beispiel f32x4 0x9 0xa 0xb 0xc. Jeder Lane der Ausgabe, die auf den Stack gelegt wird, ist die Addition der entsprechenden Lanes in den Eingabewerten.
Binärcode
| Anweisung | Binärformat | Beispieltext => binär |
|---|---|---|
i32.add |
0x6a |
i32.add => 0x6a |
i64.add |
0x7c |
i64.add => 0x7c |
f32.add |
0x92 |
f32.add => 0x92 |
f64.add |
0xa0 |
f64.add => 0xa0 |
i8x16.add |
0xfd 110:u32 |
i8x16.add => 0xfd 0x6e |
i16x8.add |
0xfd 142:u32 |
i16x8.add => 0xfd 0x8e 0x01 |
i32x4.add |
0xfd 174:u32 |
i32x4.add => 0xfd 0xae 0x01 |
i64x2.add |
0xfd 206:u32 |
i64x2.add => 0xfd 0xce 0x01 |
f32x4.add |
0xfd 228:u32 |
f32x4.add => 0xfd 0xe4 0x01 |
f64x2.add |
0xfd 240:u32 |
f64x2.add => 0xfd 0xf0 0x01 |
Beispiele
>SIMD Addition
In diesem Beispiel demonstrieren wir das Addieren zweier SIMD-Werte und das Ausgeben eines der Lane-Werte.
JavaScript
In unserem Skript holen wir uns eine Referenz auf ein <p> Element, in das wir unser Ergebnis ausgeben werden, dann definieren wir ein Objekt zum Importieren in Wasm, das eine einzige Funktion enthält, die einen Wert in das Ausgabe-<p> schreibt. Wir kompilieren und instanziieren dann unser Wasm-Modul mit der Methode WebAssembly.instantiateStreaming(), wobei wir das Objekt importieren.
const outputElem = document.querySelector("p");
const obj = {
output(val) {
outputElem.textContent += val;
},
};
WebAssembly.instantiateStreaming(fetch("{%wasm-url%}"), {
obj,
});
Wasm
In unserem Wasm-Modul importieren wir zuerst die JavaScript-Funktion output(), wobei wir sicherstellen, dass sie einen i32-Parameter hat. Dann deklarieren wir zwei SIMD-i32x4-Werte und addieren sie mit i32x4.add. Schließlich extrahieren wir den in Lane 3 der Summe gespeicherten Wert mit der extract_lane Anweisung und geben ihn an das DOM aus, indem wir die importierte output()-Funktion aufrufen.
(module
;; Import output function
(import "obj" "output" (func $output (param i32)))
(func $main
;; load two SIMD values onto the stack
v128.const i32x4 9 10 11 12
v128.const i32x4 9 10 11 12
i32x4.add ;; add the two values
i32x4.extract_lane 3 ;; Extract a value from the result
call $output
)
(start $main)
)
Ergebnis
Die Ausgabe ist wie folgt:
Das Ergebnis ist 24, da der Wert, der in Lane 3 jedes der Eingabewerte gespeichert ist, 12 ist. Einmal addiert, enthält Lane 3 des Ausgabewertes den Wert 24.