{-# LANGUAGE UnicodeSyntax, FlexibleContexts #-} module GraphRewriting.Layout.Coulomb where import Data.View import Data.Functor import GraphRewriting.Graph.Types import GraphRewriting.Graph.Read import GraphRewriting.Layout.Position import GraphRewriting.Layout.Force coulombForce ∷ View Position n ⇒ Node -> WithGraph n Force coulombForce node = do n ← examine position <$> readNode node ns ← fmap (map $ examine position) (mapM readNode =<< readNodeList) return $ fsum [repulsion n' n | n' ← ns]