mirror of
https://github.com/github/semantic.git
synced 2025-01-05 05:58:34 +03:00
Move vmagnitude into unitVector.
This commit is contained in:
parent
0cfa23fcc2
commit
b966b56494
@ -107,6 +107,7 @@ decorateTermWithFeatureVector d = cata $ \ (RCons gram rest :< functor) ->
|
|||||||
unitVector :: Int -> Int -> Vector.Vector Double
|
unitVector :: Int -> Int -> Vector.Vector Double
|
||||||
unitVector d hash = normalize ((`evalRand` mkQCGen hash) (sequenceA (Vector.replicate d getRandom)))
|
unitVector d hash = normalize ((`evalRand` mkQCGen hash) (sequenceA (Vector.replicate d getRandom)))
|
||||||
where normalize vec = fmap (/ vmagnitude vec) vec
|
where normalize vec = fmap (/ vmagnitude vec) vec
|
||||||
|
vmagnitude = sqrtDouble . Vector.sum . fmap (** 2)
|
||||||
|
|
||||||
-- | Annotates a term with a feature vector at each node.
|
-- | Annotates a term with a feature vector at each node.
|
||||||
featureVectorDecorator :: (Hashable label, Traversable f) => (forall b. CofreeF f (Record fields) b -> label) -> Int -> Int -> Int -> Cofree f (Record fields) -> Cofree f (Record (Vector.Vector Double ': fields))
|
featureVectorDecorator :: (Hashable label, Traversable f) => (forall b. CofreeF f (Record fields) b -> label) -> Int -> Int -> Int -> Cofree f (Record fields) -> Cofree f (Record (Vector.Vector Double ': fields))
|
||||||
@ -119,10 +120,6 @@ featureVectorDecorator getLabel p q d
|
|||||||
padToSize :: Alternative f => Int -> [f a] -> [f a]
|
padToSize :: Alternative f => Int -> [f a] -> [f a]
|
||||||
padToSize n list = take n (list <> repeat empty)
|
padToSize n list = take n (list <> repeat empty)
|
||||||
|
|
||||||
-- | The magnitude of a Euclidean vector, i.e. its distance from the origin.
|
|
||||||
vmagnitude :: Vector.Vector Double -> Double
|
|
||||||
vmagnitude = sqrtDouble . Vector.sum . fmap (** 2)
|
|
||||||
|
|
||||||
|
|
||||||
-- Instances
|
-- Instances
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user