avgr_u: Wasm SIMD Rechenoperation
Die avgr_u SIMD-Rechenoperation führt einen aufgerundeten Durchschnitt von zwei unsignierten v128 Wertinterpretationen durch. Jede Lane des Ausgabewerts ist (a + b + 1) / 2, das heißt der Durchschnittswert der entsprechenden Lanes der Eingabewerte, aufgerundet auf die nächstgelegene ganze Zahl.
Probieren Sie es aus
(module
(import "console" "log" (func $log (param i32)))
(func $main
v128.const i16x8 4 6 16 8 23 65 82 9
v128.const i16x8 0 25 2 30 2 34 45 80
i16x8.avgr_u
i16x8.extract_lane_s 7
call $log ;; log the result
)
(start $main)
)
WebAssembly.instantiateStreaming(fetch("{%wasm-url%}"), { console });
Syntax
value_type.avgr_u
value_type-
Der Typ des Wertes, auf dem die Anweisung ausgeführt wird. Die folgenden Typen unterstützen
avgr_u:i8x16i16x8
avgr_u-
Die
avgr_u-Anweisung. Muss immer nach demvalue_typeund einem Punkt (.) eingefügt werden.
Typ
[input1, input2] -> [output]
Binäre Kodierung
| Anweisung | Binärformat | Beispieltext => binär |
|---|---|---|
i8x16.avgr_u |
0xfd 123:u32 |
i8x16.avgr_u => 0xfd 0x7b |
i16x8.avgr_u |
0xfd 155:u32 |
i16x8.avgr_u => 0xfd 0x9b 0x01 |