module GraphRewriting.Layout.Gravitation where

import Data.View
import Data.Vector.Class
import Data.Vector.V2
import Control.Monad
import GraphRewriting.Graph.Types
import GraphRewriting.Graph.Read
import GraphRewriting.Layout.Position
import GraphRewriting.Layout.Force


centralGravitation  View Position n  Node  WithGraph n Force
centralGravitation = liftM (attraction $ vpromote 0) . examineNode position

gravitation  View Position n  Node -> Rewrite n Force
gravitation node = do
 	n  examineNode position node
 	ns  mapM (examineNode position) =<< readNodeList
 	return $ fsum [attraction n' n | n'  ns]