IN: math.vectors.tests
-USING: math.vectors tools.test kernel ;
+USING: math.vectors tools.test kernel specialized-arrays compiler
+kernel.private ;
+SPECIALIZED-ARRAY: int
[ { 1 2 3 } ] [ 1/2 { 2 4 6 } n*v ] unit-test
[ { 1 2 3 } ] [ { 2 4 6 } 1/2 v*n ] unit-test
[ { 0 3 2 5 4 } ] [ { 1 2 3 4 5 } { 1 1 1 1 1 } v+- ] unit-test
-[ 1 ] [ { C{ 0 1 } } dup v. ] unit-test
\ No newline at end of file
+[ 1 ] [ { C{ 0 1 } } dup v. ] unit-test
+
+! Make sure vector shifts behave the same as hardware SIMD vector shifts
+[ int-array{ 0 0 0 0 } ] [ int-array{ 10 20 30 40 } -1 vlshift ] unit-test
+
+[ int-array{ 0 0 0 0 } ] [
+ int-array{ 10 20 30 40 }
+ [ { int-array } declare -1 vlshift ] compile-call
+] unit-test
\ No newline at end of file
: vbitor ( u v -- w ) over '[ _ [ bitor ] fp-bitwise-op ] 2map ;
: vbitxor ( u v -- w ) over '[ _ [ bitxor ] fp-bitwise-op ] 2map ;
-: vlshift ( u n -- w ) '[ _ shift ] map ;
-: vrshift ( u n -- w ) neg '[ _ shift ] map ;
+: vlshift ( u n -- w ) HEX: ff bitand '[ _ shift ] map ;
+: vrshift ( u n -- w ) HEX: ff bitand neg '[ _ shift ] map ;
: vfloor ( u -- v ) [ floor ] map ;
: vceiling ( u -- v ) [ ceiling ] map ;