How to Process MRI Images:
- Beginner's Guide to Command-Line Interface
- Installation Instructions
- Preprocessing T1 images
- Hippocampus Segmentation
Reading Materials and Lecture Slides
Table of Contents:
[TOC]
The full guide can be found here.
The command-line interface, sometimes referred to as the CLI, is a tool into which you can type text commands to perform specific tasks as opposed to using the mouse to point and click on menus and buttons. Since you can directly control the computer by typing, many tasks can be performed more quickly, and some tasks can be automated with special commands that loop through and perform the same action on many files—saving you, potentially, loads of time in the process.
The application or user interface that accepts your typed responses and displays the data on the screen is called a shell, and there are many different varieties that you can choose from, but the most common these days is the Bash shell, which is the default on Linux and Mac systems in the Terminal application. By default, Windows systems only include the anemic Command Prompt application, which has nowhere near the power of Bash. You can use the open source Cygwin tool as your Windows command line if needed.
To get started with the command line, you'll need to open up a terminal window and get ready to start typing commands. Here's a list of basic commands you can use, organized by the type of activity that you might want to perform.
When you run your terminal application (Cygwin on Windows, Terminal on Mac and Linux), your command prompt will start up pointing to a specific folder on your hard drive. You can navigate between folders, act on files inside those folders, or perform other actions.
First, let's display a list of files inside the active folder. For this task, you'll need to use the ls
command. You can pass a number of parameters to the command to display extra details or change the sorting. For instance, if I add -l
to the end of my ls command, I'll see a detailed listing; -t
will sort the results by file time; -S
will sort by file size; and -r
will reverse the sorting. You could use a combination of these together, like this command, which will show all files sorted by file size with the largest files at the bottom:
#!console
$ ls -lSr
If you use the –a
option, you can see hidden files, and you'll also notice something else in the listing: there are two entries for "." and ".." at the beginning of the list. These represent the current folder—the "." folder—and the parent folder—the ".." folder.
You can change between directories using the cd
command, and using what we just learned about the ".." folder, you can use the following command to switch to the directory directly above the current one:
#!console
$ cd ..
You can navigate to either full or relative paths. For example, the command above navigates to a relative path—one above the current folder. If you're in /path/to/ and you want to navigate to the folder stuff inside that folder, you can simply type:
#!console
$ cd stuff
You can also navigate to absolute paths. Again, if I were in /path/to/ and I want to navigate to /another/path/, I would simply type:
#!console
$ cd /another/path
To swap directories to the previous working directory, the '-' (hyphen) shortcut is handy to have on hand. For example, if you were in the /first/folder/path/ directory and then switched over to /etc/ to make a configuration change, you might not want to type in the full path to switch back. You can quickly switch back to the previous working directory with this command:
#!console
$ cd -
To create a new folder, you can simply use the mkdir <foldername>
command. You can then remove any folder with the rmdir <foldername>
command—as long as the folder is empty. If there are files in the folder, you'll have to delete those files before you can remove the folder.
You can use the touch <filename>
command to create a new, blank file, and then use the rm <filename>
command to delete files:
#!console
$ rm filename
You can quickly remove all files in a directory by using the '*' (asterisk) wildcard—another simple tool that will come in very handy during your time in the command line. For example, if you're in a folder and want to delete every file inside that folder, just type:
#!console
$ rm *
If you want to delete a list of files and folders, including all files from subdirectories, without prompting you for every single entry, you can use the -r option for recursive, and the -f option for force. This command will wipe out every instance of a matching filename pattern (note the slightly different use of the wildcard) from the current directory and below:
#!console
$ rm -rf filename.*
The following commands will be extremely useful to know when trying to run a whole set of participants at once. These commands go beyond the basic command lines.
If you have an application or shell script in the current folder, you can't simply type the name of the command and expect it to start. You'll need to add a ./ to the beginning of the command in order to start it. Why? Because in the Bash shell, the current directory, or "." folder, is not included in the system path. So to launch scriptname.sh in the current folder, you'll need to use:
#!console
$ ./scriptname.sh
You can use the very powerful find
command to search for files on your system. For instance, if you wanted to find all files with .txt in the name that were modified in the last 5 days, you would use this command:
#!console
$ find . -name "*.txt" -mtime 5
The grep
command can be used to quickly find text within files, even searching through subdirectories. For instance, if you wanted to search through all files in the current directory and below it for "text string", you could use this command:
#!console
$ grep -ir "text string" *
##Loops
A loop is a block of code that proliferates a process over a series of values until certain conditions are met. This can be very useful in quickly performing a common process on a series of files all at once.
A basic format for a loop command is:
#!console
$ for <argument> in <value>
> do
> <process executed>
> done
To help you understand loops better we'll go through a couple examples of how they can be used.
Uncompressing a series of .tar.gz files in your "Downloads" folder
#!console
$ FILES=/home/username/Downloads/*.tar.gz
$ for file in $FILES
> do
> tar xvzf $file
> done
In the statement "FILES=/home/username/Downloads/.tar.gz" the variable "FILES" is assigned the list of files in directory (folder) "/home/username/Downloads/", whose name ends with ".tar.gz". The "" (wild card character) stands for any sequence of characters.
In the for-statement "file" is used as the name of the loop variable, which is assigned each of the file names in the list assigned to "FILES". The body of the for-loop (the statements between the "do" and the "done") is executed once for each file name.
If you want to loop through a set of filenames and perform an action on each one, you can use the for
command to loop through a set of files. For instance, to loop through all the .txt files in the current directory and display them on the console, you could use:
#!console
$ for f in *.txt
> do
> echo $f
> done
You can also combine the find command and the loop action to find specific files and then perform an action:
#!console
$ for i in $(find . -name "*.txt" -mtime 5)
> do
> echo $i
> done
You can use the history
command to show a list of all the recently used commands, or the up/down arrows to loop through them. The Ctrl+R shortcut key will start a search mode where you can type the first few characters of a command to search through your recent history.
There are a number of very useful shortcut keys you can use in the bash shell, and it pays to master them all. Here's a couple to get you started:
- Tab: Auto-complete files and folder names
- Ctrl + A: Go to the beginning of the line you are currently typing on
- Ctrl + E: Go to the end of the line you are currently typing on
- Ctrl + L: Clears the Screen, similar to the clear command
- Ctrl + U: Clears the line before the cursor position. If you are at the end of the line, clears the entire line.
- Ctrl + H: Same as backspace
- Ctrl + R: Let’s you search through previously used commands
- Ctrl + C: Kill whatever you are running
- Ctrl + D: Exit the current shell
- Ctrl + Z: Puts whatever you are running into a suspended background process. fg restores it.
- Ctrl + W: Delete the word before the cursor
- Ctrl + K: Clear the line after the cursor
- Ctrl + T: Swap the last two characters before the cursor
- Esc + T: Swap the last two words before the cursor
- Alt + F: Move cursor forward one word on the current line
- Alt + B: Move cursor backward one word on the current line
Read this page https://help.ubuntu.com/community/FilePermissions
The basic message is that in Ubuntu you need to do
#!console
$ sudo chmod ugo+rwx <mango>
To get files to be accessible to everyone.
In other Linux environments you don't need the sudo
command.
When we talk about environment variables in coding we refer to a unique set of functions and code that effect how programs are run beyond what is simply part of the typical operating system.
An example of one you will most likely run into here is:
#!console
$ ARTHOME=/usr/local/art
$ export ARTHOME
If you type this into the command line these values will be active for the remainder of that session (the time that specific command line is open). However, if you want to add an environment variable permanently you need to create a file that contains it. It may be helpful to use one document to store all of your environment variables for you MRI projects. In order to do this you can use the vi
command.
When you use this command you'll want to type the name of the command following it. We'll make a file for the preprocessing_acpcdetect program using the above variables.
#!console
$ vi .preprocessing_acpcdetect
You'll then see a bunch of "~" lining the left side of the screen. This means you're in Vim editor, where you edit and make environment variables. Vim has two modes, insert and command. To go to command press the esc key. To enter insert mode press "i". Now just type the ARTHOME variables above. When you're done press "zz". If you want more details on how to control Vim you can go here.
You can also create a file with the chunk of coding you want and apply ".sh" to the end. If you make such a file in the bin directory you only need to type source nameoffile.sh
to activate those environment variables in a sessions. This can be far easier than having to retype environment variables in for every session.