Skip to content

Commit

Permalink
Merge pull request #278 from openworm/development
Browse files Browse the repository at this point in the history
Merge for 0.8
  • Loading branch information
slarson authored Feb 19, 2018
2 parents ea2a628 + eaa93a9 commit a47399b
Show file tree
Hide file tree
Showing 8 changed files with 117 additions and 41 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
.DS_Store
output/C2*

33 changes: 16 additions & 17 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -77,16 +77,16 @@ WORKDIR $HOME

RUN mkdir neuron && \
cd neuron && \
git clone https://github.com/lungd/iv.git && \
git clone https://github.com/lungd/nrn.git && \
git clone https://github.com/nrnhines/iv.git && \
git clone https://github.com/nrnhines/nrn.git && \
cd iv && \
git checkout ow-0.1 && \
git checkout 76c123b && \
./build.sh && \
./configure --prefix=`pwd` && \
make && \
sudo make install && \
cd ../nrn && \
git checkout ow-0.1 && \
git checkout e0950a1 && \
./build.sh && \
./configure --prefix=`pwd` --with-iv=$HOME/neuron/iv --with-nrnpython=/usr/bin/python --with-paranrn && \
make && \
Expand Down Expand Up @@ -114,29 +114,28 @@ RUN wget http://registrationcenter-download.intel.com/akdlm/irc_nas/vcp/11705/in
cd $HOME && \
rm intel_sdk_for_opencl_$INTEL_SDK_VERSION.tgz && \
sudo rm /tmp/silent-intel-sdk.cfg

RUN git clone https://github.com/lungd/jNeuroML.git && \
cd jNeuroML && \
git checkout ow-0.1 && \
python getNeuroML.py ow-0.1

RUN git clone https://github.com/lungd/pyNeuroML.git && \
RUN git clone https://github.com/NeuroML/pyNeuroML.git && \
cd pyNeuroML && \
git checkout ow-0.1 && \
git checkout ow-0.8a && \
sudo python setup.py install

RUN git clone https://github.com/lungd/PyOpenWorm.git && \
RUN git clone https://github.com/openworm/PyOpenWorm.git && \
cd PyOpenWorm && \
git checkout ow-0.1 && \
git checkout 7ff1266 && \
sudo python setup.py install

RUN git clone https://github.com/lungd/CElegansNeuroML.git && \
RUN git clone https://github.com/openworm/CElegansNeuroML.git && \
cd CElegansNeuroML && \
git checkout ow-0.1
# Pointing this at a recent commit that adds python 3 support!
# https://github.com/openworm/CElegansNeuroML/commit/c8b13642d79335bb8157431b83624e33d50a166e
git checkout c8b1364

RUN git clone https://github.com/lungd/sibernetic.git && \
RUN git clone https://github.com/openworm/sibernetic.git && \
cd sibernetic && \
git checkout ow-0.1 && \
# fixed to a specific commit in development branch:
# https://github.com/openworm/sibernetic/commit/3eb9914db040fff852cba76ef8f4f39d0bed3294
git checkout 3eb9914 && \
make clean && make all

ENV JNML_HOME=$HOME/jNeuroML
Expand Down
60 changes: 50 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ We are using a bottom-up approach, aimed at observing the worm behaviour emerge

Quickstart
----------
We have put together a [docker container](http://docker.com) that pulls together the major components of our simulation and runs it on your machine. When you get it all running it do the following:
We have put together a [docker container](http://docker.com) that pulls together the major components of our simulation and runs it on your machine. When you get it all running it does the following:

1. Run our nervous system model, known as [c302](https://github.com/openworm/CElegansNeuroML/tree/master/CElegans/pythonScripts/c302), on your computer.
2. Run our body model, known as [Sibernetic](https://github.com/openworm/sibernetic), on your computer, using the output of the nervous system model.
Expand All @@ -24,13 +24,13 @@ We have put together a [docker container](http://docker.com) that pulls together

<img src="img/muscle-activity.png" width="250"><img src="img/neuron-activity.png" width="350">

**NOTE**: Running the simulation for the full amount of time would produce content like the above. However, in order to run in a reasonable amount of time, the default run time for the simulation is limited. As such, you will see only a partial output, equivalent to about 5% of run time, compared to the examples above.
**NOTE**: Running the simulation for the full amount of time would produce content like the above. However, in order to run in a reasonable amount of time, the default run time for the simulation is limited. As such, you will see only a partial output, equivalent to about 5% of run time, compared to the examples above. To extend the run time, use the `-d` argument as described below.

**Installation**

Pre-requisites:

1. Currently Windows is not supported; you will need Mac OS or Linux (or a virtual environment on Windows that runs either of those).
1. Currently Windows is not supported (see https://github.com/openworm/OpenWorm/issues/263); you will need Mac OS or Linux (or a virtual environment on Windows that runs either of those).
2. You should have at least 60 GB of free space on your machine and at least 2GB of RAM

To Install:
Expand All @@ -39,23 +39,63 @@ To Install:

**Running**

1. Open a terminal and run `run-shell-only.sh`.
2. Run `DISPLAY=:44 python master_openworm.py`.
3. About 5-10 minutes of output will display on the screen as the steps run.
4. The simulation will end. Exit the container with `exit` and run `stop.sh` on your system to clean up the running container.
5. Inspect the output in the `output` directory.
1. Open a terminal and run: `git clone http://github.com/openworm/openworm`; `cd openworm`
1. Run `./run.sh`.
2. About 5-10 minutes of output will display on the screen as the steps run.
3. The simulation will end. Exit the container with `exit` and run `stop.sh` on your system to clean up the running container.
4. Inspect the output in the `output` directory.

**Advanced**

Try the following to play around with the system:
***Arguments***

* -d [num] : Use to modify the duration of the simulation in milliseconds. Default is 15. Use 5000 to run for time to make the full movie above.

***Other things to try***

* Open a terminal and run `run-shell-only.sh`. This will let you log into the system before it has run `master_openworm.py`. From here you can inspect the internals of the various checked out code bases and installed systems and modify things. Afterwards you'll still need to run `stop.sh` to clean up.
* If you modify what gets installed, you should modify Dockerfile. If you modify what runs, you should modify `master_openworm.py`. Either way you will need to run `build.py` in order to rebuild the image locally. Afterwards you can run normally.

### FAQ

#### **What is the docker container?**

The docker container is a self-contained environment in which you can run openworm simulations. It's fully setup to get you started by following the steps above. At the moment, it runs simulations and produces visualizations for you, but these visualizations must be viewed outside of the docker container.

#### **Is it possible to modify the simulation without having to run `build.py`?**

Yes, but it is marginally more complex. The easiest way is to modify anything in the docker container once you are inside of it - it will work just like a bash shell. If you want to modify any code in the container, you'll need to use an editor that runs in the terminal, like nano. Once you've modified something in the container, you don't need to re-build. However, if you run `stop.sh` once you exit, those changes will be gone.

#### **How do I access more data than what is already output?**

The simulation by default outputs only a few figures and movies to your home system (that is, outside of the docker container). If you want to access the entire output of the simulation, you will need to copy it from the docker container.

For example, say you want to extract the worm motion data. This is contained in the file `worm_motion_log.txt`, which is found in the `/home/ow/sibernetic/simulations/[SPECIFIC_TIMESTAMPED_DIRECTORY]/worm_motion_log.txt`. The directory `[SPECIFIC_TIMESTAMPED_DIRECTORY]` will have a name like `C2_FW_2018_02-12_18-36-32`, and its name can be found by checking the `output` directory. This is actually the main output directory for the simulation, and contains all output, including cell modelling and worm movement.

Once the simulation ends and you exit the container with `exit`, but before you run `stop.sh`, run the following command from the openworm-docker-master folder:

`docker cp openworm:/home/ow/sibernetic/simulations/[SPECIFIC_TIMESTAMPED_DIRECTORY]/worm_motion_log.txt ./worm_motion_log.txt`

This will copy the file from the docker container, whose default name is `openworm`. **It is crucial that you do not run `stop.sh` before trying to get your data out (see below)**

#### **What is the difference between `exit` and `stop.sh`?**

When you are in the Docker Container `openworm`, and are done interacting with it, you type `exit` to return to your system's shell. This stops execution of anything in the container, and that container's status is now `Exited`. If you try to re-start the process using `run-shell-only.sh`, you will get an error saying that the container already exists. You can choose, at this point, to run `stop.sh`. Doing so will remove the container and any files associated with it, allowing you to run a new simulation. However, if you don't want to remove that container, you will instead want to re-enter it.

#### **How do I enter a container I just exited?**

If you run `stop.sh` you'll delete your data and reset the container for a new run. If, however, you don't want to do that, you can re-enter the docker container like this:

sudo docker exec -it openworm bash

You'll need to enter your su password. This tells docker to all you to *execute* commands (`exec`) with an *interactive, tty* (`-it`) bash (`bash`) shell in the container `openworm`.

You'll be able to interact with the container as before.

Documentation
-------------
Find out more about OpenWorm. Documentation is available at [http://docs.openworm.org](http://docs.openworm.org). [Join us on Slack](http://bit.ly/OpenWormVolunteer).

This repository references:
* A project-wide [Kanban board of all issues](https://waffle.io/openworm/openworm)
* Project-wide tracking via high-level [issues](https://github.com/openworm/OpenWorm/issues?labels=&milestone=&page=1&state=open) and [milestones](https://github.com/openworm/OpenWorm/milestones)
* Project-wide tracking via high-level [issues](https://github.com/openworm/OpenWorm/issues?labels=&milestone=&page=1&state=open) and [milestones](https://github.com/openworm/OpenWorm/milestones)
2 changes: 1 addition & 1 deletion build.sh
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
#!/bin/bash

docker build -t "openworm/openworm:0.7" .
docker build -t "openworm/openworm:0.8" .
8 changes: 6 additions & 2 deletions master_openworm.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
import math

print("****************************")
print("OpenWorm Master Script v.0.7")
print("OpenWorm Master Script v.0.8")
print("****************************")
print("")
print("This script attempts to run a full pass through the OpenWorm scientific libraries.")
Expand Down Expand Up @@ -106,8 +106,12 @@ def execute_with_realtime_output(command, directory, env=None):
print("Unexpected error: %s" % sys.exc_info()[0])
raise

#Default is 15 ms of simulation time.
sim_duration = 15.0
if 'DURATION' in os.environ:
sim_duration = float(os.environ['DURATION'])

DEFAULTS = {'duration': 15.0, # 50 ms
DEFAULTS = {'duration': sim_duration,
'dt': 0.005,
'dtNrn': 0.05,
'logstep': 100,
Expand Down
1 change: 1 addition & 0 deletions output/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
The output produced after running simulations in the Docker container will be saved here (in your native filesystem).
2 changes: 1 addition & 1 deletion run-shell-only.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,6 @@ docker run -ti \
-v /tmp/.X11-unix:/tmp/.X11-unix:rw \
--privileged \
-v $HOST_OUT_DIR:$OW_OUT_DIR:rw \
openworm/openworm:0.7 \
openworm/openworm:0.8 \
bash

49 changes: 39 additions & 10 deletions run.sh
Original file line number Diff line number Diff line change
@@ -1,17 +1,46 @@
#!/bin/bash

#from: https://unix.stackexchange.com/a/129401
while getopts ":d:p:" opt; do
case $opt in
d) duration="$OPTARG"
;;
p) p_out="$OPTARG"
;;
\?) echo "Invalid option -$OPTARG" >&2
;;
esac
done

OW_OUT_DIR=/home/ow/shared
HOST_OUT_DIR=$PWD

xhost +

docker run -d \
--name openworm \
--device=/dev/dri:/dev/dri \
-e DISPLAY=$DISPLAY \
-e OW_OUT_DIR=$OW_OUT_DIR \
-v /tmp/.X11-unix:/tmp/.X11-unix:rw \
--privileged \
-v $HOST_OUT_DIR:$OW_OUT_DIR:rw \
openworm/openworm:0.7 \
python master_openworm.py
if [ -z "$duration" ]
then #duration is not set, don't use it
docker run -d \
--name openworm \
--device=/dev/dri:/dev/dri \
-e DISPLAY=$DISPLAY \
-e OW_OUT_DIR=$OW_OUT_DIR \
-v /tmp/.X11-unix:/tmp/.X11-unix:rw \
--privileged \
-v $HOST_OUT_DIR:$OW_OUT_DIR:rw \
openworm/openworm:0.8 \
bash -c "DISPLAY=:44 python master_openworm.py"
else #Duration is set, use it.
docker run -d \
--name openworm \
--device=/dev/dri:/dev/dri \
-e DISPLAY=$DISPLAY \
-e DURATION=$duration \
-e OW_OUT_DIR=$OW_OUT_DIR \
-v /tmp/.X11-unix:/tmp/.X11-unix:rw \
--privileged \
-v $HOST_OUT_DIR:$OW_OUT_DIR:rw \
openworm/openworm:0.8 \
bash -c "DISPLAY=:44 python master_openworm.py"
fi

docker logs -f openworm

0 comments on commit a47399b

Please sign in to comment.