Orbit for the cloud in Cloud Haskell!
This is a shameless translation from the original Orbit-int written in Erlang by Patrick Maier P.Maier@hw.ac.uk.
Make the executable
make
-
Sequential Orbit
./orbit seq short|intermediate|long host port # Example: executing the 'long' benchmark ./orbit seq long 127.0.0.1 1555
-
Parallel Orbit
./orbit par True|False short|intermediate|long nWorkers host port # Example: executing the 'long' benchmark with parallel image # computations using 4 workers on 4 cores ./orbit +RTS -N4 -RTS par True long 4 127.0.0.1 1555
-
Distributed Orbit
First, start the worker nodes.
# Run for every worker node ./orbit dist slave host port # Example: run a worker node on 4 cores ./orbit +RTS -N4 -RTS dist slave 127.0.0.1 1554
Once all the workers nodes have been deployed on the local network, start the master node.
./orbit dist master True|False short|intermediate|long nWorkers host port # Example: executing the 'long' benchmark without parallel image # computations, using 4 workers on each node and the master node # running on 2 cores ./orbit +RTS -N2 -RTS dist master long 4 127.0.0.1 1555
We have created some Python scripts to automatically run sample configurations of the sequential, parallel and distributed Orbit.
Python 2.x is needed in order to run the scripts.
-
Sequential Orbit
python seq.py
Variables that can be tweaked with their default values.
# Path to the file that will hold the results. fname = 'seq.log' # Number of repetitions per configuration. reps = 1 # List of versions. versions = ["short", "intermediate", "long"] # Host information. node = {"host": "127.0.0.1", "port": 5050}
-
Parallel Orbit
python par.py
Variables that can be tweaked with their default values.
# Path to the file that will hold the results. fname = 'par.log' # Number of repetitions per configuration. reps = 1 # List of versions. versions = ["short", "intermediate", "long"] # Perform parallel image computations iwps = [False, True] # No of cores used cores = [1,2,4,8,16] # Ratio of No of workers to No of cores. workersPerCore = 1 # Host information. node = {"host": "127.0.0.1", "port": 5050}
-
Distributed Orbit
python dist.py
Variables that can be tweaked with their default values.
# Path to the file that will hold the results. fname = 'dist.log' # Number of repetitions per configuration. reps = 1 # List of versions. versions = ["short", "intermediate", "long"] # Perform parallel image computations. iwps = [False, True] # No of cores used by each worker node. cores = [1] # Ratio of No of workers to No of cores in each worker node. workersPerCore = 1 # Master node information master = {"host": "127.0.0.1", "port": 5050} # Maximum number of workers nodes maxSlaves = 60 # No of workers nodes to add after each iteration step = 2 # Port of the 1st worker node (Assume that the host will be localhost). workerPort = 5051
-
Compile with enabled profiling
make prof
-
Run with the proper RTS options
# Example: executing the 'long' benchmark ./orbit +RTS -hd -p -RTS seq long 127.0.0.1 1555
-
Prepare the report
make prof-results
-
Compile with enabled event logging
make threadscope
-
Run with the proper RTS options
# Example: executing the 'long' benchmark ./orbit +RTS -ls -RTS seq long 127.0.0.1 1555
-
Open the report with threadscope
threadscope orbit.eventlog
Written by:
- Yiannis Tsiouris gtsiour@softlab.ntua.gr
- Aggelos Giantsios aggelgian@softlab.ntua.gr