module Numeric.Array.Family.ArrayW16 () where
import GHC.Base (runRW#)
import GHC.Prim
import GHC.Types (Int (..), RuntimeRep (..), isTrue#)
import GHC.Word (Word16 (..))
import Numeric.Array.ElementWise
import Numeric.Array.Family
import Numeric.Commons
import Numeric.Dimensions
import Numeric.Dimensions.Traverse
#include "MachDeps.h"
#define ARR_TYPE ArrayW16
#define ARR_FROMSCALAR FromScalarW16#
#define ARR_CONSTR ArrayW16#
#define EL_TYPE_BOXED Word16
#define EL_TYPE_PRIM Word#
#define EL_RUNTIME_REP 'WordRep
#define EL_CONSTR W16#
#define EL_SIZE SIZEOF_WORD16#
#define EL_ALIGNMENT ALIGNMENT_WORD16#
#define EL_ZERO 0##
#define EL_ONE 1##
#define EL_MINUS_ONE -1#
#define INDEX_ARRAY indexWord16Array#
#define WRITE_ARRAY writeWord16Array#
#define OP_EQ eqWord#
#define OP_NE neWord#
#define OP_GT gtWord#
#define OP_GE geWord#
#define OP_LT ltWord#
#define OP_LE leWord#
#define OP_PLUS plusWord#
#define OP_MINUS minusWord#
#define OP_TIMES timesWord#
#include "Array.h"
instance Num (ArrayW16 ds) where
(+) = zipV plusWord#
() = zipV minusWord#
(*) = zipV timesWord#
negate = mapV (\x -> int2Word# (negateInt# (word2Int# x)))
abs = id
signum = mapV (\x -> if isTrue# (gtWord# x 0##)
then 1##
else 0##
)
fromInteger = broadcastArray . fromInteger
instance Bounded (ArrayW16 ds) where
minBound = broadcastArray minBound
maxBound = broadcastArray maxBound