1 ! Copyright (C) 2009 Slava Pestov.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors byte-arrays combinators fry sequences
4 compiler.tree.propagation.info cpu.architecture kernel words math
5 math.intervals math.vectors.simd.intrinsics ;
6 IN: compiler.tree.propagation.simd
33 } [ { byte-array } "default-output-classes" set-word-prop ] each
35 : scalar-output-class ( rep -- class )
37 literal>> scalar-rep-of {
38 { float-rep [ float ] }
39 { double-rep [ float ] }
45 \ (simd-sum) [ nip scalar-output-class ] "outputs" set-word-prop
47 \ (simd-v.) [ 2nip scalar-output-class ] "outputs" set-word-prop
53 } [ { boolean } "default-output-classes" set-word-prop ] each
55 \ (simd-select) [ 2nip scalar-output-class ] "outputs" set-word-prop
58 real [0,inf] <class/interval-info> value-info-intersect
59 ] "outputs" set-word-prop
61 ! If SIMD is not available, inline alien-vector and set-alien-vector
63 : inline-unless-intrinsic ( word -- )
64 dup '[ drop _ dup "intrinsic" word-prop [ drop f ] [ def>> ] if ]
65 "custom-inlining" set-word-prop ;
67 \ alien-vector inline-unless-intrinsic
69 \ set-alien-vector inline-unless-intrinsic