===== Yuko's Scribbles ===== Computational Neuroscience Seminars: http://pdl.brain.riken.jp/staff/dalex/computational_neuroscience_seminar/ Yuko Hara Toshima-ku Kanamecho 1-15-3 Frais Kanamecho #402, Tokyo, JAPAN 171-0043 c/o RIKEN Brain Science Institute 2-1 Hirosawa, Wako-shi, Saitama JAPAN 351-0198 Tel: +81 (048) 462-1111 x7069 tel: +81 (90) 6106-1358, yuko.hara@brain.riken.jp Technical Staff () Gardner Research Unit RIKEN Brain Science Institute 2-1 Hirosawa, Wako-shi, Saitama JAPAN 351-0198 Tel: +81 (048) 462-1111 x7069 yuko_hara@brain.riken.jp Education Yale University, New Haven, CT, USA (May 2009) Bachelor of Science in Biomedical Engineering Coursework includes Differential Equations, Probability Theory, Linear Algebra, Signals and Systems, Image Processing and Analysis, Physics Christine Larson Nelson Memorial Scholarship for Engineering and Applied Sciences Punahou School, Honolulu, HI, USA (June 2005) High School Diploma with Honors President's Award, Principal's Award ('04, '05) =====Before you run dofmrigru at all...===== ====Informed Consent forms==== At the end of your experiment, make a copy of the scan log, RRC consent form, and RRC questionnaire. The RRC needs these documents filed in their respective folders downstairs with the magnet. The copies are for GRU to keep. The set of forms that needs to be filed for GRU records are: - completed GRUExpProtocol document (available in gru svn repository) - GRU explanation and informed consent forms - (optional but useful) copy of RRC scan log - (optional but useful) copy of RRC informed consent - (optional but useful) copy of RRC questionnaire A set of originals as well as a set of copies needs to be filed in a secure cabinet in Justin's office. Usually, Kenji can take care of this for you but always good to know what's going on. Kenji will also update the secure linkable annonymity (sp?) chart and non-online scan history chart as needed. Now, an electronic copy of JUST THE GRU EXPERIMENT PROTOCOL SHEETS should be emailed to yourself so you can keep them with the scan directory on usr1. Use the GRU scanner upstairs to **email a pdf copy (under filename, type s###yyyymmdd_protocol) to youraddress@brain.riken.jp**. Where to file them will be discussed below... ===="Hot off the scanner" datadir, usr1/justin/data==== The GRU data directory on usr1, 'usr1/justin/data', will contain all hot-off-the-scanner fids. We will dump everything related to the scan in here - protocol sheets, car/ext files, stimfiles, etc. - and dofmrigru is designed to look in this directory and grab what we need into your local directory. Ultimately, datadir acts like a backup copy of your original data. In case you haven't already, mount usr1 (scan data from downstairs) and usr4 (contains the functions you will need to process your data). Open 'Connect to Server' (apple-K on Desktop) Server Address: nfs://is/Volumes/usr1 Server Address: nfs://is/Volumes/usr4 Click Connect. If you ls /usr1/justin/data in Terminal, a directory called s###yyyymmdd should already exist with fids, car/ext files, and stim files from downstairs. Now, save emailed s###yyymmdd_protocol.pdf document into /usr1/justin/data/s####yyyymmdd. You're also encouraged to **carefully** clean up /usr1/justin/data/s####yyyymmdd. Look over your GRUExpProtocol sheet and delete irrelevant stimfiles or car/ext files that were scrapped downstairs. But be careful! Make sure that your 3d anatomy was processed (was fftw3rd run before saving downstairs?). If some fid names contain periods '.' in the filename besides the extension, fix them (in matlab, there is a function called fixbadchars). ====Update Online Scan History==== This is also a good time to update your online [[grupub:scanhistory|Scan History]]. Make notes if you were sleepy in some runs, if some car/ext files may be corrupt/need to be checked... Now you're ready to run dofmrigru. Read on... =====Run dofmgrigru, First pass===== The first pass of dofmrigru will grab and sort files from datadir into your newly created scan directory. It will run some initial processing scripts and set you up for the second pass of dofmrigru. First make an new **empty** scan directory in your local data directory. mkdir ~/data/Experiments/s###yyyymmdd If your scan was a retinotopy, your scan directory may be ~/data/Retinotopy/s###yyyymmdd Now, cd to this empty scan directory and start matlab (make sure you've already run X11 so your windows show up) cd s###yyyymmdd matlab -nodesktop pwd pwd should return the scan directory. To run dofmrigru, type into the matlab terminal dofmrigru The dofmrigru script defaults to grabbing files from datadir /usr1/justin/data/s###yyyymmdd. If you happen to have your own "hot off the scanner" data directory (like /usr1/yourname/data) you can tell dofmrigru to look there instead by passing in the argument dofmrigru('dataDir=/usr1/yourname/data'). In your terminal, dofmrigru should print a list of files that it found in your datadir. Some things to check for: - If you took both a 2d and 3d anatomy during your session, were they both picked up? If not, it may not have been processed (fftw3rd) downstairs. - If running sense (actually, this page is written for sense processing using dofmrigru) make sure that both your reference and noise scans were picked up. - If you copied the electronic version of your experiment protocol form into your own data directory, a pdf should have been picked up. - Were all your relevant stimfiles found? Check your protocol notes. Now, a window should pop up (often behind your terminal window if you're using X11) 'Match the car file with the scan.' Refer back to your experiment protocol sheet and check that the correct CAR/EXT (not stim!) files are matched with the correct scans (sometimes, car/exts are scrapped downstairs so check each number and make note of skipped files. The start and end timestamps may be useful if you're not sure which car/exts were terminated early). Use the arrow '>' button to toggle between scans. Press OK.
{{:grupub:screen_shot_2010-02-23_at_17.23.52.png|}}
Your terminal should now print a list of commands that dofmrigru, first pass will run. Check that the car/exts are being dumped into their corresponding fid directories. At prompt 'OK to run above commands? (y/n)?' type 'y.' The printed commands will be executed. Copying fid files and epirri5 processing will all take some time (on mrdarcy, 3minutes for 10fids). All terminal screen printouts will be logged in a text file called 'logbook.' A mrInit window to 'Initialize session for mrTools' in s###yyyymmdd will pop up. Fill in the blanks and press Ok.
{{:grupub:screen_shot_2010-02-23_at_17.38.41.png|}}
Another window 'Choose group parameters' will pop up so you can link the correct stimfiles to each scan. This can be done manually later, but it is much easier to do now when you have your protocol sheet in front of you. The Copy Parameters button will let you copy the current scan description, nFrames, and junkFrames to other scans of the same type.
{{:grupub:screen_shot_2010-02-23_at_17.42.24.png|}}
Here are some scan descriptions that GRU recommends (esp if you're using any of yuko's functions like shiftAvg or sdtDotsAnalysis... scan descriptions will start to matter): **For Retinotopy** - scanDescription: 'rings expanding' and 'rings contracting' - scanDescription: usually, dir=-1 is 'wedge CW' and dir=+1 is 'wedge CCW' <- pay attention to non-pluralness and order - junk the first 8 frames (half cycle) **For sdtDots** - sdtDots vanilla co5, 310 frames, don't junk - sdtDots mixed co335, 310 frames, don't junk - sdtDots localizer co100, 310 frames, don't junk - block localizer, 210 frames but junk the first 10 frames = 200 frames (tr1.2s, 12s on, 12s off, 20 frames per cycle, junk first half cycle) Click OK. Prompt will show up in matlab terminal, 'Do you want to append any notes? (y/n)?' type 'n.' A window will ask you to 'Set motionComp parameters'. Note that motionComp will actually be run at the end of the second pass, but we will be setting the parameters now.
{{:grupub:screen_shot_2010-02-23_at_18.18.54.png|}}
- default interpolation Method 'linear' is correct. - 'baseScan' should be set to whichever run was taken closest to the session anatomical that you will be using to align - usually the first scan since the session anatomical is taken in the beginning of the experiment (not the case right now since we are still wondering if we should replace the 2danat scan with the 3danat). - 'baseFrame' should be set to 'mean' (not default as of 23 feb '10) - **sliceTimeCorrection should be UNCHECKED (not default as of 23 feb 2010)** - press '**Set crop region**' and the reconstructed sense reference image should show up. cropping in mrTools (like mrAlign) is for image normalization only, so don't worry if you're not including all of the slices. just aim to capture as many slices as you reasonably can with gray matter in it. crop so that most of the cropped region is the brain and not the skull or background noise:
{{:grupub:screen_shot_2010-02-23_at_18.09.47.png|}}
Click OK. You are done with dofmrigru's first pass!=====things to do before dofmrigru, second pass===== The second pass of dofmrigru will perform physiofix and sense reconstruction, as well as a full motion comp. - Sense reconstruction will require a hand-drawn mask around the brain (and anything non-noise) - Physiofix will require that you have run a usr4 program called 'peak' Here's how to do both... ====Draw the Mask==== The mask will be a hand drawn ROI around your sense reference image. dofmrigru created a dummy mrLoadRet directory to allow you to do this in folder 'Pre'. Draw the ROI in mrLoadRet and export it as a nifti file mask.img/hdr into Pre. Here are the details: In your scan directory, start matlab (and X11): cd ~/data/Experiments/s###yyyymmdd matlab -nodesktop pwd pwd should return your scan directory. In matlab, move into your Pre/Mask directory and begin mrLoadRet for mask drawing. cd ./Pre/Mask mrLoadRet Your sense reference image should try to load automatically. **Choose any frame but 0 or 1** (frame 1 contains the nav echo... a white streak and no brain).
{{:grupub:screen_shot_2010-02-23_at_19.26.51.png|}}
You should see a sense reconstructed brain in mrLoadRet
{{:grupub:screen_shot_2010-02-23_at_19.27.23.png|}}
Make sure you are on the first slice and go to ROI>Create>Polygon (or apple-P). 'Create a new ROI' window should pop up. Name this ROI 'mask' and choose a color that will stand out against black. Click OK. Your pointer should have turned into a cross. This means you are in the polygon drawing mode and you should finish drawing a polygon before clicking other buttons to avoid running into errors. Draw a generous polygon around any part of the image that is not "black" whether it be brain or wrapped skull. You want to unfold as much of the non-noise image as possible during the sense reconstruction. Note that your polygon crosshairs can spill out of the image window into the figure background - in the end, when you double click and close the polygon, your ROI will be restricted to the image boundaries. Click away!
{{:grupub:screen_shot_2010-02-23_at_19.31.40.png|}}
Make sure your pointer is back to its original shape, not the cross, and slide over to slice 2. Go to ROI>Add>Polygon (apple-O) and draw another generous polygon around the brain. Repeat until you have encircled the brain in all slices. You can add or subtract polygons from your image using apple-O or apple-W. Once you have created a mask ROI spanning all slices, you might want to save it to the s###yyyymmdd/Pre/Mask/ROIs directory. File>Export>ROI and you should get a window 'Specify name of nifti file to export ROI to'. The name should include the word 'mask' (like mask.img) and should be exported to the **s###yyyymmdd/Pre** directory, which is not usually the default directory. Make sure you are in the parent Pre directory, not parentPre/Mask/Pre!
{{:grupub:screen_shot_2010-02-23_at_19.47.32.png|}}
You are done creating the mask.img/hdr in Pre. ====!Peak==== Physiofix will need you to have run 'peak' in every fid that you want to physiofix. The relevant car file should have been dumped into the corresponding fid directory in Pre during the first pass of dofmrigru. All three output "peak files" (respriatory, cardio, and acquisition) should be inside each fid directory before the second pass of dofmrigru is run. If you are missing any peak files, dofmrigru will assume that you want to skip that physiofix. One thing to remember is that 'peak' is not justin's matlab command, peak.m, but a command found in usr4. The path is /usr4/local/mac_bin2/peak. If matlab is still running in your terminal, you will need to type this command with an exclamation point like this: !peak to tell matlab it is an external command. In matlab, type !which peak to check that the non-matlab "peak" command is indeed aliased to /usr4/local/mac_bin2/peak. If not, check that usr4 is mounted (see above), and type !alias peak '/usr4/local/mac_bin2/peak' <- not sure if this is the right format... If you are running this outside of matlab, just omit the exclamation point. If you do not have XCode properly installed, you will get the following error message: >> !peak ----- Peak version 1.12 [2009.Jan.28] ----- sh: /usr/bin/cpp: No such file or directory Endian type (CPU) : Little When you run peak, this window should pop up:
{{:grupub:screen_shot_2010-02-23_at_19.59.50.png|}}
Go to 'Load raw' in the upper right corner and look for the first fid directory in Pre. Inside this fid directory, you should see the corresponding car/ext file pair. The car file contains the information needed for physiofix (ext contains other information like square waves for button presses). Select that car file and click OK.
{{:grupub:screen_shot_2010-02-23_at_20.01.26.png|}}
Your car file should have been loaded. The magenta spikes (tightly packed) are the acquisitions and the blue sinusoid is your physiological signal. Below the Load raw button should be three radio buttons - respir, cardio, and acq. Clcik on the 'respir' radio button. We will start with your respiratory peaks.
{{:grupub:screen_shot_2010-02-23_at_20.07.08.png|}}
Click the 'Smooth' button in the right column. You should see that your noisy respiration data was smoothed by the green line. Usually, the default settings are good, but in case the smoothing looks bad, try playing with the smooth window (Less or More buttons) and smooth again.
{{:grupub:screen_shot_2010-02-23_at_20.13.38.png|}}
After smoothing, click the 'Find Peaks' button in the right column. Vertical yellow lines should hit at every peak. Sometimes, peaks will be missed, other times, peaks will be indicated in obvious rifts due to noise. As a rule of thumb, try to make the "peaks" occur in even intervals. If you're missing peaks because of signal drop out (sniusoid is just a flat line), place peaks at even intervals. You can add and remove peaks using the right mouse button.
{{:grupub:screen_shot_2010-02-23_at_20.17.06.png|}}
The gray slider below the black peaks window will let you toggle through the entire range of the recording. Make sure that all peaks are marked. Note that you will need to place at least one peak before and one peak after the acquisition pulse train to run physiofix. If there happens to be no peak at the beginning or end of the acquisition period (magenta spikes), mark an arbitrary one at a reasonable frequency. Once all peaks are marked, click 'Save peaks' in the right column above the Quit button (easy to mix this up with 'Save raw'... but you want 'Save peaks'). Keep the default naming and click save. respir.peak.bit should have been saved inside the corresponding fid directory.
{{:grupub:screen_shot_2010-02-23_at_20.25.25.png|}}
Repeat the process for the cardio radio button. Finding peaks in cardio signals are harder. Repeat the process for the acq radio button, but skip the smoothing process. Just click "Find peaks" and "Save peaks." If you look at your fid directory in Finder, you will notice that three new peak files: - respir.peak.bit - cardio.peak.bit - acq.peak.bit have been saved inside. Now you have finished running peaks on your first fid!! Now go do the same for every functional fid... Have fun! ====Checks before you go on to the second pass==== Open up your local scan directory (~/data/Experiments/s###yyyymmdd) using Finder - Look in Pre and make sure that mask.img/hdr exists. - Use the arrow keys to toggle your selection over each functional fid folder in finder and make sure that the three peak files are present in each... if you are missing any peak files, the missing physiofix will be skipped. General note: If you find that you need to rerun dofmrigru, first pass, anytime (like you found that you had linked a corrupted car file, the sense reference.img wasn't copied correctly... lots of things can happen) just move your scan folder to a different foldername such as 's###yyyymmdd_imessedup_deleteme' and create a new directory mkdir s###yyyymmdd (without overwriting your old work) and rerun dofmrigru, first pass. As long as this new directory does not contain folders like 'Pre' or 'Anatomy', the first pass will run. After the first pass is complete, you can drag and drop your old *.peak.bit files into the corresponding fids (just be careful you're in correct fid folder) or your mask.img/hdr pait in to Pre. You don't have to redo everything!
{{:grupub:screen_shot_2010-02-23_at_20.37.26.png|}}
=====Running dofmrigru, Second pass===== Go to your scan directory that now contains Pre/Mask.img and .hdr as well as the three peak.bit files in each fid directory (ls Pre/*.fid/*.peak.bit). cd ~/data/Experiments/s###yyyymmdd Run matlab (after X11) matlab -no desktop pwd pwd should return your scan directory. If the first pass has already been run on this directory (the flags we check for are whether if folders like Pre and Anatomy already exist), then dofmrigru should default to the second pass. Type into the matlab terminal dofmrigru If you are missing any peak files, you will get a prompt asking you if you would like to proceed. Answer yes if you skipped these files intentionally. After Mauro's sense reconstruction, full motion comp will be performed according to the params set in the first pass of dofmrigru. Message "Done" will print when the script is finished. =====Scaling Factor===== sFacs = [1.08468528829887 1.0531954310169 1.05883615483564], finalized on 18jan10. alignment to new canonical 20091216 to 2d, 1st 20100106 to 3d, last 20100112 to 3d doesn't work - 3d doesn't look processed?? to 2d, 1st 20100126 to 3d, last 20100129 to 3d, last 20100202 to 3d, last ===== Tasklist ===== ==== busywork ==== - original informed consent s00120100202 is in copy machine tray... - email it to yourself when riken email server is back up - file the original into cabinet ==== scripts ==== - getDotsAnalInfoPerScan - let it find matching errors, figure out how error bars are plotted and output should be same format - remember that criterion only has one value per scan, even if it is a mixed scan. - label each point with scan num, session name, and scan description - dotsPlot - needs to work for psychophysics, too. - rerun on psychophysics stimfiles ==== mrLoadRet ==== - edit all scan descriptions in the following form: sdtDots vanilla co3 sdtDots localizer co100 sdtDots mixed co335 block localizer - realign and prioritize occiptial area! - concatenated retinotopy!! get rois... mt especially. ==== concatenation across sessions ==== - start off with block localizer - start concatenating two days - do not do filtering, turn off percent signal radio button - do mlorDisplayEPI from mrLoadRet window [[grupub:cueconAnalysisNotes|cueconAnalysisNotes]] [[gru:tasklist|Tasklist]]