lt_u: Wasm Textanweisung
Die lt_u-Anweisung, kurz für less than unsigned, prüft, ob eine unsignierte Ganzzahl kleiner als eine andere unsignierte Ganzzahl ist.
Es gibt weitere lt-Anweisungen:
Probieren Sie es aus
(module
(import "env" "log_bool" (func $log_bool (param i32)))
(func $main
;; load 10 and 3 onto the stack
i32.const 10
i32.const 3
i32.lt_u ;; check if 10 is greater than 3
call $log_bool ;; log the result
)
(start $main)
)
const url = "{%wasm-url%}";
function log_bool(value) {
console.log(Boolean(value));
// Expected output: true
}
await WebAssembly.instantiateStreaming(fetch(url), {
env: { log_bool },
});
Syntax
value_type.lt_u
value_type-
Der Wertetyp, auf dem die Anweisung ausgeführt wird. Die folgenden Typen unterstützen
lt_u:i32i64v128-Interpretationen:i8x16i16x8i32x4
lt_u-
Die
lt_u-Anweisung. Muss immer nach demvalue_typeund einem Punkt (.) hinzugefügt werden.
Typ
[input1, input2] -> [output]
input1-
Der erste Eingabewert.
input2-
Der zweite Eingabewert.
output-
Der Ausgabewert, der ein Ganzzahltyp sein wird.
Bei einem nicht-SIMD lt_u sind die Eingaben einfache numerische Werte wie 3 oder 12. Ist die erste Eingabe kleiner als die zweite Eingabe, wird 1 auf den Stapel als Ausgabe geschoben, andernfalls 0.
Bei einem SIMD lt_u sind die Eingaben v128-Werteinterpretationen, z.B. i32x4 2 30 86 120. Jede Bahn der auf den Stapel geschobenen Ausgabe ist eine 1 oder 0, die anzeigt, ob die entsprechende Bahn des ersten Eingabewertes kleiner als die entsprechende Bahn des zweiten Eingabewertes ist.
Binäre Kodierung
| Anweisung | Binärformat | Beispieltext => binär |
|---|---|---|
i32.lt_u |
0x49 |
i32.lt_u => 0x49 |
i64.lt_u |
0x54 |
i64.lt_u => 0x54 |
i8x16.lt_u |
0xfd 38:u32 |
i8x16.lt_u => 0xfd 0x26 |
i16x8.lt_u |
0xfd 48:u32 |
i16x8.lt_u => 0xfd 0x30 |
i32x4.lt_u |
0xfd 58:u32 |
i32x4.lt_u => 0xfd 0x3a |
Beispiele
>SIMD lt_u Beispiel
In diesem Beispiel demonstrieren wir die Verwendung von lt_u, um zu testen, ob ein SIMD-Bahnwert kleiner als derselbe Bahnwert in einem anderen SIMD-Wert ist.
JavaScript
In unserem Skript erhalten wir eine Referenz zu einem <p>-Element, an das wir unser Ergebnis ausgeben werden, und definieren dann ein Objekt für den Import nach Wasm, das eine einzelne Funktion enthält, die einen Wert an die Ausgabe <p> schreibt. Wir kompilieren und instanziieren dann unser Wasm-Modul mit der Methode WebAssembly.instantiateStreaming() und importieren dabei das Objekt.
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 zunächst die JavaScript-Funktion output(), wobei wir sicherstellen, dass sie einen i32-Parameter hat. Wir deklarieren dann zwei SIMD i32x4-Werte und überprüfen, ob die Bahnenwerte des ersten kleiner als die des zweiten sind, indem wir i32x4.lt_u verwenden. Schließlich extrahieren wir den in Bahn 3 des Ausgabe-Werts gespeicherten Wert mithilfe der Anweisung extract_lane und geben ihn an das DOM aus, indem wir die importierte Funktion output() aufrufen.
(module
;; Import output function
(import "obj" "output" (func $output (param i32)))
(func $main
;; load two SIMD values onto the stack
v128.const i32x4 20 12 15 102
v128.const i32x4 20 12 15 100
;; check whether the first value is less than the second
i32x4.lt_u
i32x4.extract_lane 3 ;; Extract a value from the result
call $output
)
(start $main)
)
Ergebnis
Die Ausgabe ist wie folgt:
Das Ergebnis ist 0, da der in Bahn 3 des ersten Eingabewerts gespeicherte Wert nicht kleiner ist als der in Bahn 3 des zweiten Eingabewerts gespeicherte Wert.