June 3, 2010
Revised: Dec. 20, 2011
Welcome to BrainGrid! This document contains everything you need to get started.
TortoiseSVN is popular on Windows, while MacOS and Linux have several free options.
BrainGrid source code is kept on homer.u.washington.edu. The Subversion repository is accessible via SSH. To get access, you must provide Professor Stiber with an RSA public key. To do this, run the following at a Linux or Mac command line:
ssh-keygen -t rsa
Accept the default file name, and the password can be left blank (if you're feeling paranoid, a password can be entered.) Two files will be created. The private key, id_rsa, should be kept on the computers you plan to run a subversion client on. Send the public key, id_rsa.pub, to Professor Stiber.
After Professor Stiber has granted you access, you must configure your Subversion client for ssh access. The steps vary depending on the client. From a Linux/Mac command line, svn can be configured by editing ~/.subversion/config to include the following line under [tunnels] section:
biocomp = /usr/bin/ssh -p 22 -q -l biocomp -i /Users/username/.ssh/id_rsa
This creates a “svn+biocomp” tunnel scheme (where you need to change “/Users/username/.ssh/id_rsa” to be the full path to your private key). For configuring other clients, see <http://wiki.site5.com/SVN/Subversion_(SVN)_Setup_Guide> near the bottom for clues. From the command line, you can try
svn --verbose list svn+biocomp:%%//homer.u.washington.edu/BrainGrid/trunk%%
Once you have a connection set up, you can do a check out do get a local copy of the source code.
After getting a local copy of the source, you can build. Run ‘make’ to make the braingrid project. Three executable will be created:
growth - Single-threaded version. growth_omp - Multi-threaded version (OMP). growth_gpu - GPU version (C UDA).
If “PERFORMANCE_METRICS” is defined, cumulative executable time of each kernel function will be shown. “-maxrregcount” is a nvcc compiler option, which set the maximum number of registers used within each kernel function. “include/bgtypes.h” defines the type of floating point (double or single). To make the Matlab post-processing modules, run ‘make’ from the MATLAB subdirectory.
To run the simulator, invoke the exe you just built. BrainGrid requires at least one parameter:
./growth -t input.xml.
This input file provides simulation parameters and the name of the output file. If you wish to provide the output file name on the command line, you can use this syntax:
./growth -t input.xml -o output.xml.
“-w” option specifies the name of an output file, which saves the memory image of neurons, synapses, firing rate, and radii of the final state. “-r” option specifies the name of an input files, which was saved by “-w” option. When the option is added, the simulator restores the previous state and continues simulation.
./growth -t input.xml -w state.dat ./growth -t input.xml -r state.dat
“-d” option is for the GPU version only, and specifies the device ID of GPU.
./growth_gpu -t input.xml -d 0
In windows similarly without the ‘./’:
growth -t input.xml
growth -t input.xml -o output.xml.
You can run Matlab from any of the UW1-320 Linux machines. The name of the Matlab script is ‘batch’. In order to invoke it correctly, you need to add the path to the matlab post-processing modules:
addpath '/home2/username/BrainGrid/MATLAB' –BEGIN
Substitute the string in quotes for the full path to your MATLAB subdirectory. Name your output file ‘historyDump.xml’, copy it to ‘/home2/username/BrainGrid’ and run ‘batch’. If run successfully, 5 plots will be generated and saved as 01 – 05_historyDump.jpg in the current working directory.
The main simulation loop is in the Network class. The advance() method invokes interface implementations of advanceUntilGrowth().
#bash shell #one time startxwin #every time DISPLAY=:0;export DISPLAY ssh -c arcfour,blowfish-cbc -XC hydra.uwb.edu DISPLAY=:0;export DISPLAY ssh -c arcfour,blowfish-cbc -XC uw1-320-17.uwb.edu To make processes run in the background after logging out: screen # Run command ./growth -t input.xml # Detach screen with control-A followed by ‘d’ ^A d