Commit 131b1fb6 authored by Yiannis Tsiouris's avatar Yiannis Tsiouris

Fix whitespace + add debugging info

parent 924e798d
...@@ -4,15 +4,19 @@ module Bench( -- sequential benchmarks ...@@ -4,15 +4,19 @@ module Bench( -- sequential benchmarks
, par, par_seq , par, par_seq
-- distributed benhcmarks -- distributed benhcmarks
, dist, dist_seq , dist, dist_seq
, seqTest
) where ) where
import Control.Distributed.Process (Process, ProcessId, NodeId) import Control.Concurrent (threadDelay)
import Data.List (lookup) import Control.Distributed.Process
import Data.Maybe (fromMaybe) import Control.Distributed.Process.Node
import Prelude hiding (seq) import Data.List (lookup)
import Data.Maybe (fromMaybe)
import Prelude hiding (seq)
import Network.Transport.TCP
import MasterWorker (HostInfo(..), MaybeHosts(..), import MasterWorker (HostInfo(..), MaybeHosts(..),
MasterStats, orbit) MasterStats, orbit)
import Utils import Utils
----------------------------------------------------------------------------- -----------------------------------------------------------------------------
...@@ -59,3 +63,12 @@ sz (mainStats : _) = ...@@ -59,3 +63,12 @@ sz (mainStats : _) =
case "size" `lookup` mainStats of case "size" `lookup` mainStats of
Nothing -> "false" Nothing -> "false"
Just s -> "{size," ++ s ++ "}" Just s -> "{size," ++ s ++ "}"
seqTest :: IO ()
seqTest = do
Right t <- createTransport "127.0.0.1" "10504" defaultTCPParameters
node <- newLocalNode t initRemoteTable
runProcess node $ do
res <- par gg13 11 2
liftIO $ print res
threadDelay (2 * 1000000)
...@@ -410,11 +410,12 @@ remotable ['init] ...@@ -410,11 +410,12 @@ remotable ['init]
orbit :: GenClos -> [Vertex] -> MaybeHosts -> Process ([Vertex], [MasterStats]) orbit :: GenClos -> [Vertex] -> MaybeHosts -> Process ([Vertex], [MasterStats])
orbit (GenClos (_, _, gs)) xs (Seq tablesize) = orbit (GenClos (_, _, gs)) xs (Seq tablesize) =
return $ Sq.orbit gs xs tablesize return $ Sq.orbit gs xs tablesize
orbit gs xs (Par hostInfo) = par_orbit gs xs hostInfo orbit gs xs (Par hostInfo) = par_orbit gs xs hostInfo
par_orbit :: GenClos -> [Vertex] -> HostInfo par_orbit :: GenClos -> [Vertex] -> HostInfo
-> Process ([Vertex], [MasterStats]) -> Process ([Vertex], [MasterStats])
par_orbit gs xs hosts = do par_orbit gs xs hosts = do
say "---- in par_orbit"
-- spawn workers on Hosts -- spawn workers on Hosts
(workers, globTabSize) <- start_workers hosts (workers, globTabSize) <- start_workers hosts
self <- getSelfPid self <- getSelfPid
...@@ -445,7 +446,9 @@ par_orbit gs xs hosts = do ...@@ -445,7 +446,9 @@ par_orbit gs xs hosts = do
-- * Workers is a list of Worker, sorted wrt. TableOffset in ascending order. -- * Workers is a list of Worker, sorted wrt. TableOffset in ascending order.
start_workers :: HostInfo -> Process ([(ProcessId, Int, Int)], Int) start_workers :: HostInfo -> Process ([(ProcessId, Int, Int)], Int)
start_workers (JustOne host) = do start_workers (JustOne host) = do
say "---- in start_workers"
(workers, globalTableSize) <- do_start_shm host ([], 0) (workers, globalTableSize) <- do_start_shm host ([], 0)
say "---- after do_start_shm"
return (reverse workers, globalTableSize) return (reverse workers, globalTableSize)
start_workers (Many hosts) = do start_workers (Many hosts) = do
(workers, globalTableSize) <- do_start_dist hosts ([], 0) (workers, globalTableSize) <- do_start_dist hosts ([], 0)
...@@ -455,8 +458,10 @@ do_start_shm :: (Int, Int, Int, Bool) -> ([(ProcessId, Int, Int)], Int) ...@@ -455,8 +458,10 @@ do_start_shm :: (Int, Int, Int, Bool) -> ([(ProcessId, Int, Int)], Int)
-> Process ([(ProcessId, Int, Int)], Int) -> Process ([(ProcessId, Int, Int)], Int)
do_start_shm (0, _, _, _) acc = return acc do_start_shm (0, _, _, _) acc = return acc
do_start_shm (m, tabSize, tmOut, spawnImgComp) (workers, gTabSize) = do do_start_shm (m, tabSize, tmOut, spawnImgComp) (workers, gTabSize) = do
selfNode <- getSelfNode node <- getSelfNode
pid <- spawnLink selfNode ($(mkClosure 'init) (tabSize, tmOut, spawnImgComp)) say $ "---- i got a node id " ++ show m ++ " " ++ show tabSize ++ " " ++ show tmOut ++ " " ++ show workers
pid <- spawnLink node ($(mkClosure 'init) (tabSize, tmOut, spawnImgComp))
say "---- after spawnLink"
do_start_shm (m - 1, tabSize, tmOut, spawnImgComp) do_start_shm (m - 1, tabSize, tmOut, spawnImgComp)
((pid, gTabSize, tabSize) : workers, gTabSize + tabSize) ((pid, gTabSize, tabSize) : workers, gTabSize + tabSize)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment