User Tools

Site Tools


neuroimagen:fmri

Notas para crear un pipeline de fMRI

Conversión a NIfTI-1

Que bonito, hay dos tipos de formato diferentes. A ver como hacemos.

ep2d_pace_moco_p2

Este es facil y se convierte con dcm2nii. El DICOM consiste en una serie de scaners completos (150). Básicamente lo que hecho es localizar los fMRI de este tipo y escribirlos en un archivo.

for x in `find ./ -name Img00001.dcm`; do if [[ `dckey -k "SeriesDescription" "$x" 2>&1 | grep ep2d_pace_moco_p2` ]]; then echo $x | awk -F"/" {'print $2,$3'} | sed 's/F/0/;s/Serie(//;s/)//'; fi; done | sort > ~/data/facehbi/ep2d_pace_moco_p2.loc

y despues un script en perl para automatizar la conversión

moco2nii

que se ejecuta con

dcm_moco_2nii.pl -e facehbi

y otro script para organizarlo, por aquello de la vagancia de cada cual

moco organizer ;-)

ep2d_fid_bold_p2

Por lo pronto la mejor manera de convertir de DICOM a nifti parece ser utilizando spm. Básicamente abrimos matlab, llamamos el spm y hacemos ahí la conversión. Pero siguiendo al viejo Jack (The Ripper), vayamos por partes.

Los pasos a seguir aqui son especificos para el proyecto FACEHBI pero aplicables a cualquier otro. Primero hay que encontrar donde estan las imágenes fMRI de cada sujeto.

$ cd ~/data/facehbi/fmri/
$ for x in /nas/corachan/facehbi/*; do for y in `ls $x`; do a=(`ls "$x/$y" | head -n 1`) ; if [[ `dckey -k "SeriesDescription" "$x/$y/$a" 2>&1 | grep bold` ]]; then echo "$x - $y"; fi; done; done 2>&1| grep -v "No such file or directory"

que da un resultado como este:

/nas/corachan/facehbi/F005 - Serie(22)
/nas/corachan/facehbi/F009 - Serie(21)
/nas/corachan/facehbi/F010 - Serie(22)
/nas/corachan/facehbi/F011 - Serie(24)
/nas/corachan/facehbi/F012 - Serie(21)
/nas/corachan/facehbi/F013 - Serie(22)
/nas/corachan/facehbi/F015 - Serie(10)

Esto se puede escribir a un file o lo que sea pero de entrada ya tenemos con que empezar a trabajar.

Ahora ya abrimos matlab y cargamos el SPM. Lamentablemente aqui hay que ir despacio por cada archivo. La conversion demora mucho. Lo mas parecido es hacer un batch pero todavia no entiendo muy bien que podria hacer para editarlo externamente. asi que ahi vamos,

Después, por cada sujeto, queda un grupo de archivos así:

$ ls f005/
sD417843-0024-00001-000001-01.nii  sD417843-0024-00012-000474-01.nii  sD417843-0024-00023-000947-01.nii  sD417843-0024-00034-001420-01.nii  sD417843-0024-00045-001893-01.nii  sD417843-0024-00056-002366-01.nii  sD417843-0024-00067-002839-01.nii
sD417843-0024-00002-000044-01.nii  sD417843-0024-00013-000517-01.nii  sD417843-0024-00024-000990-01.nii  sD417843-0024-00035-001463-01.nii  sD417843-0024-00046-001936-01.nii  sD417843-0024-00057-002409-01.nii  sD417843-0024-00068-002882-01.nii
sD417843-0024-00003-000087-01.nii  sD417843-0024-00014-000560-01.nii  sD417843-0024-00025-001033-01.nii  sD417843-0024-00036-001506-01.nii  sD417843-0024-00047-001979-01.nii  sD417843-0024-00058-002452-01.nii  sD417843-0024-00069-002925-01.nii
sD417843-0024-00004-000130-01.nii  sD417843-0024-00015-000603-01.nii  sD417843-0024-00026-001076-01.nii  sD417843-0024-00037-001549-01.nii  sD417843-0024-00048-002022-01.nii  sD417843-0024-00059-002495-01.nii  sD417843-0024-00070-002968-01.nii
sD417843-0024-00005-000173-01.nii  sD417843-0024-00016-000646-01.nii  sD417843-0024-00027-001119-01.nii  sD417843-0024-00038-001592-01.nii  sD417843-0024-00049-002065-01.nii  sD417843-0024-00060-002538-01.nii  sD417843-0024-00071-003011-01.nii
sD417843-0024-00006-000216-01.nii  sD417843-0024-00017-000689-01.nii  sD417843-0024-00028-001162-01.nii  sD417843-0024-00039-001635-01.nii  sD417843-0024-00050-002108-01.nii  sD417843-0024-00061-002581-01.nii  sD417843-0024-00072-003054-01.nii
sD417843-0024-00007-000259-01.nii  sD417843-0024-00018-000732-01.nii  sD417843-0024-00029-001205-01.nii  sD417843-0024-00040-001678-01.nii  sD417843-0024-00051-002151-01.nii  sD417843-0024-00062-002624-01.nii  sD417843-0024-00073-003097-01.nii
sD417843-0024-00008-000302-01.nii  sD417843-0024-00019-000775-01.nii  sD417843-0024-00030-001248-01.nii  sD417843-0024-00041-001721-01.nii  sD417843-0024-00052-002194-01.nii  sD417843-0024-00063-002667-01.nii  sD417843-0024-00074-003140-01.nii
sD417843-0024-00009-000345-01.nii  sD417843-0024-00020-000818-01.nii  sD417843-0024-00031-001291-01.nii  sD417843-0024-00042-001764-01.nii  sD417843-0024-00053-002237-01.nii  sD417843-0024-00064-002710-01.nii
sD417843-0024-00010-000388-01.nii  sD417843-0024-00021-000861-01.nii  sD417843-0024-00032-001334-01.nii  sD417843-0024-00043-001807-01.nii  sD417843-0024-00054-002280-01.nii  sD417843-0024-00065-002753-01.nii
sD417843-0024-00011-000431-01.nii  sD417843-0024-00022-000904-01.nii  sD417843-0024-00033-001377-01.nii  sD417843-0024-00044-001850-01.nii  sD417843-0024-00055-002323-01.nii  sD417843-0024-00066-002796-01.nii

Pero algunos barridos no son correctos por lo que algunas de las imagenes estan cortadas. Para identificarlas intentamos unirlas,

$ fslmerge -t f005 `for x in f005/*; do echo $x; done | sed ':a;N;$!ba;s/\n/ /g'`
Error in size-match along non-concatenated dimension for input file: f005/sD417843-0024-00074-003140-01.nii

El error nos dice la imagen que esta mal, asi que la borramos,

$ rm f005/sD417843-0024-00074-003140-01.nii

y lo intetamos de nuevo hasta tener la imagen correcta,

$ ls -l f005.nii.gz 
-rw-rw---- 1 osotolongo osotolongo 13786881 Sep  9  2015 f005.nii.gz

En este punto tenemos las imagenes correctas convertidas a NIfTI y podemos empezar el preprocesamiento.

Preprocesamiento con AFNI

Esto no es más que una colección de pasos tomados de aquí y probados.

Primero vamos a copiar el archivo a un formato de nombre familiar ;-)

$ cp fmri_conv/f005.nii.gz fmri/smc0005s0022.nii.gz

y ahora hacemos: Slice-timing correction, Motion correction (realignment), Despiking

$ 3dTshift -prefix fmri/smc0005_st.nii.gz -tpattern altplus fmri/smc0005s0022.nii.gz
$ 3dvolreg -prefix fmri/smc0005_mc.nii.gz -1Dfile fmri/smc0005_motion.1D -Fourier -twopass -zpad 4 -base fmri/smc0005_st.nii.gz[0] fmri/smc0005_st.nii.gz
$ 3dDespike -prefix fmri/smc0005_ds.nii.gz -ssave fmri/smc0005_spikiness.nii.gz fmri/smc0005_mc.nii.gz

Esto de alguna manera podría meterse en un script. A ver,

#!/bin/sh
# Ejemplo: func_pre.sh smc0014s0006 ~/data/facehbi/fmri
 
idf=$1
shift
tdir=$1
shift
id=${idf%s0*}
 
3dTshift -prefix ${tdir}/${id}_st.nii.gz -tpattern altplus ${tdir}/${idf}.nii.gz
3dvolreg -prefix ${tdir}/${id}_mc.nii.gz -1Dfile ${tdir}/${id}_motion.1D -Fourier -twopass -zpad 4 -base ${tdir}/${id}_st.nii.gz[0] ${tdir}/${id}_st.nii.gz
3dDespike -prefix ${tdir}/${id}_ds.nii.gz -ssave ${tdir}/${id}_spikiness.nii.gz ${tdir}/${id}_mc.nii.gz
fslreorient2std ${tdir}/${id}_ds.nii.gz ${tdir}/${id}_ro.nii.gz

Coregistro al espacio anatomico

Ahora hay que mover la imagen funcional al espacio anatomico del sujeto

$ flirt -omat working/smc0005_func2anat.mat -cost corratio -dof 12 -interp trilinear -ref working/smc0005_brain.nii.gz -in fmri/smc0005s0022_ro.nii.gz
$ flirt -out working/smc0005_func_inA.nii.gz -interp trilinear -applyxfm -init working/smc0005_func2anat.mat -ref working/smc0005_brain.nii.gz -in fmri/smc0005s0022_ro.nii.gz

Reducción de ruido

Esto lo voy a quitar por ahora. Vamos a ver que pasa si confiamos en la estadística.

Corregistro al espacio estandard

Ahora lo ponemos en el espacio MNI standard, pero esto ya sabiamos hacerlo, ¿no?

${FSLDIR}/bin/flirt -ref ${FSLDIR}/data/standard/MNI152_T1_2mm_brain -in ${wdir}/${id}_brain -omat ${wdir}/${id}_tmp_aff_struct2mni.mat
${FSLDIR}/bin/fnirt --in=${wdir}/${id}_struc --aff=${wdir}/${id}_tmp_aff_struct2mni.mat --cout=${wdir}/${id}_tmp_nonlinear_transf --config=T1_2_MNI152_2mm
${FSLDIR}/bin/applywarp --ref=${FSLDIR}/data/standard/MNI152_T1_2mm --in=${wdir}/${id}_func_inA --out=${wdir}/${id}_func_inMNI --warp=${wdir}/${id}_tmp_nonlinear_transf

Procesamiento (the atlas way)

Al construir la red lo ideal sería calcular la interaccion entre todos lo voxels. Pero todavía no se me ha ocurrido una manera en que pueda calcularlo con los recursos disponibles. La solucion por ahora es utilizar un atlas y calcular la interacción entre las diferentes regiones de interés (ROI). El seleccionado a priori es el atlas de Destrieux. (Ver aqui las ROI).

Lo primero entonces es calcular la serie temporal media en cada una de las ROI. Esto se hace usando 3dmaskave de AFNI,

my $order =  '3dmaskave -quiet -mrange '.$roik.' '.$roik.' -mask '.$ENV{'PIPEDIR'}.$atlas{$parcelation}{'file'}.' '.$w_dir.'/'.$subject.'_func_inMNI.nii.gz';
my @lines = qx/$order/;

y una vez guardado en memoria toda la información se calcula la interacción entre dos nodos de la red como,

<latex> r(x_{1},x_{2})=\frac{\left<V(x_{1},t)V(x_{2},t)\right> - \left<V(x_{1},t)\right>\left<V(x_{2},t)\right>}{\sigma\left(V(x_{1})\right)\sigma\left(V(x_{2})\right)} </latex>

siendo

<latex> \sigma^{2}\left(V(x)\right)=\left<V(x,t)^{2}\right> - \left<V(x,t)\right>^{2} </latex>

8-) Afortunadamente esta es una matriz triangular y

solo hay que calcular la mitad

Pero para propositos de graficar y demas voy a escribir todo a disco (a no ser que despues necestie ahorrar espacio :-?)

Pero por ahora asi va

Esto esta todo junto en func_getnet.pl que se llama desde func_nii2net.pl

Ya tengo la red y ahora que?

Lo que tienes son las interacciones entre los distintos nodos que has definido. para convertirla en una red discreta hay que fijar un umbral, por ejemplo $r>0.7$ y quedan definidos los enlaces entre los nodos,

Y ahora se pueden calcular varias cosas! El coeficiente de clustering de cada nodo, <latex> C_{i}=\frac{2E_{i}}{k_{i}(k_{i}-1)} </latex> y por consiguiente el coeficiente de clustering medio. La Degree distribution $P(k)$,

Wavelets Analysis

Libro

Statistical Analysis of fMRI Data F. Gregory Ashby

Toolbox

Conn + SPM

neuroimagen/fmri.txt · Last modified: 2020/08/04 10:58 (external edit)