Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

nearest: Wasm-Textinstruktion

Die nearest-Instruktion wird verwendet, um den Wert einer Gleitkommazahl auf die nächste ganze Zahl zu runden.

Probieren Sie es aus

(module
  (import "console" "log" (func $log (param f32)))
  (func $main

    f32.const 2.7 ;; load a number onto the stack
    f32.nearest ;; round to the nearest integer
    call $log ;; log the result

  )
  (start $main)
)
const url = "{%wasm-url%}";
await WebAssembly.instantiateStreaming(fetch(url), { console });

Syntax

value_type.nearest
value_type

Der Typ des Wertes, auf dem die Instruktion ausgeführt wird. Die folgenden Typen unterstützen nearest:

  • f32
  • f64
  • v128 Interpretationen:
    • f32x4
    • f64x2
nearest

Die nearest-Instruktion. Muss immer nach dem value_type und einem Punkt (.) eingefügt werden.

Typ

[input] -> [output]
input

Der Eingabewert.

output

Der Ausgabewert, der eine Gleitkommazahl sein wird.

Für ein nicht-SIMD nearest werden dies grundlegende numerische Werte wie 3.5 oder 3 sein.

Für ein SIMD nearest werden dies v128 Wertinterpretationen sein, zum Beispiel f32x4 3.5 6.0 10.1 40.9. Jeder Lane des auf den Stapel geschobenen Ausgabewerts entspricht der entsprechenden Lane des Eingabewertes, gerundet auf die nächste ganze Zahl.

Binärkodierung

Instruktion Binärformat Beispieltext => Binär
f32.nearest 0x90 f32.nearest => 0x90
f64.nearest 0x9e f64.nearest => 0x9e
f32x4.nearest 0xfd 106:u32 f32x4.nearest => 0xfd 0x6a
f64x2.nearest 0xfd 148:u32 f64x2.nearest => 0xfd 0x94 0x01

Beispiele

SIMD nearest Rundung

In diesem Beispiel demonstrieren wir die Verwendung von nearest, um einen SIMD-Wert zu runden.

JavaScript

In unserem Skript holen wir eine Referenz zu einem <p>-Element, an das wir unser Ergebnis ausgeben werden, und definieren dann ein Objekt zum Importieren in Wasm, das eine einzelne Funktion enthält, die einen Wert an das Ausgabe-<p> schreibt. Dann kompilieren und instanziieren wir unser Wasm-Modul mithilfe der WebAssembly.instantiateStreaming()-Methode und importieren dabei das Objekt.

js
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-output()-Funktion und achten darauf, dass sie einen f32-Parameter deklariert. Dann deklarieren wir einen SIMD-f32x4-Wert und verwenden f32x4.nearest, um alle seine Lanes auf den nächsten ganzzahligen Wert zu runden. Schließlich extrahieren wir den Wert, der in Lane 3 des Ausgabewerts gespeichert ist, mithilfe der extract_lane-Instruktion und geben ihn an das DOM aus, indem wir die importierte output()-Funktion aufrufen.

wat
(module
  ;; Import output function
  (import "obj" "output" (func $output (param f32)))

  (func $main
    ;; load a SIMD value onto the stack
    v128.const f32x4 400.3 28.5 79.9 80.1

    f32x4.nearest ;; convert lanes to nearest integer
    f32x4.extract_lane 3 ;; Extract a value from the result
    call $output
  )

  (start $main)
)

Ergebnis

Die Ausgabe ist wie folgt:

80 wird ausgegeben, weil es der nächstgelegene ganzzahlige Wert zum Wert in Lane 3 des Eingabewertes (80.1) ist.