-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
498 lines (467 loc) · 414 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="generator" content="pandoc" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="author" content="Jonathan D. Clayden, Susana Muñoz Maniega, Amos J. Storkey, Martin D. King, Mark E. Bastin & Chris A. Clark" />
<meta name="date" content="2016-05-18" />
<title>TractoR: Magnetic Resonance Imaging and Tractography with R</title>
<style type="text/css">code{white-space: pre;}</style>
<style type="text/css">
div.sourceCode { overflow-x: auto; }
table.sourceCode, tr.sourceCode, td.lineNumbers, td.sourceCode {
margin: 0; padding: 0; vertical-align: baseline; border: none; }
table.sourceCode { width: 100%; line-height: 100%; }
td.lineNumbers { text-align: right; padding-right: 4px; padding-left: 4px; color: #aaaaaa; border-right: 1px solid #aaaaaa; }
td.sourceCode { padding-left: 5px; }
code > span.kw { color: #007020; font-weight: bold; } /* Keyword */
code > span.dt { color: #902000; } /* DataType */
code > span.dv { color: #40a070; } /* DecVal */
code > span.bn { color: #40a070; } /* BaseN */
code > span.fl { color: #40a070; } /* Float */
code > span.ch { color: #4070a0; } /* Char */
code > span.st { color: #4070a0; } /* String */
code > span.co { color: #60a0b0; font-style: italic; } /* Comment */
code > span.ot { color: #007020; } /* Other */
code > span.al { color: #ff0000; font-weight: bold; } /* Alert */
code > span.fu { color: #06287e; } /* Function */
code > span.er { color: #ff0000; font-weight: bold; } /* Error */
code > span.wa { color: #60a0b0; font-weight: bold; font-style: italic; } /* Warning */
code > span.cn { color: #880000; } /* Constant */
code > span.sc { color: #4070a0; } /* SpecialChar */
code > span.vs { color: #4070a0; } /* VerbatimString */
code > span.ss { color: #bb6688; } /* SpecialString */
code > span.im { } /* Import */
code > span.va { color: #19177c; } /* Variable */
code > span.cf { color: #007020; font-weight: bold; } /* ControlFlow */
code > span.op { color: #666666; } /* Operator */
code > span.bu { } /* BuiltIn */
code > span.ex { } /* Extension */
code > span.pp { color: #bc7a00; } /* Preprocessor */
code > span.at { color: #7d9029; } /* Attribute */
code > span.do { color: #ba2121; font-style: italic; } /* Documentation */
code > span.an { color: #60a0b0; font-weight: bold; font-style: italic; } /* Annotation */
code > span.cv { color: #60a0b0; font-weight: bold; font-style: italic; } /* CommentVar */
code > span.in { color: #60a0b0; font-weight: bold; font-style: italic; } /* Information */
</style>
<link href="data:text/css;charset=utf-8,body%20%7B%0Abackground%2Dcolor%3A%20%23fff%3B%0Amargin%3A%201em%20auto%3B%0Amax%2Dwidth%3A%20700px%3B%0Aoverflow%3A%20visible%3B%0Apadding%2Dleft%3A%202em%3B%0Apadding%2Dright%3A%202em%3B%0Afont%2Dfamily%3A%20%22Open%20Sans%22%2C%20%22Helvetica%20Neue%22%2C%20Helvetica%2C%20Arial%2C%20sans%2Dserif%3B%0Afont%2Dsize%3A%2014px%3B%0Aline%2Dheight%3A%201%2E35%3B%0A%7D%0A%23header%20%7B%0Atext%2Dalign%3A%20center%3B%0A%7D%0A%23TOC%20%7B%0Aclear%3A%20both%3B%0Amargin%3A%200%200%2010px%2010px%3B%0Apadding%3A%204px%3B%0Awidth%3A%20400px%3B%0Aborder%3A%201px%20solid%20%23CCCCCC%3B%0Aborder%2Dradius%3A%205px%3B%0Abackground%2Dcolor%3A%20%23f6f6f6%3B%0Afont%2Dsize%3A%2013px%3B%0Aline%2Dheight%3A%201%2E3%3B%0A%7D%0A%23TOC%20%2Etoctitle%20%7B%0Afont%2Dweight%3A%20bold%3B%0Afont%2Dsize%3A%2015px%3B%0Amargin%2Dleft%3A%205px%3B%0A%7D%0A%23TOC%20ul%20%7B%0Apadding%2Dleft%3A%2040px%3B%0Amargin%2Dleft%3A%20%2D1%2E5em%3B%0Amargin%2Dtop%3A%205px%3B%0Amargin%2Dbottom%3A%205px%3B%0A%7D%0A%23TOC%20ul%20ul%20%7B%0Amargin%2Dleft%3A%20%2D2em%3B%0A%7D%0A%23TOC%20li%20%7B%0Aline%2Dheight%3A%2016px%3B%0A%7D%0Atable%20%7B%0Amargin%3A%201em%20auto%3B%0Aborder%2Dwidth%3A%201px%3B%0Aborder%2Dcolor%3A%20%23DDDDDD%3B%0Aborder%2Dstyle%3A%20outset%3B%0Aborder%2Dcollapse%3A%20collapse%3B%0A%7D%0Atable%20th%20%7B%0Aborder%2Dwidth%3A%202px%3B%0Apadding%3A%205px%3B%0Aborder%2Dstyle%3A%20inset%3B%0A%7D%0Atable%20td%20%7B%0Aborder%2Dwidth%3A%201px%3B%0Aborder%2Dstyle%3A%20inset%3B%0Aline%2Dheight%3A%2018px%3B%0Apadding%3A%205px%205px%3B%0A%7D%0Atable%2C%20table%20th%2C%20table%20td%20%7B%0Aborder%2Dleft%2Dstyle%3A%20none%3B%0Aborder%2Dright%2Dstyle%3A%20none%3B%0A%7D%0Atable%20thead%2C%20table%20tr%2Eeven%20%7B%0Abackground%2Dcolor%3A%20%23f7f7f7%3B%0A%7D%0Ap%20%7B%0Amargin%3A%200%2E5em%200%3B%0A%7D%0Ablockquote%20%7B%0Abackground%2Dcolor%3A%20%23f6f6f6%3B%0Apadding%3A%200%2E25em%200%2E75em%3B%0A%7D%0Ahr%20%7B%0Aborder%2Dstyle%3A%20solid%3B%0Aborder%3A%20none%3B%0Aborder%2Dtop%3A%201px%20solid%20%23777%3B%0Amargin%3A%2028px%200%3B%0A%7D%0Adl%20%7B%0Amargin%2Dleft%3A%200%3B%0A%7D%0Adl%20dd%20%7B%0Amargin%2Dbottom%3A%2013px%3B%0Amargin%2Dleft%3A%2013px%3B%0A%7D%0Adl%20dt%20%7B%0Afont%2Dweight%3A%20bold%3B%0A%7D%0Aul%20%7B%0Amargin%2Dtop%3A%200%3B%0A%7D%0Aul%20li%20%7B%0Alist%2Dstyle%3A%20circle%20outside%3B%0A%7D%0Aul%20ul%20%7B%0Amargin%2Dbottom%3A%200%3B%0A%7D%0Apre%2C%20code%20%7B%0Abackground%2Dcolor%3A%20%23f7f7f7%3B%0Aborder%2Dradius%3A%203px%3B%0Acolor%3A%20%23333%3B%0Awhite%2Dspace%3A%20pre%2Dwrap%3B%20%0A%7D%0Apre%20%7B%0Aborder%2Dradius%3A%203px%3B%0Amargin%3A%205px%200px%2010px%200px%3B%0Apadding%3A%2010px%3B%0A%7D%0Apre%3Anot%28%5Bclass%5D%29%20%7B%0Abackground%2Dcolor%3A%20%23f7f7f7%3B%0A%7D%0Acode%20%7B%0Afont%2Dfamily%3A%20Consolas%2C%20Monaco%2C%20%27Courier%20New%27%2C%20monospace%3B%0Afont%2Dsize%3A%2085%25%3B%0A%7D%0Ap%20%3E%20code%2C%20li%20%3E%20code%20%7B%0Apadding%3A%202px%200px%3B%0A%7D%0Adiv%2Efigure%20%7B%0Atext%2Dalign%3A%20center%3B%0A%7D%0Aimg%20%7B%0Abackground%2Dcolor%3A%20%23FFFFFF%3B%0Apadding%3A%202px%3B%0Aborder%3A%201px%20solid%20%23DDDDDD%3B%0Aborder%2Dradius%3A%203px%3B%0Aborder%3A%201px%20solid%20%23CCCCCC%3B%0Amargin%3A%200%205px%3B%0A%7D%0Ah1%20%7B%0Amargin%2Dtop%3A%200%3B%0Afont%2Dsize%3A%2035px%3B%0Aline%2Dheight%3A%2040px%3B%0A%7D%0Ah2%20%7B%0Aborder%2Dbottom%3A%204px%20solid%20%23f7f7f7%3B%0Apadding%2Dtop%3A%2010px%3B%0Apadding%2Dbottom%3A%202px%3B%0Afont%2Dsize%3A%20145%25%3B%0A%7D%0Ah3%20%7B%0Aborder%2Dbottom%3A%202px%20solid%20%23f7f7f7%3B%0Apadding%2Dtop%3A%2010px%3B%0Afont%2Dsize%3A%20120%25%3B%0A%7D%0Ah4%20%7B%0Aborder%2Dbottom%3A%201px%20solid%20%23f7f7f7%3B%0Amargin%2Dleft%3A%208px%3B%0Afont%2Dsize%3A%20105%25%3B%0A%7D%0Ah5%2C%20h6%20%7B%0Aborder%2Dbottom%3A%201px%20solid%20%23ccc%3B%0Afont%2Dsize%3A%20105%25%3B%0A%7D%0Aa%20%7B%0Acolor%3A%20%230033dd%3B%0Atext%2Ddecoration%3A%20none%3B%0A%7D%0Aa%3Ahover%20%7B%0Acolor%3A%20%236666ff%3B%20%7D%0Aa%3Avisited%20%7B%0Acolor%3A%20%23800080%3B%20%7D%0Aa%3Avisited%3Ahover%20%7B%0Acolor%3A%20%23BB00BB%3B%20%7D%0Aa%5Bhref%5E%3D%22http%3A%22%5D%20%7B%0Atext%2Ddecoration%3A%20underline%3B%20%7D%0Aa%5Bhref%5E%3D%22https%3A%22%5D%20%7B%0Atext%2Ddecoration%3A%20underline%3B%20%7D%0A%0Acode%20%3E%20span%2Ekw%20%7B%20color%3A%20%23555%3B%20font%2Dweight%3A%20bold%3B%20%7D%20%0Acode%20%3E%20span%2Edt%20%7B%20color%3A%20%23902000%3B%20%7D%20%0Acode%20%3E%20span%2Edv%20%7B%20color%3A%20%2340a070%3B%20%7D%20%0Acode%20%3E%20span%2Ebn%20%7B%20color%3A%20%23d14%3B%20%7D%20%0Acode%20%3E%20span%2Efl%20%7B%20color%3A%20%23d14%3B%20%7D%20%0Acode%20%3E%20span%2Ech%20%7B%20color%3A%20%23d14%3B%20%7D%20%0Acode%20%3E%20span%2Est%20%7B%20color%3A%20%23d14%3B%20%7D%20%0Acode%20%3E%20span%2Eco%20%7B%20color%3A%20%23888888%3B%20font%2Dstyle%3A%20italic%3B%20%7D%20%0Acode%20%3E%20span%2Eot%20%7B%20color%3A%20%23007020%3B%20%7D%20%0Acode%20%3E%20span%2Eal%20%7B%20color%3A%20%23ff0000%3B%20font%2Dweight%3A%20bold%3B%20%7D%20%0Acode%20%3E%20span%2Efu%20%7B%20color%3A%20%23900%3B%20font%2Dweight%3A%20bold%3B%20%7D%20%20code%20%3E%20span%2Eer%20%7B%20color%3A%20%23a61717%3B%20background%2Dcolor%3A%20%23e3d2d2%3B%20%7D%20%0A" rel="stylesheet" type="text/css" />
</head>
<body>
<h1 class="title toc-ignore">TractoR: Magnetic Resonance Imaging and Tractography with R</h1>
<h4 class="author"><em>Jonathan D. Clayden, Susana Muñoz Maniega, Amos J. Storkey, Martin D. King, Mark E. Bastin & Chris A. Clark</em></h4>
<h4 class="date"><em>2016-05-18</em></h4>
<p><em>Please note that this is an updated version of the <a href="http://www.jstatsoft.org/v44/i08/">original TractoR paper</a>, which was published in the</em> Journal of Statistical Software <em>in 2011. Please cite the reference below if you use TractoR in your work.</em></p>
<p><em>J.D. Clayden, S. Muñoz Maniega, A.J. Storkey, M.D. King, M.E. Bastin & C.A. Clark (2011). TractoR: Magnetic resonance imaging and tractography with R.</em> Journal of Statistical Software <strong>44</strong><em>(8):1-18.</em></p>
<p><em>This version of the paper is based on v3.0.1 of TractoR, but does not cover the full scope of this more recent release. (The current version at the time of original publication was v1.8.2.) Please see <a href="http://www.tractor-mri.org.uk" class="uri">http://www.tractor-mri.org.uk</a> for more information about the package and its authors.</em></p>
<div id="abstract" class="section level2">
<h2>Abstract</h2>
<p>Statistical techniques play a major role in contemporary methods for analysing magnetic resonance imaging (MRI) data. In addition to the central role that classical statistical methods play in research using MRI, statistical modelling and machine learning techniques are key to many modern data analysis pipelines. Applications for these techniques cover a broad spectrum of research, including many preclinical and clinical studies, and in some cases these methods are working their way into widespread routine use.</p>
<p>In this manuscript we describe a software tool called TractoR (for “Tractography with R”), a collection of packages for the R language and environment, along with additional infrastructure for straightforwardly performing common image processing tasks. TractoR provides general purpose functions for reading, writing and manipulating MR images, as well as more specific code for fitting signal models to diffusion MRI data and performing tractography, a technique for visualising neural connectivity.</p>
</div>
<div id="introduction" class="section level2">
<h2>Introduction</h2>
<p>Magnetic resonance imaging (MRI) is a noninvasive medical imaging technique which is used routinely in hospitals worldwide. By exploiting fundamentally quantum-mechanical characteristics of water molecules in the presence of a strong magnetic field, MRI can recover detailed images of body tissues at a resolution of around 1 mm. Unlike many other medical imaging methods, MRI uses no ionising radiation, and therefore permits repeated scanning.</p>
<p>MRI is also a very flexible technique. By manipulating the nuclear magnetic resonance signal from water molecules, a broad variety of tissue contrasts can be obtained. Of particular interest in this paper is diffusion MRI (dMRI), wherein image intensity at each pixel (or voxel for 3D images) depends on the local pattern of self-diffusion of water (<a href="#bibliography">Le Bihan, 2003</a>). Since elements of body tissue such as cell membranes present obstacles to diffusion, these images can provide information about microscopic tissue structure; and the orientation of highly linear structures such as the brain’s white matter can also be inferred.</p>
<p>The development of new MRI analysis techniques is a major area of research, and some of the ideas generated by this research are filtering through to clinical applications. Statistical techniques play a very important part in many of these new developments. Currently, MATLAB is probably the most widely-used programming language for the development of new MRI analysis tools, with the statistical parametric mapping (SPM) package being a notable example (<a href="#bibliography">Friston et al., 2007</a>); but C++, Java and Python are also common choices. Due to its statistical pedigree and vectorised programming model, R (<a href="#bibliography">R Core Team, 2016</a>) is a strong candidate for software development in this field.</p>
<p>In this paper we introduce a software package called <strong>TractoR</strong> (for “Tractography with R”), which consists of several R packages, along with a simple command line based front-end and some associated infrastructure for performing common MRI analysis tasks. TractoR is free software, available from <a href="http://www.tractor-mri.org.uk" class="uri">http://www.tractor-mri.org.uk</a> under the terms of the GNU Public Licence, version 2.</p>
</div>
<div id="package-overview-and-conventions" class="section level2">
<h2>Package overview and conventions</h2>
<p>The core functionality of TractoR is provided in seven R packages. The <strong>tractor.base</strong> package provides general functions for reading, writing and manipulating magnetic resonance images; <strong>tractor.reg</strong> handles image registration or co-alignment; <strong>tractor.session</strong> maintains the various image files associated with a particular scan session or subject, and provides interfaces to third-party software; <strong>tractor.track</strong> provides core functions for performing diffusion <a href="#fibre-tracking">fibre tracking</a>; <strong>tractor.nt</strong> implements <a href="#neighbourhood-tractography">“neighbourhood tractography”</a>; <strong>tractor.graph</strong> provides data structures and algorithms to support graph-based “connectome” analyses; and <strong>tractor.utils</strong> provides various utility functions, primarily used by the TractoR <a href="#the-tractor-shell-interface">shell interface</a>.</p>
<p>The session abstraction obviates the need for the user to keep track of the locations of large numbers of files, instead following a convention for simplicity. The general layout in the current version of TractoR is shown in the table below, and the <strong>tractor.session</strong> package provides accessor functions for obtaining the true path to a particular image, such as the fractional anisotropy map (located at <code>tractor/diffusion/dti_FA</code> by default). The user may specify alternative paths for particular files if necessary, through the use of so-called “session maps”.</p>
<table>
<colgroup>
<col width="33%"></col>
<col width="66%"></col>
</colgroup>
<thead>
<tr class="header">
<th>Directory</th>
<th>Purpose</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td><code>tractor</code></td>
<td>Top-level managed directory</td>
</tr>
<tr class="even">
<td><code>tractor/transforms</code></td>
<td>Stored transformations between different spaces</td>
</tr>
<tr class="odd">
<td><code>tractor/diffusion</code></td>
<td>Diffusion-weighted images and their derivatives (e.g. diffusion tensor components)</td>
</tr>
<tr class="even">
<td><code>tractor/fdt</code></td>
<td>Images and other files used by FSL’s diffusion toolbox</td>
</tr>
<tr class="odd">
<td><code>tractor/fdt.bedpostX</code></td>
<td>Images and other files produced by FSL BEDPOSTX</td>
</tr>
<tr class="even">
<td><code>tractor/structural</code></td>
<td>Structural (e.g. <span class="math inline">\(T_1\)</span>-weighted) images</td>
</tr>
<tr class="odd">
<td><code>tractor/freesurfer</code></td>
<td>Output from the Freesurfer pipeline</td>
</tr>
<tr class="even">
<td><code>tractor/functional</code></td>
<td>Functional (generally <span class="math inline">\(T_2^*\)</span>-weighted BOLD) images</td>
</tr>
</tbody>
</table>
<p>Classes in TractoR are implemented primarily as R reference classes, with a number of methods for accessing and modifying encapsulated data, which are called directly on the object. This will be demonstrated explicitly in the next section.</p>
</div>
<div id="the-mriimage-class" class="section level2">
<h2>The MriImage class</h2>
<p>The core data type used in TractoR is the <code>MriImage</code>. This class is defined in the <strong>tractor.base</strong> R package, along with methods for reading and writing objects from and to standard medical image file types, visualisation and flexible image manipulation. This data type consists of a dense or sparse array of voxel intensity values, along with a set of metadata describing the voxel dimensions, coordinate origin and storage format of the image.</p>
<p>The standard file format used by TractoR to store <code>MriImage</code> objects on disk is the <a href="http://nifti.nimh.nih.gov/nifti-1">NIfTI-1 format</a>, a widely-supported standard in medical imaging. Reading an image from such a file is simple.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(<span class="st">"tractor.base"</span>)
i <-<span class="st"> </span><span class="kw">readImageFile</span>(<span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>), <span class="st">"share"</span>, <span class="st">"mni"</span>, <span class="st">"brain.nii.gz"</span>))</code></pre></div>
<p>(Note that this example requires that the full TractoR distribution has been installed, and that the <code>TRACTOR_HOME</code> environment variable has been correctly set to point to its location on disk.) This particular image is a standard representation of the brain in Montréal Neurological Institute space (MNI space; see <a href="#bibliography">Evans et al., 1994</a>), provided by McGill University. Information about the image can be obtained through its <code>print()</code> method.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">print</span>(i)
<span class="co">#> Image source : /usr/local/tractor/share/mni/brain</span>
<span class="co">#> Image dimensions : 197 x 233 x 189 voxels</span>
<span class="co">#> Voxel dimensions : 1 x 1 x 1 mm</span>
<span class="co">#> Coordinate origin : (99,135,73)</span>
<span class="co">#> Additional tags : (none)</span>
<span class="co">#> Sparseness : 78.25% (dense storage)</span></code></pre></div>
<p>Access to the array of voxel values stored with the image, or specific elements of metadata, is through a series of accessor functions.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">d <-<span class="st"> </span>i$<span class="kw">getData</span>()
<span class="kw">class</span>(d)
<span class="co">#> [1] "array"</span>
<span class="kw">dim</span>(d)
<span class="co">#> [1] 197 233 189</span>
i$<span class="kw">getOrigin</span>()
<span class="co">#> [1] 99 135 73</span></code></pre></div>
<p>A full list of methods available for the <code>MriImage</code> class—or, analogously, any other reference class defined by TractoR—may be obtained by calling the <code>methods()</code> method on an object of the relevant class.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">i$<span class="kw">methods</span>()
<span class="co">#> [1] ".objectPackage" ".objectParent" "apply" </span>
<span class="co">#> [4] "binarise" "callSuper" "copy" </span>
<span class="co">#> [7] "export" "field" "fields" </span>
<span class="co">#> [10] "fill" "getClass" "getData" </span>
<span class="co">#> [13] "getDataAtPoint" "getDimensionality" "getDimensions" </span>
<span class="co">#> [16] "getFieldOfView" "getMetadata" "getNonzeroIndices" </span>
<span class="co">#> [19] "getOrigin" "getRefClass" "getSlice" </span>
<span class="co">#> [22] "getSource" "getSparseness" "getTags" </span>
<span class="co">#> [25] "getVoxelDimensions" "getVoxelUnits" "getXform" </span>
<span class="co">#> [28] "import" "initFields" "initialize" </span>
<span class="co">#> [31] "isEmpty" "isInternal" "isReordered" </span>
<span class="co">#> [34] "isSparse" "map" "mask" </span>
<span class="co">#> [37] "methods" "nTags" "serialise" </span>
<span class="co">#> [40] "setOrigin" "setSource" "setXform" </span>
<span class="co">#> [43] "show" "summarise" "threshold" </span>
<span class="co">#> [46] "trace" "untrace" "usingMethods" </span>
<span class="co">#> [49] "writeToFile"</span></code></pre></div>
<p>Slices of an image, maximum intensity projections and “contact sheet” style visualisations of all image slices can be easily created, with the aspect ratio of the image set according to the voxel dimensions. Simple image processing operations such as applying a lower intensity threshold can also be applied, and more sophisticated image processing is available through the <strong>mmand</strong> package (<a href="#bibliography">Clayden, 2016a</a>), which is provided as part of the full TractoR distribution, or available separately from the Comprehensive R Archive Network.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">createSliceGraphic</span>(i, <span class="dt">z=</span><span class="dv">80</span>)</code></pre></div>
<p><img src="" /><!-- --></p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">j <-<span class="st"> </span>i$<span class="kw">copy</span>()$<span class="kw">threshold</span>(<span class="dv">50</span>)
<span class="kw">createSliceGraphic</span>(j, <span class="dt">z=</span><span class="dv">80</span>)</code></pre></div>
<p><img src="" /><!-- --></p>
<p>The plane of the graphic is set by the option <code>z=80</code>, indicating the slice perpendicular to the <em>z</em>-axis (bottom-to-top), 80 voxels from the bottom of the brain volume. Notice that the image is first copied before thresholding it; otherwise, the threshold would be applied to the original.</p>
<p>Arbitrary functions of one or more images may also be applied easily, using the <code>map()</code> method, as in the examples below.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">k <-<span class="st"> </span>i$<span class="kw">copy</span>()$<span class="kw">map</span>(function(x) x^<span class="dv">2</span>)
l <-<span class="st"> </span>i$<span class="kw">copy</span>()$<span class="kw">map</span>(<span class="st">"*"</span>, j)</code></pre></div>
<p>The first of these produces a new image whose voxel values are the squares of the original, while the second multiplies two images together. The latter may be achieved more succinctly using the standard multiplication operator, as in <code>i*j</code>.</p>
<p>Finally, an <code>MriImage</code> may be created from a standard R array object, by using another <code>MriImage</code> as a template, or by specifying the metadata explicitly. In the following example we create a mask image whose value is 1 wherever the original image is positive, and 0 everywhere else. This could be more simply achieved using the <code>binarise()</code> method, but the longer version is instructive.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">d <-<span class="st"> </span><span class="kw">array</span>(<span class="kw">as.integer</span>(i$<span class="kw">getData</span>() ><span class="st"> </span><span class="dv">0</span>), <span class="dt">dim=</span>i$<span class="kw">getDimensions</span>())
j <-<span class="st"> </span><span class="kw">asMriImage</span>(d, i)
<span class="kw">print</span>(j)
<span class="co">#> Image source : internal</span>
<span class="co">#> Image dimensions : 197 x 233 x 189 voxels</span>
<span class="co">#> Voxel dimensions : 1 x 1 x 1 mm</span>
<span class="co">#> Coordinate origin : (99,135,73)</span>
<span class="co">#> Additional tags : (none)</span>
<span class="co">#> Sparseness : 78.25% (dense storage)</span></code></pre></div>
<p>The first line here binarises the original image, and the second uses the original image as a template to create a new <code>MriImage</code>.</p>
<div id="handling-dicom-files" class="section level3">
<h3>Handling DICOM files</h3>
<p>DICOM (for Digital Imaging and Communications in Medicine; see <a href="http://dicom.nema.org" class="uri">http://dicom.nema.org</a>) is an extremely complex standard for storing and transferring medical imaging information, and is the format in which image data is usually obtained from an MRI scanner. An <code>MriImage</code> object may be created from a directory of related DICOM files, where each file represents a slice of a larger image, and subsequently converted to NIfTI-1 format.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="co"># First copy DICOM files into a temporary directory</span>
<span class="kw">dir.create</span>(path <-<span class="st"> </span><span class="kw">tempfile</span>())
<span class="kw">file.copy</span>(<span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>), <span class="st">"tests"</span>, <span class="st">"data"</span>, <span class="st">"dicom"</span>, <span class="kw">c</span>(<span class="st">"01.dcm"</span>,<span class="st">"02.dcm"</span>)), path)
<span class="co">#> [1] TRUE TRUE</span>
<span class="co"># Now read and convert the files</span>
info <-<span class="st"> </span><span class="kw">readDicomDirectory</span>(path)
<span class="co">#> Looking for DICOM files in directory /var/folders/k0/s94b87h541b00dbrlpt29_7h0000gn/T//RtmpNMAc22/file181958c78b0a</span>
<span class="co">#> Reading image information from 2 files</span>
<span class="co">#> INFO: [x2] Data matrix is transposed relative to acquisition matrix</span>
<span class="co">#> Image orientation is PIR</span>
<span class="co">#> Data set contains 1 volume(s); 2 slice(s) per volume</span>
<span class="kw">print</span>(info$image)
<span class="co">#> Image source : internal</span>
<span class="co">#> Image dimensions : 2 x 224 x 256 voxels</span>
<span class="co">#> Voxel dimensions : 1 x 1 x 1 mm</span>
<span class="co">#> Coordinate origin : (19.25,95.05,134.78)</span>
<span class="co">#> Additional tags : (none)</span>
<span class="co">#> Sparseness : 0.84% (dense storage)</span>
<span class="kw">writeImageFile</span>(info$image, <span class="st">"image"</span>, <span class="st">"NIFTI"</span>)</code></pre></div>
<p>The output file will be called “image.nii”. (A gzipped NIfTI file, or image/header pair, may be obtained by substituting <code>"NIFTI_GZ"</code> or <code>"NIFTI_PAIR"</code> as the last argument to <code>writeImageFile</code>.)</p>
<p>Alternatively, a DICOM file may be read into a <code>DicomMetadata</code> object, which retains all of the information stored in the file. Individual DICOM “tags”, containing information about the scan acquisition, may then be extracted.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">m <-<span class="st"> </span><span class="kw">readDicomFile</span>(<span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>), <span class="st">"tests"</span>, <span class="st">"data"</span>, <span class="st">"dicom"</span>, <span class="st">"01.dcm"</span>))
m$<span class="kw">getTagValue</span>(<span class="dv">0x0018</span>, <span class="dv">0x0087</span>)
<span class="co">#> [1] 1.494</span>
tractor.base:::<span class="kw">getDescriptionForDicomTag</span>(<span class="dv">0x0018</span>, <span class="dv">0x0087</span>)
<span class="co">#> [1] "Magnetic Field Strength"</span></code></pre></div>
</div>
</div>
<div id="modelling-the-diffusion-weighted-signal" class="section level2">
<h2>Modelling the diffusion-weighted signal</h2>
<p>The <strong>tractor.session</strong> package for R defines the <code>MriSession</code> class, which encapsulates a single scanning session with a single subject, and manages a hierarchy of image files and other information which relate to that scan. Since several of these files are involved in performing most data processing tasks, the abstraction obviates the necessity to specify each of these files individually—rather, only the top-level directory containing the session data need be given explicitly.</p>
<p>Some initial preprocessing is required to move from a set of raw data files acquired from an MRI scanner to a data set ready for fibre tracking as laid out below, and the <strong>tractor.session</strong> package provides tools to perform that preprocessing, but those steps are omitted here for brevity. The <code>dpreproc</code> script, inside the full TractoR distribution’s <code>share/experiments</code> subdirectory, demonstrates how each of the standard preprocessing steps can be achieved. They are conversion of DICOM files to NIfTI-1 format if required (as described <a href="#handling-dicom-files">above</a>), brain extraction and coregistration of diffusion-weighted volumes.</p>
<div id="the-diffusion-tensor" class="section level3">
<h3>The diffusion tensor</h3>
<p>Diffusion MRI data are usually acquired as a series of 3D volumes, each of which has an associated diffusion sensitising magnetic gradient applied along a particular direction relative to the scanner’s native coordinate system, represented as a normalised column vector, <span class="math inline">\(\mathsf{G}\)</span>. Under the assumption that the spatial distribution of diffusing water molecules after a particular time, <span class="math inline">\(t\)</span>, is 3D Gaussian, the relationship between the signal amplitude in the presence of diffusion sensitisation, <span class="math inline">\(S\)</span>, and the signal without it, <span class="math inline">\(S_0\)</span>, is</p>
<p><span class="math display">\[\frac{S(b,\mathsf{G})}{S_0} = \exp \left(-b \mathsf{G}^{\mathsf{T}} \mathsf{D} \mathsf{G} \right) \; .\]</span></p>
<p>Here, <span class="math inline">\(b\)</span> is the diffusion “weighting factor”, which depends on the diffusion time and the strength of the magnetic gradient applied. <span class="math inline">\(\mathsf{D}\)</span> is known as the “effective diffusion tensor”, represented relative to the scanner’s coordinate system, and is related to the covariance matrix of the 3D Gaussian molecular displacement distribution by <span class="math inline">\(\Sigma=2\mathsf{D}t\)</span>. Using the equation above, the elements of the diffusion tensor matrix may be estimated in each voxel of the brain from the log-transformed signal intensities with and without diffusion weighting, using ordinary or weighted least-squares estimation, or more sophisticated methods where required. The combination of dMRI acquisition with diffusion tensor estimation is referred to as diffusion tensor imaging (<a href="#bibliography">Basser et al., 1994</a>).</p>
<p>With the diffusion tensor estimated at each voxel in the brain, it is common for many applications to calculate the eigenvalues, <span class="math inline">\(\lambda_1\)</span>, <span class="math inline">\(\lambda_2\)</span> and <span class="math inline">\(\lambda_3\)</span>, of each tensor, along with various derived quantities. The eigenvalues represent effective diffusivities, generally specified in mm<sup>2</sup> s<sup>-1</sup>, along the principal axes of the displacement distribution. From these are typically calculated measures such as mean diffusivity (MD), the mean of the eigenvalues, <span class="math inline">\(\bar{\lambda}\)</span>, and fractional anisotropy (FA), given by</p>
<p><span class="math display">\[\textrm{FA} = \sqrt{\frac{3}{2}} \sqrt{\frac{(\lambda_1-\bar{\lambda})^2 + (\lambda_2-\bar{\lambda})^2 + (\lambda_3-\bar{\lambda})^2}{\lambda_1^{\,2} + \lambda_2^{\,2} + \lambda_3^{\,2}}} \; .\]</span></p>
<p>Considering the isosurface of probability density after a given diffusion time as an ellipsoid, MD describes the volume of the ellipsoid while FA describes its shape. FA is zero for a spherical ellipsoid, representing isotropic diffusion, while it is close to unity when one eigenvalue is substantially larger than the others, corresponding to a prolate ellipsoid (subfigures a–c, below). The white matter of the brain is highly linearised, and FA is consequently higher in these regions (subfigure d).</p>
<div class="figure">
<img src="" alt="Ellipsoids representing isotropic (a), oblate (b) and prolate (c) diffusion profiles, along with a map of fractional anisotropy in a slice of the human brain (d)." />
<p class="caption"><em>Ellipsoids representing isotropic (a), oblate (b) and prolate (c) diffusion profiles, along with a map of fractional anisotropy in a slice of the human brain (d).</em></p>
</div>
<p>Diffusion tensor fitting may be performed with TractoR using either ordinary least-squares or iterative weighted least-squares approaches. The latter is recommended due to heteroskedasticity in the log-transformed signal intensities (<a href="#bibliography">Salvador et al., 2005</a>). It may be performed as follows.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(<span class="st">"tractor.session"</span>)
s <-<span class="st"> </span><span class="kw">attachMriSession</span>(<span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>), <span class="st">"tests"</span>, <span class="st">"data"</span>, <span class="st">"session"</span>))
## createDiffusionTensorImagesForSession(s, method="iwls")</code></pre></div>
<p>This command will use preprocessed data files already stored in the specified session directory to estimate diffusion tensors at each image voxel, and write out a series of images representing various quantities derived from it or its diagonalisation, including MD and FA. (Be aware that running this command on the test data supplied with TractoR exactly as given will overwrite some standard test files, and may lead to some of TractoR’s self-tests failing afterwards. It is therefore preferable to use a copy of the test data, or a different data set, when experimenting.) Ordinary least-squares tensor fitting may be performed by substituting <code>method="ls"</code> into the last command. The full path to any particular image created within the session directory in this way may be obtained as follows.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">s$<span class="kw">getImageFileNameByType</span>(<span class="st">"FA"</span>)
<span class="co">#> [1] "/usr/local/tractor/tests/data/session/tractor/diffusion/dti_FA"</span></code></pre></div>
<p>An interface to the tensor estimation tool in the FMRIB Software Library (FSL; see <a href="#bibliography">Smith et al., 2004</a>; <a href="http://fsl.fmrib.ox.ac.uk" class="uri">http://fsl.fmrib.ox.ac.uk</a>) may be used as an alternative, for its somewhat faster speed, as follows.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">runDtifitWithSession</span>(s)</code></pre></div>
<p>In this case only the ordinary least-squares method is used, and FSL must be installed on the user’s system as well as TractoR.</p>
<p>We note that other diffusion signal models, such as a Gaussian mixture model or the so-called “q-ball” model, can be fitted to dMRI data using the <strong>dti</strong> R package (<a href="#bibliography">Polzehl & Tabelow, 2009</a>).</p>
</div>
<div id="a-sampling-based-approach" class="section level3">
<h3>A sampling-based approach</h3>
<p>The assumption of a 3D Gaussian molecular displacement distribution for self-diffusion of water in living tissue is oversimplistic. Even in highly linear white matter, more complex patterns of diffusion occur regularly at the crossings of multiple pathways (<a href="#bibliography">Jones, 2008</a>). For the purpose of fibre tracking, discussed in the next section, it is therefore usually desirable to allow for contributions from multiple fibre populations with different orientations. One such generalisation, described by <a href="#bibliography">Behrens et al. (2007)</a> and often referred to as the “ball and sticks” model, treats the displacement distribution as a mixture of pure isotropic and anisotropic components. Assuming that the orientation of the <span class="math inline">\(i\)</span>th fibre population is given by the column vector <span class="math inline">\(\mathsf{N}_i\)</span>, the signal model then becomes</p>
<p><span class="math display">\[\frac{S(b,\mathsf{G})}{S_0} = \left(1-\sum_i f_i \right) \exp(-bD) + \sum_i f_i \exp \left(-bD \left( \mathsf{G}^{\mathsf{T}} \mathsf{N}_i \right)^2 \right) \; ,\]</span></p>
<p>where <span class="math inline">\(f_i \in [0,1]\)</span> is the volume fraction of the <span class="math inline">\(i\)</span>th anisotropic component, and <span class="math inline">\(D\)</span> is the effective diffusivity.</p>
<p>In a standard dMRI acquisition, the known values in the equation above are <span class="math inline">\(b\)</span> and <span class="math inline">\(\mathsf{G}\)</span>, while <span class="math inline">\(S\)</span> and <span class="math inline">\(S_0\)</span> are observed, and <span class="math inline">\(D\)</span>, <span class="math inline">\((f_i)\)</span> and <span class="math inline">\((\mathsf{N}_i)\)</span> are to be estimated. Rather than calculate point estimates of these parameters, (<a href="#bibliography">Behrens et al., 2007</a>) put forward a Markov chain Monte Carlo (MCMC) approach to estimating their posterior distributions. (The priors used by the algorithm as published are uninformative. Noise in each voxel is modelled to be independent and identically distributed Gaussian, with a Gamma distribution prior on the precision parameter.) They refer to their algorithm as BEDPOST (Bayesian Estimation of Diffusion Parameters Obtained using Sampling Techniques). The algorithm is provided as part of FSL, and TractoR provides a simple interface to it for R, viz.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">runBedpostWithSession</span>(s, <span class="dt">nFibres=</span><span class="dv">3</span>)</code></pre></div>
<p>Here, the <code>nFibres</code> argument determines the maximum number of anisotropic components allowed per voxel, i.e., the upper limit on <span class="math inline">\(i\)</span> in the model in the equation above. BEDPOST uses the automatic relevance determination framework on the volume fraction parameters, <span class="math inline">\((f_i)\)</span>, to set priors which allow the weights of components to be forced to zero where they are irrelevant for predicting the signal (see <a href="#bibliography">MacKay, 1995</a>). In this way, only as many components are maintained in each voxel as are supported by the data. BEDPOST typically takes several hours to run, at the end of which a number of new files are created within the session directory, representing the estimated distributions for each parameter of interest—notably the orientation vectors, <span class="math inline">\((\mathsf{N}_i)\)</span>.</p>
</div>
</div>
<div id="fibre-tracking" class="section level2">
<h2>Fibre tracking</h2>
<p>Diffusion fibre tracking, or “tractography”, is the process of reconstructing white matter tract trajectories by following the local orientation information estimated as <a href="#modelling-the-diffusion-weighted-signal">described above</a>. It has a wide spectrum of applications in clinical imaging and neuroscience.</p>
<div id="tracking-from-single-seed-points" class="section level3">
<h3>Tracking from single seed points</h3>
<p>The standard algorithm for performing streamline tractography from a single seed point may be described as follows.</p>
<ol style="list-style-type: decimal">
<li>Start with the current “front” of the streamline set to the seed point.</li>
<li>Sample a local fibre orientation at the streamline front.</li>
<li>Move the front some small distance in the direction of the sampled direction.</li>
<li>Return to step 2, and repeat until a stopping criterion is met.</li>
<li>Return to step 1 and repeat once, travelling in the opposite direction away from the seed point.</li>
</ol>
<p>Step 2 in the process described above involves some subtlety. Firstly, if a point estimate of the local fibre orientation is used—such as the principal eigenvector of a single diffusion tensor—then the sampling is deterministic. If MCMC is used to estimate a distribution over orientations, on the other hand, then the sampling may be repeated multiple times with different results in general. Thus, multiple streamlines may be generated from a single seed point. Local uncertainty will tend to accumulate in the streamlines’ trajectories as one moves away from the seed point, and a set of streamlines generated in this way give an indication of the precision available for tracking pathways from the seed. Secondly, in models of diffusion allowing for multiple anisotropic components, multiple fibre directions may be present within each voxel, and one must therefore decide which component to sample from. The convention is usually to sample from all components, and then choose the sample which is most similar to the orientation of the previous step; but alternative strategies are possible, and may be more robust (e.g., <a href="#bibliography">Clayden & Clark, 2010</a>).</p>
<p>White matter pathways terminate in grey matter, which does not have the orientational coherence of white matter, and orientation uncertainty is therefore very high in these areas. Stopping criteria usually ensure that the streamline does not leave the brain or turn back on itself, but entering grey matter may also be a reason to stop tracking.</p>
<div class="figure">
<img src="" alt="Example of fibre tracking in the brain. A set of 1000 sampled streamlines from a single seed point (the red dot) are shown individually (a), and summarised in a visitation map (b)." />
<p class="caption"><em>Example of fibre tracking in the brain. A set of 1000 sampled streamlines from a single seed point (the red dot) are shown individually (a), and summarised in a visitation map (b).</em></p>
</div>
<p>Assuming BEDPOST has already been run on the session directory, single seed tractography can be run as follows.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(<span class="st">"tractor.track"</span>)
s <-<span class="st"> </span><span class="kw">attachMriSession</span>(<span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>), <span class="st">"tests"</span>, <span class="st">"data"</span>, <span class="st">"session"</span>))
p <-<span class="st"> </span>s$<span class="kw">getTracker</span>()$<span class="kw">run</span>(<span class="kw">c</span>(<span class="dv">50</span>,<span class="dv">59</span>,<span class="dv">33</span>), <span class="dt">count=</span><span class="dv">1000</span>, <span class="dt">requireStreamlines=</span><span class="ot">TRUE</span>)</code></pre></div>
<p>The first argument to the <code>run()</code> method of the tracker provides the 3D coordinates of the seed point—using the R convention of indexing from one—and <code>count</code> is the number of streamlines to generate. (If <code>count</code> is set to 1, then only a single streamline is generated, and the result is analogous to “deterministic” tractography.) The resulting set of streamlines is written to a file in TrackVis “.trk” format (<a href="#bibliography">Wang & Wedeen, 2015</a>), which may be visualised in the TrackVis program, or else plotted within R as shown in the figure above.</p>
<p>A common method of presentation for tractography results is as a visitation map or spatial histogram, an image with the same resolution as the original dMRI images wherein each voxel’s value is the number of streamlines which pass through it. An example is shown in subfigure b, above, as a maximum intensity projection overlaid on a slice of the FA image. This type of visualisation may be created using the following TractoR code.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">fa <-<span class="st"> </span>s$<span class="kw">getImageByType</span>(<span class="st">"FA"</span>)
i <-<span class="st"> </span>StreamlineSource$<span class="kw">new</span>(p)$<span class="kw">getVisitationMap</span>(fa)
<span class="kw">createSliceGraphic</span>(fa, <span class="dt">z=</span><span class="dv">33</span>)
<span class="kw">createProjectionGraphic</span>(i, <span class="dt">axis=</span><span class="dv">3</span>, <span class="dt">colourScale=</span><span class="dv">2</span>, <span class="dt">add=</span><span class="ot">TRUE</span>)</code></pre></div>
<p><img src="" /><!-- --></p>
<p>Note that an object of class <code>StreamlineSource</code> is created as a wrapper around the “.trk” file full of streamlines created above, and the visitation map is retrieved by calling this object’s <code>getVisitationMap()</code> method. The <code>axis</code> option in the last line controls the axis of the projection, while the <code>colourScale</code> option is used to select a heatmap, rather than greyscale, colour lookup table for the overlay. Since <code>add=TRUE</code> is given, the projection is overlaid on the FA slice graphic created by the previous command.</p>
<p>If only a visitation map is required, without the intermediate set of streamlines, then the same effect may be achieved using the command</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">i <-<span class="st"> </span><span class="kw">readImageFile</span>(s$<span class="kw">getTracker</span>()$<span class="kw">run</span>(<span class="kw">c</span>(<span class="dv">50</span>,<span class="dv">59</span>,<span class="dv">33</span>), <span class="dt">count=</span><span class="dv">1000</span>))</code></pre></div>
<p>This works because the <code>run()</code> method of the <code>Tracker</code> class returns the path to the file or files that it creates.</p>
</div>
<div id="tracking-between-regions" class="section level3">
<h3>Tracking between regions</h3>
<p>An alternative to single seed tractography, which is relevant to many applications, is tracking between regions of the brain. Under this arrangement, a seed region is used to generate streamlines, and one or more “waypoint” regions are used to constrain their paths. In most implementations, streamlines which do not pass through all of the waypoint regions are simply discarded.</p>
<p>TractoR provides facilities for identifying target regions and filtering out streamlines that do not reach them. For example,</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="co"># Create a 3 x 3 x 3 voxel neighbourhood</span>
n <-<span class="st"> </span><span class="kw">createNeighbourhoodInfo</span>(<span class="dv">3</span>)
<span class="co"># Duplicate the FA map twice, fill each with 0s, and then add 1s</span>
<span class="co"># within the neighbourhood of a point in each case</span>
seed <-<span class="st"> </span>fa$<span class="kw">copy</span>()$<span class="kw">fill</span>(0L)
seed[<span class="kw">t</span>(n$vectors +<span class="st"> </span><span class="kw">c</span>(<span class="dv">42</span>,<span class="dv">66</span>,<span class="dv">32</span>))] <-<span class="st"> </span>1L
target <-<span class="st"> </span>fa$<span class="kw">copy</span>()$<span class="kw">fill</span>(0L)
target[<span class="kw">t</span>(n$vectors +<span class="st"> </span><span class="kw">c</span>(<span class="dv">58</span>,<span class="dv">66</span>,<span class="dv">33</span>))] <-<span class="st"> </span>1L
<span class="co"># Retrieve the session's tracker and set options, then track</span>
tracker <-<span class="st"> </span>s$<span class="kw">getTracker</span>()$<span class="kw">setTargets</span>(target)$<span class="kw">setFilters</span>(<span class="dt">minTargetHits=</span><span class="dv">1</span>)
i <-<span class="st"> </span><span class="kw">readImageFile</span>(tracker$<span class="kw">run</span>(seed$<span class="kw">getNonzeroIndices</span>(), <span class="dt">count=</span><span class="dv">500</span>))
<span class="co">#> 4450 streamlines (33%) were retained after filtering</span>
<span class="co"># Visualise the result, and the original regions of interest</span>
<span class="kw">createSliceGraphic</span>(fa, <span class="dt">z=</span><span class="dv">32</span>)
<span class="kw">createProjectionGraphic</span>(i, <span class="dt">axis=</span><span class="dv">3</span>, <span class="dt">colourScale=</span><span class="dv">2</span>, <span class="dt">add=</span><span class="ot">TRUE</span>)
<span class="kw">createSliceGraphic</span>(seed, <span class="dt">z=</span><span class="dv">32</span>, <span class="dt">colourScale=</span><span class="st">"green"</span>, <span class="dt">add=</span><span class="ot">TRUE</span>)
<span class="kw">createSliceGraphic</span>(target, <span class="dt">z=</span><span class="dv">32</span>, <span class="dt">colourScale=</span><span class="st">"blue"</span>, <span class="dt">add=</span><span class="ot">TRUE</span>)</code></pre></div>
<p><img src="" /><!-- --></p>
<p>In this case, the <code>count</code> option controls the number of streamlines generated <em>per seed point</em> within the mask. These commands create a seed mask and waypoint mask (each as a 3 x 3 x 3 voxel block), run tractography using them, and visualise the results. The visualisation is built up with an FA slice as the base layer, then a projection of the tract, and finally the two regions of interest.</p>
</div>
<div id="neighbourhood-tractography" class="section level3">
<h3>Neighbourhood tractography</h3>
<p>“Neighbourhood tractography” is an alternative to waypoint methods, which uses a reference tract and machine learning methods to find consistent representations of a particular tract of interest in a group of dMRI data sets (<a href="#bibliography">Clayden et al., 2007, 2009b</a>). The principle is to model the variation in shape of the tract across individuals, and then evaluate the plausibility of a given “candidate tract” as a match to the reference tract. The <strong>tractor.nt</strong> package provides functions and supporting data structures for performing neighbourhood tractography, and a standard set of reference tracts are provided with the main TractoR distribution (<a href="#bibliography">Muñoz Maniega et al., 2008</a>). New reference tracts may also be created by the user.</p>
<p>Reference and candidate tracts are represented for these purposes as B-splines with a fixed distance between knot points. Where multiple streamlines are generated from a single seed point, the spline is fitted to the spatial median of the set. One knot is arranged to coincide with the seed point, and for the <span class="math inline">\(i\)</span>th candidate tract in a data set there are then <span class="math inline">\(L_1^i\)</span> knots to one side of the seed, and <span class="math inline">\(L_2^i\)</span> to the other. Working away from the seed point, we denote the angle between the straight line connecting knot <span class="math inline">\(u-1\)</span> to knot <span class="math inline">\(u\)</span>, and its equivalent in the reference tract, with <span class="math inline">\(\phi^i_u\)</span>. The index, <span class="math inline">\(u\)</span>, is taken as being negative to one side of the seed, and positive to the other side.</p>
<p>A set of indicator variables, <span class="math inline">\((z^i)\)</span>, describe which candidate tract is the best match to the reference tract within the data set, such that <span class="math inline">\(z^i=1\)</span> if tract <span class="math inline">\(i\)</span> is the best match and <span class="math inline">\(z^i=0\)</span> otherwise. The special case <span class="math inline">\(z^0=1\)</span> is also allowed, to indicate no match. The likelihood of the model given the observed data then depends on the value of the relevant indicator variable. Our aim is to establish the posterior distribution <span class="math inline">\(P(z^i\,|\,D)\)</span>, where <span class="math inline">\(D\)</span> represents all data, for all candidate tracts, subject to the constraint that</p>
<p><span class="math display">\[\sum_{i=0}^N P(z^i=1) = 1 \, ;\]</span></p>
<p>i.e., there is exactly one best match, or none.</p>
<p>Given the shape and length data for the best matching tract and an appropriate reference tract, the likelihood is given by</p>
<p><span class="math display">\[P(\mathbf{d}^i\,|\,\mathbf{A},\mathbf{p},z^i=1) = P(L^i_1\,|\,L^*_1,\mathbf{p}_1,z^i=1) \, P(L^i_2\,|\,L^*_2,\mathbf{p}_2,z^i=1) \prod_{u=1}^{\check{L}^i_1} P(\phi^i_{-u}\,|\,\alpha_u,z^i=1) \prod_{u=1}^{\check{L}^i_2} P(\phi^i_{u}\,|\,\alpha_u,z^i=1) \; ,\]</span></p>
<p>where <span class="math inline">\(\mathbf{d}^i = (L_1^i,L_2^i,(\phi_u^i))\)</span>, <span class="math inline">\(\mathbf{A}=(\alpha_u)\)</span> and <span class="math inline">\(\mathbf{p}=(\mathbf{p}_1,\mathbf{p}_2)\)</span>—the latter two being parameters of the model. <span class="math inline">\(L^*_1\)</span> and <span class="math inline">\(L^*_2\)</span> are the lengths of the reference tract corresponding to <span class="math inline">\(L^i_1\)</span> and <span class="math inline">\(L^i_2\)</span> respectively; <span class="math inline">\(\check{L}^i_1 = \min \{ L^i_1, L^*_1 \}\)</span>, and equivalently for <span class="math inline">\(\check{L}^i_2\)</span>. The corresponding forward model for tracts which do not match the reference (with <span class="math inline">\(z^i=0\)</span>) is uninformative, since the reference tract is not a good predictor of their topologies.</p>
<div class="figure">
<img src="" alt="Graphical representation of the tract shape model for tracts matched to a reference tract, including priors on model parameters. The shaded nodes represent observed variables." />
<p class="caption"><em>Graphical representation of the tract shape model for tracts matched to a reference tract, including priors on model parameters. The shaded nodes represent observed variables.</em></p>
</div>
<p>A graphical representation of this model is shown above, and the distributional details are as follows.</p>
\begin{align}
L^i_1 \, | \, L^*_1 \sim \mathrm{Multinomial}(n_1,\mathbf{p}_1) \nonumber \\
L^i_2 \, | \, L^*_2 \sim \mathrm{Multinomial}(n_2,\mathbf{p}_2) \\
\frac{\cos \phi^i_u + 1}{2} \sim \mathrm{Beta}(\alpha_u,1) \nonumber
\end{align}
<p>where <span class="math inline">\(n_1 = |\mathbf{p}_1|\)</span>, and equivalently for <span class="math inline">\(n_2\)</span>. Multinomial distributions are appropriate for the tract length variables because they reflect the number of knots either side of the seed point, which must be integral. The true length of the tract is therefore approximated by the sum of the fixed-length gaps between knots. We apply the prior</p>
<p><span class="math display">\[\alpha_u - 1 \sim \mathrm{Exponential}(\lambda) \; ,\]</span></p>
<p>which constrains each <span class="math inline">\(\alpha_u\)</span> to ensure that smaller deviations from the reference tract are always more likely (<span class="math inline">\(\alpha_u \geq 1\)</span>), and also regularises their distributions to avoid model overfitting for small data sets.</p>
<p>The model may be fitted in a supervised fashion by choosing a set of training tracts representing good matches to the reference , or taking an unsupervised approach using an Expectation–Maximisation (EM) algorithm (<a href="#bibliography">Clayden et al., 2009b</a>). The unsupervised approach is generally preferable in applications, unless test data are very scarce, in which case it may be helpful to train from another population. The same framework may also be used to remove individual streamlines which are inconsistent with the trajectory of the reference tract (<a href="#bibliography">Clayden et al., 2009a</a>).</p>
<p>A set of B-spline tract representations suitable for training or evaluating against a model may be created using the following commands.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(<span class="st">"tractor.nt"</span>)
s <-<span class="st"> </span><span class="kw">attachMriSession</span>(<span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>), <span class="st">"tests"</span>, <span class="st">"data"</span>, <span class="st">"session"</span>))
r <-<span class="st"> </span><span class="kw">getNTResource</span>(<span class="st">"reference"</span>, <span class="st">"pnt"</span>, <span class="kw">list</span>(<span class="dt">tractName=</span><span class="st">"genu"</span>))
n <-<span class="st"> </span><span class="kw">createNeighbourhoodInfo</span>(<span class="dt">centre=</span><span class="kw">c</span>(<span class="dv">50</span>,<span class="dv">59</span>,<span class="dv">33</span>), <span class="dt">width=</span><span class="dv">3</span>)
l <-<span class="st"> </span><span class="kw">calculateSplinesForNeighbourhood</span>(s, n, r, <span class="dt">nStreamlines=</span><span class="dv">100</span>)</code></pre></div>
<p>Here, we are using the standard reference for the “genu” tract as the reference, and creating B-spline candidate tracts for every point within a <span class="math inline">\(3 \times 3 \times 3\)</span> voxel neighbourhood centred at (50,59,33). (The <code>getNTResource()</code> function is used to obtain various standard resources provided with TractoR for performing neighbourhood tractography. In this case, we are requesting a reference tract, <code>"reference"</code>, associated with tract name <code>"genu"</code>, appropriate for probabilistic neighbourhood tractography, <code>"pnt"</code>.) Each B-spline is fitted to the median of 100 sampled streamlines. We must then calculate the components of <span class="math inline">\(\mathbf{d}^i\)</span> for each seed point, and this is achieved with</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">d <-<span class="st"> </span><span class="kw">createDataTableForSplines</span>(l, r$<span class="kw">getTract</span>(), <span class="st">"knot"</span>, <span class="dt">sessionPath=</span>s$<span class="kw">getDirectory</span>(), <span class="dt">neighbourhood=</span>n)</code></pre></div>
<p>The reference tract needs to be provided here to calculate the angles, <span class="math inline">\((\phi^i_u)\)</span>, between segments of the reference and candidate tracts.</p>
<p>We can now fit a model using these B-spline tracts as training data. (Of course, this is not wise in practice without manually removing aberrant tracts, and in any case tracts from several data sets should be used for a generalisable model, but this serves to illustrate the method.)</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">m <-<span class="st"> </span><span class="kw">newMatchingTractModelFromDataTable</span>(d, r$<span class="kw">getTract</span>(), <span class="dt">lambda=</span><span class="dv">1</span>, <span class="dt">alphaOffset=</span><span class="dv">1</span>, <span class="dt">weights=</span><span class="ot">NULL</span>, <span class="dt">asymmetric=</span><span class="ot">TRUE</span>)
<span class="kw">print</span>(m)
<span class="co">#> INFO: [x27] Fitting B-spline model with fixed knot spacing of 8.38</span>
<span class="co">#> Asymmetric model : TRUE</span>
<span class="co">#> Alphas (left) : 1.98, 1.96, 1.99, 1.96, 1.99</span>
<span class="co">#> Alphas (right) : 1.99, 1.97, 1.99, 1.97, 1.95</span>
<span class="co">#> Ref tract lengths : 6 (left), 6 (right)</span>
<span class="co">#> Length cutoff : 11</span>
<span class="co">#> Point type : knot</span></code></pre></div>
<p>The model object has class <code>MatchingTractModel</code>. The values of <code>lambda</code> (<span class="math inline">\(\lambda\)</span>), <code>alphaOffset</code> and <code>weights</code> specified here will have a significant effect on the outcome—indeed, with only one subject in the data set, the prior dominates in this example, limiting the values of <span class="math inline">\(\alpha_u\)</span> severely. The larger the value of <code>lambda</code>, the greater the extent to which the prior will favour small values of <span class="math inline">\(\alpha_u\)</span>, since the exponential prior has mean <span class="math inline">\(1/\lambda\)</span>. A value of <code>alphaOffset=1</code> corresponds to the prior given above. If the specified weights are <code>NULL</code>, then each tract is given the same weight. In the EM context, this corresponds to an assumption that each tract is <em>a priori</em> equiprobable. The <code>asymmetric</code> parameter determines whether a constraint that <span class="math inline">\(\alpha_u = \alpha_{-u}\)</span> should be applied (the symmetric case) or not (the asymmetric case). It is generally wise to set this to <code>TRUE</code> unless very few data are available.</p>
<p>The trained model generated above may be used directly to calculate the posterior matching probabilities of a new set of candidate tracts. However, in applications it is often helpful to work in an unsupervised fashion, learning the model and calculating posteriors in one go, since this removes the need for separate training data. This can be achieved as follows.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">m <-<span class="st"> </span><span class="kw">runMatchingEMForDataTable</span>(d, r$<span class="kw">getTract</span>(), <span class="dt">lambda=</span><span class="dv">1</span>, <span class="dt">alphaOffset=</span><span class="dv">1</span>, <span class="dt">asymmetricModel=</span><span class="ot">TRUE</span>)
<span class="co">#> Starting EM algorithm</span>
<span class="kw">print</span>(m$mm)
<span class="co">#> Asymmetric model : TRUE</span>
<span class="co">#> Alphas (left) : 1.98, 1.97, 1.99, 1.96, 1.98</span>
<span class="co">#> Alphas (right) : 1.99, 1.97, 1.99, 1.97, 1.96</span>
<span class="co">#> Ref tract lengths : 6 (left), 6 (right)</span>
<span class="co">#> Length cutoff : 13</span>
<span class="co">#> Point type : knot</span>
<span class="kw">which.max</span>(m$tp[[<span class="dv">1</span>]])
<span class="co">#> [1] 2</span></code></pre></div>
<p>The list <code>m$tp</code> gives the tract matching posteriors for each subject in the data set. Here, under the final model, the 2nd (of 27) candidate tracts has the highest posterior. The mean FA within this tract may finally be calculated as follows.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="co"># Read the visitation map, threshold and binarise it</span>
i <-<span class="st"> </span><span class="kw">readImageFile</span>(s$<span class="kw">getTracker</span>()$<span class="kw">run</span>(n$vectors[,<span class="dv">2</span>], <span class="dt">count=</span><span class="dv">1000</span>))
i$<span class="kw">threshold</span>(<span class="fl">0.01</span>*<span class="kw">max</span>(i))$<span class="kw">binarise</span>()
fa <-<span class="st"> </span>s$<span class="kw">getImageByType</span>(<span class="st">"FA"</span>)
<span class="co"># Find the average FA within the nonzero voxels of the thresholded map</span>
<span class="kw">mean</span>(fa[i$<span class="kw">getNonzeroIndices</span>()], <span class="dt">na.rm=</span><span class="ot">TRUE</span>)
<span class="co">#> [1] 0.4718762</span></code></pre></div>
<p>This represents the mean FA within the region visited by at least 1% (<code>i$threshold(0.01*max(i))</code>) of the streamlines initiated from the final seed point. Mean FA values from a full data set may then be analysed using standard R hypothesis testing functions such as <code>t.test()</code> or <code>cor.test()</code>.</p>
<p>It should be noted that there is considerable scope in the code provided with the <strong>tractor.nt</strong> package for adjusting the exact processes applied, or for using similar models for other purposes, but we have focussed on a standard usage here for brevity.</p>
</div>
</div>
<div id="the-tractor-shell-interface" class="section level2">
<h2>The TractoR shell interface</h2>
<p>In addition to the three main R packages whose major functionality has been laid out above, TractoR provides a shell interface and set of related R “experiment scripts” for performing various common tasks quickly and directly. In addition, it allows those without experience of working with R to use some of TractoR’s core functionality immediately. An additional R package, <strong>tractor.utils</strong>, exists mainly to support this interface. It should be noted that the interface uses a Unix shell script and is therefore not directly usable in Windows.</p>
<p>The interface works through a single shell script program called <code>tractor</code>, which may be executed by typing just its name if the <code>bin</code> subdirectory of the TractoR distribution is on the user’s <code>PATH</code>. Specific tasks are chosen by giving the name of a particular experiment script: for example, the <code>dpreproc</code> script may be used for preprocessing dMRI data, the <code>track</code> script can be used for performing tractography, and so on. All available experiment scripts may be listed by using the <code>list</code> script, viz.</p>
<div class="sourceCode"><pre class="sourceCode bash"><code class="sourceCode bash"><span class="kw">tractor</span> list
<span class="co">#> Starting TractoR environment...</span>
<span class="co">#> Experiment scripts found in /usr/local/tractor/share/experiments:</span>
<span class="co">#> [1] age apply bedpost binarise </span>
<span class="co">#> [5] chfiletype clone components compress </span>
<span class="co">#> [9] console dicomread dicomsort dicomtags </span>
<span class="co">#> [13] dirviz dpreproc extract freesurf </span>
<span class="co">#> [17] gradcheck gradread gradrotate graph-build </span>
<span class="co">#> [21] graph-decompose graph-extract graph-props graph-reweight </span>
<span class="co">#> [25] graph-viz graph2csv hnt-eval hnt-interpret </span>
<span class="co">#> [29] hnt-ref hnt-viz imageinfo imagestats </span>
<span class="co">#> [33] import list mean mkroi </span>
<span class="co">#> [37] morph parcellate path peek </span>
<span class="co">#> [41] platform plotcorrections pnt-data pnt-em </span>
<span class="co">#> [45] pnt-eval pnt-interpret pnt-prune pnt-ref </span>
<span class="co">#> [49] pnt-train pnt-viz reg-apply reg-check </span>
<span class="co">#> [53] reg-info reg-linear reg-nonlinear reg-viz </span>
<span class="co">#> [57] reshape slice smooth split </span>
<span class="co">#> [61] status tensorfit track transform </span>
<span class="co">#> [65] trim update values view </span>
<span class="co">#> </span>
<span class="co">#> Experiment completed with 0 warning(s) and 0 error(s)</span></code></pre></div>
<p>In addition, a description and list of supported arguments and options for a particular script may be obtained by using the <code>-o</code> flag to the <code>tractor</code> program.</p>
<div class="sourceCode"><pre class="sourceCode bash"><code class="sourceCode bash"><span class="kw">tractor</span> -o mean
<span class="co">#> OPTIONS for script /usr/local/tractor/share/experiments/mean.R (* required)</span>
<span class="co">#> AveragingMode: binary [weighted]</span>
<span class="co">#> ThresholdLevel: 0.01</span>
<span class="co">#> ThresholdRelativeTo: nothing [maximum,minimum]</span>
<span class="co">#> ARGUMENTS: metric image, [mask image]</span>
<span class="co">#> </span>
<span class="co">#> DESCRIPTION:</span>
<span class="co">#> Calculate the mean or weighted mean value of a metric within the nonzero region </span>
<span class="co">#> of a brain volume. The specified mask image can be used as a binary mask (the </span>
<span class="co">#> default) or as a set of weights (with AveragingMode:weighted). In the latter </span>
<span class="co">#> case any weight threshold given is ignored. If the mask is missing then the </span>
<span class="co">#> metric image is itself the mask.</span></code></pre></div>
<p>The <code>tractor</code> program has a full Unix <code>man</code> page, and that may be consulted for further details on how to use and configure this interface. Finally, it is possible to call these scripts from R, using the <code>callExperiment()</code> function.</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(<span class="st">"tractor.utils"</span>)
<span class="kw">callExperiment</span>(<span class="st">"imageinfo"</span>, <span class="kw">file.path</span>(<span class="kw">Sys.getenv</span>(<span class="st">"TRACTOR_HOME"</span>),<span class="st">"share"</span>,<span class="st">"mni"</span>,<span class="st">"brain"</span>), <span class="dt">outputLevel=</span>OL$Info)
<span class="co">#> Running experiment script /usr/local/tractor/share/experiments/imageinfo.R</span>
<span class="co">#> Image source : /usr/local/tractor/share/mni/brain</span>
<span class="co">#> Image dimensions : 197 x 233 x 189 voxels</span>
<span class="co">#> Voxel dimensions : 1 x 1 x 1 mm</span>
<span class="co">#> Coordinate origin : (99,135,73)</span>
<span class="co">#> Additional tags : (none)</span></code></pre></div>
</div>
<div id="conclusion" class="section level2">
<h2>Conclusion</h2>
<p>In this paper we have described <strong>TractoR</strong>, a set of R packages along with a separate shell interface and scripting platform for processing magnetic resonance images in general, and dMRI data in particular. The package provides facilities for general-purpose reading, writing and manipulation of 2D, 3D and 4D images, along with signal modelling, tractography and tract shape modelling functions specific to dMRI. Relatively recent additions which have not been explicitly covered in this paper include image registration using the <strong>RNiftyReg</strong> package (<a href="#bibliography">Clayden, 2016b</a>), and graph-based “connectome” analysis. It is intended that this platform will continue to broaden in the future, making further use of the comprehensive statistical capabilities of the R language and package ecosystem.</p>
</div>
<div id="bibliography" class="section level2">
<h2>Bibliography</h2>
<p>Basser PJ, Mattiello J, Le Bihan D (1994). “Estimation of the Effective Self-Diffusion Tensor from the NMR Spin Echo.” <em>Journal of Magnetic Resonance, Series B</em>, <strong>103</strong>(3), 247–254.</p>
<p>Behrens TEJ, Johansen-Berg H, Jbabdi S, Rushworth MFS, Woolrich MW (2007). “Probabilistic Diffusion Tractography with Multiple Fibre Orientations: What Can We Gain?” <em>NeuroImage</em>, <strong>34</strong>(1), 144–155.</p>
<p>Clayden JD (2016a). “mmand: Mathematical Morphology in Any Number of Dimensions.” Version 1.3.0, <a href="https://cran.r-project.org/package=mmand" class="uri">https://cran.r-project.org/package=mmand</a>.</p>
<p>Clayden JD (2016b). “RNiftyReg: Image Registration Using the NiftyReg Library.” Version 2.3.0, <a href="https://cran.r-project.org/package=RNiftyReg" class="uri">https://cran.r-project.org/package=RNiftyReg</a>.</p>
<p>Clayden JD, Clark CA (2010). “On the Importance of Appropriate Fibre Population Selection in Diffusion Tractography.” In <em>Proceedings of the ISMRM-ESMRMB Joint Annual Meeting</em>, p. 1679. International Society for Magnetic Resonance in Medicine.</p>
<p>Clayden JD, King MD, Clark CA (2009a). “Shape Modelling for Tract Selection.” In GZ Yang, D Hawkes, D Rueckert, A Noble, C Taylor (eds.), <em>Medical Image Computing and Computer-Assisted Intervention</em>, volume 5762 of <em>Lecture Notes in Computer Science</em>, pp. 150–157. Springer-Verlag.</p>
<p>Clayden JD, Storkey AJ, Bastin ME (2007). “A Probabilistic Model-Based Approach to Consistent White Matter Tract Segmentation.” <em>IEEE Transactions on Medical Imaging</em>, <strong>26</strong>(11), 1555–1561.</p>
<p>Clayden JD, Storkey AJ, Muñoz Maniega S, Bastin ME (2009b). “Reproducibility of Tract Segmentation Between Sessions Using an Unsupervised Modelling-Based Approach.” <em>NeuroImage</em>, <strong>45</strong>(2), 377–385.</p>
<p>Evans A, Kamber M, Collins DL, MacDonald D (1994). “An MRI-Based Probabilistic Atlas of Neuroanatomy.” In S Shorvon, D Fish, F Andermann, GM Bydder, H Stefan (eds.), <em>Magnetic Resonance Scanning and Epilepsy</em>, volume 264 of <em>NATO ASI Series A, Life Sciences</em>, pp. 263–274. Plenum Press.</p>
<p>Friston K, Ashburner J, Kiebel S, Nichols T, Penny W (eds.) (2007). <em>Statistical Parametric Mapping: The Analysis of Functional Brain Images.</em> Academic Press, New York.</p>
<p>Jones DK (2008). “Studying Connections in the Living Human Brain with Diffusion MRI.” <em>Cortex</em>, <strong>44</strong>(8), 936–952.</p>
<p>Le Bihan D (2003). “Looking into the Functional Architecture of the Brain with Diffusion MRI.” <em>Nature Reviews Neuroscience</em>, <strong>4</strong>(6), 469–480.</p>
<p>MacKay DJC (1995). “Probable Networks and Plausible Predictions — A Review of Practical Bayesian Methods for Supervised Neural Networks.” <em>Network: Computation in Neural Systems</em>, <strong>6</strong>(3), 469–505.</p>
<p>Muñoz Maniega S, Bastin ME, McIntosh AM, Lawrie SM, Clayden JD (2008). “Atlas-Based Reference Tracts Improve Automatic White Matter Segmentation with Neighbourhood Tractography.” In <em>Proceedings of the ISMRM 16th Scientific Meeting & Exhibition</em>, p. 3318. International Society for Magnetic Resonance in Medicine.</p>
<p>Polzehl J, Tabelow K (2009). “Structural Adaptive Smoothing in Diffusion Tensor Imaging: The R Package dti.” <em>Journal of Statistical Software</em>, <strong>31</strong>(9), 1–23.</p>
<p>R Core Team (2016). “R: A Language and Environment for Statistical Computing.” R Foundation for Statistical Computing.</p>
<p>Salvador R, Peña A, Menon DK, Carpenter TA, Pickard JD, Bullmore ET (2005). “Formal Characterization and Extension of the Linearized Diffusion Tensor Model.” <em>Human Brain Mapping</em>, <strong>24</strong>(2), 144–155.</p>
<p>Smith SM, Jenkinson M, Woolrich MW, Beckmann CF, Behrens TEJ, Johansen-Berg H, Bannister PR, De~Luca M, Drobnjak I, Flitney DE, Niazy RK, Saunders J, Vickers J, Zhang Y, De~Stefano N, Brady JM, Matthews PM (2004). “Advances in Functional and Structural MR Image Analysis and Implementation as FSL.” <em>NeuroImage</em>, <strong>23 Suppl 1</strong>, S208–S219.</p>
<p>Wang R, Wedeen VJ (2015). “TrackVis.” Version 0.6.0, <a href="http://www.trackvis.org" class="uri">http://www.trackvis.org</a>.</p>
</div>
<!-- dynamically load mathjax for compatibility with self-contained -->
<script>
(function () {
var script = document.createElement("script");
script.type = "text/javascript";
script.src = "https://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
document.getElementsByTagName("head")[0].appendChild(script);
})();
</script>
</body>
</html>