Download Algoritmo de segmentación y cuantificación de la estenosis en

Document related concepts
no text concepts found
Transcript
Algoritmo de segmentación y cuantificación de la estenosis en estructuras vasculares
Juan Sebastián Ruiz – ruizvilla@gmail.com
Ricardo Arcila Toro – ricartomojo@gmail.com
El algoritmo que a continuación se plantea,
es una adaptación e implementación práctica
de la modificación del algoritmo MARACAS
para la cuantificación de la estenosis
publicada por Marcela Hernández en
conjunto con el laboratorio IMAGINE de la
universidad de los andes, y el laboratorio
CREATIS. Con base en el algoritmo
presentado a continuación se desarrollaron 2
módulos en python para la plataforma Slicer
3d mediante los cuales se implementó
efectivamente el algoritmo.
muchas mas acciones sean tomadas en
consideración. A partir de ese primer
algoritmo maracas, el grupo de investigación
imagine de la universidad de los andes
propuso una adaptación en las cuales se
tenia
en
cuenta
una
fase
de
preprocesamiento gráfico de manera que las
3 fases iniciales del algoritmo maracas
pudieran llevarse a cabo, y su resultado
tuviera una mayor precisión. A continuación
se puede observar el algoritmo propuesto
por el grupo Imagine:
El algoritmo maracas es un algoritmo de
análisis asistido por computadora de
resonancia magnética para angiografía, el
cual está basado originalmente en un
modelo que fue inicialmente diseñado para
segmentar una sola arteria en imágenes ARM
(angiografía por resonancia magnética); sin
embargo, el laboratorio IMAGINE de la
universidad de los andes realizó una
adaptación del mismo, de manera que se
tuvieran en cuenta las especificidades de las
imágenes TAC, así como la presencia de
bifurcaciones. El algoritmo MARACAS
originalmente esta comprendido por 3
etapas: extracción de la línea central,
segmentación del lumen arterial,
y
cuantificación de la estenosis. Los cuales, en
términos de alto nivel, son los pasos
necesarios para realizar la detección de
puntos anómalos; no obstante, la
implementación de estos pasos requiere que
Fig. 1- Modificación del algoritmo MARACAS
Se pueden observar 2 niveles de
procedimientos, procedimientos de bajo
nivel los cuales están enfocados a mejorar la
calidad de la imagen y presegmentarla, y la
segunda categoría son procedimientos de
alto nivel, los cuales están enfocados en
extraer la línea central de la arteria,
segmentar el lumen y cuantificar la
estenosis.
La
última
categoría
de
procedimientos hace parte del algoritmo
MARACAS original.
Dado que los algoritmos de segmentación
son
sumamente
susceptibles
a
degradaciones en la imagen y que las
imágenes CT son propensas al ruido, es
necesario agregar una etapa de filtrado al
algoritmo, en función de que los resultados
arrojados por este sean de mayor precisión.
En este caso particular se utilizó un filtro de
reducción de ruido Non-Local Means Filter.
En la etapa de realce de las estructuras y
presegmentación se basa en el principio de
que diferentes tipos de estructuras y tejidos
aparecen cada uno de manera diferente en
las imágenes de CT (siglas en ingles de
tomografía computarizada) de manera que
en esta etapa se definen umbrales con el
objetivo de clasificar los tejidos en las
siguientes clases: hueso/calcificaciones,
lumen, posible lumen los cuales son voxeles
(unidad equivalente a un pixel para una
imagen de 3 dimensiones) que típicamente
pertenecen a los bordes y no se pueden
clasificar en una categoría y por ultimo otros
tejidos.
Después de la etapa de realce y
presegmentación se encuentran las etapas
de procesamiento de alto nivel . Dado que
en la implementación actual del algoritmo no
se tienen en cuenta bifurcaciones, este paso
será obviado; sin embargo es de resaltar, que
hace parte de la propuesta de adaptación del
laboratorio imagine.
El algoritmo propuesto a continuación esta
diseñado para ser aplicado sobre imágenes
de tomografía axial computarizada, o
tomografía
computarizada,
obtenidas
después de la inyección de un radiocontraste
que realce el lumen arterial.
El algoritmo que se propuso como base de la
solución al problema que se desea resolver
en este proyecto de grado, es una
aproximación semi-automática a la detección
de anomalías cardiovasculares la cual consta
de 4 pasos:
Selección del área de interés:
La primera etapa contiene la parte no
automática del algoritmo, y es la selección de
la estructura de interés. Esta etapa consiste
en que el usuario selecciona la estructura
vascular que desea analizar. Esta etapa fue
implementada mediante el uso de la
herramienta de level tracing del módulo de
segmentación manual que posee el Slicer 3d:
Figura 2 – Selección de la estructura vascular
Segmentación del lumen arterial
La segunda etapa del algoritmo consiste en
segmentar el lumen arterial (o en su caso
general, la estructura), a partir del área
seleccionada en la primera etapa. Esto con el
fin de transformar los datos que se
encuentran en las imágenes CT, a datos
computarizados; más específicamente, a un
conjunto de voxeles (pixeles 3d) los cuales
puedan ser analizados y procesados por la
aplicación. Este paso se hace a partir de la
intensidad (representada en el nivel de gris
de los voxeles en las imágenes CT) de los
voxeles del área seleccionada. Para su
implementación nos encontramos con 2
opciones: la primera seria, realizar la
segmentación manualmente, corte a corte, y
esta sería recomendada únicamente cuando
la arteria (o estructura en su caso general) es
lo suficientemente pequeña, como por
ejemplo las arterias coronarias; la segunda
opción, la cual es utilizada para la ilustración
del algoritmo en este documento, seria
realizar la segmentación automáticamente, a
partir del área seleccionada, mediante el
módulo Robust Statistics Segmenter de la
plataforma Slicer3d, este método es
recomendado para la segmentación de
estructuras de mayor volumen, por ejemplo
la arteria aorta la disyuntiva con respecto a
los métodos de segmentación se presenta
gracias a que el nivel de precisión del módulo
Robust Statistic Segmenter es muy baja al
manejar áreas de tamaño mínimo. A
continuación es posible observar el resultado
de la etapa de segmentación del lumen
arterial, aplicada a la arteria aorta
previamente seleccionada.
Fig. 3 – Segmentación resultante de la arteria aorta vista
desde los planos: axial, sagital y coronal respectivamente
División del volumen segmentado
La tercera etapa del algoritmo consiste en
dividir el volumen 3d segmentado
anteriormente en sub-secciones. Este paso
del algoritmo fue pensado, de manera que el
procesamiento del volumen segmentado
fuera menos costoso, al disminuir el número
total de “áreas” que deben ser analizadas
por la aplicación. Este paso fue
implementado mediante el desarrollo de un
módulo de extensión, llamado “Pre-diagnosis
data treatment”, para la plataforma Slicer 3d
el cual se encarga de interceptar planos cuyo
vector normal sea paralelo a la línea central
de la estructura vascular. Actualmente en el
módulo se encuentra implementado el caso
particular para el análisis de la arteria aorta;
sin embargo, es posible extender este
módulo, de manera que pueda analizar otras
estructuras claves mediante el uso del
método de reformatización multi-planar del
Slicer 3d “Reformat”. La longitud de los
segmentos es parametrizable; sin embargo,
si la longitud de los segmentos es demasiado
grande, el algoritmo pierde precisión para
señalar la ubicación de las anomalías; y si es
muy pequeño, el algoritmo se vuelve
demasiado costoso en términos de
procesamiento; pueden llegarse a utilizar
segmentos hasta de 0,01 milímetros. Para la
implementación del caso particular de
análisis de la arteria aorta, se utilizaron
segmentos de 5 milímetros; elección basada
en datos experimentales. A continuación se
puede observar el resultado de la etapa de
división del volumen segmentado sobre el
análisis de la arteria aorta. Para el desarrollo
de este módulo se utilizaron a su vez, el
módulo de edición de segmentación del
Slicer 3d de manera que se pudieran
interceptar
los
anteriormente.
planos
mencionados
Fig. 4 – A la derecha, el ancho de una sub-sección. A la
izquierda, el resultado de la etapa de división del volumen
segmentado
Cuantificación de la estenosis, y
señalamiento de la sección anómala
La cuarta y última etapa del algoritmo
consiste en seleccionar el segmento con
menor volumen, y debido a que todos tienen
la misma longitud, las únicas variaciones
entre 2 sub-secciones arbitrarias se dan en el
área segmentada de las secciones cruzadas
cuyo plano sea normal a la línea central de la
arteria, la sub-sección de menor volumen,
será entonces la sub-sección en donde se
presente la mayor variación en el lumen de
la arteria. Al seleccionar dicha sub-sección
(sección más patológica), se compara con
otra cuyo volumen se acerque más al
volumen promedio de todos los segmentos
(sección de referencia) y se obtiene el
porcentaje de estenosis mediante la
siguiente fórmula:
En donde Sp representa el volumen de la
sub-sección más patológica, y Sr es la subsección de referencia. El grado de estenosis
determinado a partir de la anterior fórmula,
es un numero de 0 a 100 en donde 0
representa que no hay obstrucción, y 100
representa
un
vaso
completamente
obstruido. Este cuarto y último paso es
particular al caso de las arterias y las
anomalías que se den en ellas, y es
implementado mediante el desarrollo de un
módulo de extensión para la plataforma
Slicer 3d llamado “ACARDI”, el cual se
encarga de realizar la selección de la subsección más patológica, mostrar el
porcentaje de obstrucción obtenido a partir
de la fórmula ilustrada anteriormente, así
como mostrar el corte transversal en la vista
axial, en el cual se encuentra dicha
obstrucción. A continuación es posible ver el
resultado final del algoritmo aplicado a partir
de datos sintéticos que representan una
obstrucción de alrededor del 50% en la
arteria aorta.
Fig. 5 – Obstrucción Sintética desde las vistas axial y coronal
respectivamente
En los resultados ilustrados a continuación
(fig. 6) se pueden ver el porcentaje de
obstrucción en el segmento más patológico,
y las coordenada de la sección transversal en
donde se encuentra dicha obstrucción, desde
la vista axial.
Resultados
Para probar la solución propuesta en este
documento, se contó con el apoyo y
supervisión del doctor Alfonso Holguín, el
doctor Jose Luis Mera, y el doctor Juan
Camilo
Castro;
pertenecientes
al
departamento de imágenes diagnósticas de
la clínica fundación Valle del Lili; el cual
proveyó de 2 estudios CT coronarios, así
como los análisis realizados por los
especialistas nombrados, sobre cada estudio.
Fig. 6 – Resultados arrojados por el módulo de diagnóstico de
apoyo
Es posible obtener una representación en 3
dimensiones de la arteria segmentada, lo
cual puede facilitar su posterior análisis, a
partir del uso del módulo de creación de
volúmenes 3d del Slicer. A continuación se
puede ver su resultado.
Fig. 7 – Representación 3d del lumen de la arteria aorta, en
donde se puede apreciar una obstrucción.
Se obtuvieron errores porcentuales de
cuantificación de la estenosis entre 20% y
50% en los estudios CT reales provistos por la
fundación, y errores entre el 5% y el 20% en
los estudios CT con datos sintéticos. Con
respecto a la etapa de segmentación sobre
los estudios CT reales, se obtuvieron errores
entre el 20% y el 45% de voxeles que fueron
segmentados de más, o quedaron excluidos,
siendo el caso máximo, la segmentación de
las arterias coronarias, la cual presento un
error del
44.7% con respecto a la
segmentación de referencia realizada por el
especialista. Con respecto a los estudios CT
sintéticos, el error de segmentación fue
menor al 10%, lo cual permitió que la
aplicación arrojara una cuantificación más
precisa de la estenosis en esos casos.
Los resultados muestran que los errores
porcentuales de cuantificación por parte de
la solución ACARDI vs el análisis de los
especialistas, fueron mayores cuando la
diferencia entre el volumen segmentado
resultante de aplicar la 2 etapa del algoritmo
con respecto al volumen de referencia
tomado del análisis tradicional de los
estudios CT, era más grande. Esto puede
verse en los resultados obtenidos por
ACARDI al ser aplicada para cuantificar la
estenosis en una arteria coronaria; la razón
del error de segmentación es explicada en
este mismo documento, en la sección donde
se define la etapa de segmentación. De igual
manera, las secciones con estenosis fueron
particularmente difíciles de segmentar, dada
la gran variación de intensidades que se
presentan en ellas, gracias a la presencia de
calcificaciones. Es posible reducir los errores
del algoritmo, mediante mejoras que se
proponen en la sección de conclusiones de
este artículo.
Conclusiones
Se presenta en este documento, una técnica
de cuantificación de estenosis para estudios
CT. Esta técnica esta basada en las
publicaciones del grupo IMAGINE, y el grupo
de investigación biomédica de la universidad
de los andes, encabezados por Marcela
Hernández. Nuestros esfuerzos estuvieron
enfocados, en desarrollar una técnica de
cuantificación que fuera clara y de igual
manera sirviera como base para otras
personas del área de tecnologías de la
información.
A nuestro conocimiento, este es una de las
pocas aproximaciones al diagnóstico
automático de anomalías cardiacas; sin
embargo, la solución planteada esta pensada
para que sea mejorada con el menor
esfuerzo posible. Los módulos que fueron
desarrollados como parte de esta solución,
se encuentran escritos, pensando en la
legibilidad de su código, en lenguaje Python,
mediante el cual es posible acceder a los
otros módulos funcionales de la plataforma
Slicer 3d, así como a las librerías vtk, itk,
numpy; entre otras, las cuales forman el
núcleo de la plataforma como tal. De igual
manera, la plataforma ofrece una capa de
compatibilidad entre todos los módulos de la
aplicación de manera que puede accederse a
los módulos desarrollados como parte de
esta solución, e integrarlos en soluciones
para otras posibles áreas de la medicina. La
solución presentada, posee 2 dificultades. En
primer lugar, la falta de precisión de los
algoritmos de segmentación disponibles
tanto en la plataforma Slicer, como en otras
fuentes de uso investigativo; lo cual
introduce
un
error
directamente
proporcional al error porcentual del módulo
de segmentación utilizado. En segundo lugar,
la necesidad de que la selección de la
estructura vascular sea lo suficientemente
precisa, introduciendo así, el riesgo de que el
algoritmo falle, dado que la selección no
representa lo suficientemente bien, la
intensidad de la estructura a segmentar.
Pensando en estas principales dificultades, se
proponen como parte de la solución, estas
oportunidades de mejora:
Primero, es posible convertir este algoritmo,
de un proceso semi-automático, a un
proceso automático, mediante el desarrollo
de un atlas computarizado del sistema
cardiovascular, el cual sea compatible con el
módulo EMSegmenter plataforma Slicer 3d;
sin embargo, el desarrollo de atlas se
encuentra, por el momento, abierto
únicamente para los desarrolladores del core
del Slicer 3d y el na-mic kit; no obstante, se
abrirá en un futuro cercano. De igual
manera, el algoritmo puede ser extendido,
para que tenga en cuenta los puntos de
bifurcación, de manera que pueda ser
extendido para que pueda ser aplicado a las
arterias coronarias, así como al punto de
bifurcación de la carótida. Otra de las
posibles mejoras que se identificaron, fue la
del desarrollo de un módulo de
segmentación, el cual posea una mayor
precisión; pensando en esto, el algoritmo fue
diseñado de manera que pudieran
reemplazarse, o mejorarse, los módulos que
implementan cada uno de sus pasos, sin
afectar a los demás, ni alterar el
funcionamiento correcto del mismo.
Si bien la plataforma Slicer 3d actualmente
no cuenta con el aval para su uso clínico, es
una muy buena base para implementar y
probar algoritmos, los cuales son productos
de proyectos de investigación que utilicen en
imágenes diagnósticas; dada la amplia
documentación, metodología de desarrollo,
comunidad desarrolladora, así como
herramientas y componentes que facilitan
las tareas anteriormente nombradas.