1
1
mirror of https://github.com/github/semantic.git synced 2025-01-03 13:02:37 +03:00

Specialize how we add vectors.

This commit is contained in:
Rob Rix 2017-02-03 13:44:36 -05:00
parent dda587e86d
commit 06b73aa0da

View File

@ -250,10 +250,10 @@ featureVectorDecorator getLabel p q d
. pqGramDecorator getLabel p q
where collect ((gram :. rest) :< functor) = cofree ((foldl' addSubtermVector (unitVector d (hash gram)) functor :. rest) :< functor)
addSubtermVector :: FeatureVector -> Term f (Record (FeatureVector ': fields)) -> FeatureVector
addSubtermVector = flip $ azipWith (+) . rhead . headF . runCofree
addSubtermVector = flip $ addVectors . rhead . headF . runCofree
azipWith :: (a -> b -> c) -> Array Int a -> Array Int b -> Array Int c
azipWith f as bs = listArray (0, d - 1) (fmap (\ i -> f (as ! i) (bs ! i)) [0..(d - 1)])
addVectors :: Num a => Array Int a -> Array Int a -> Array Int a
addVectors as bs = listArray (0, d - 1) (fmap (\ i -> as ! i + bs ! i) [0..(d - 1)])
-- | Annotates a term with the corresponding p,q-gram at each node.
pqGramDecorator