Richardson-Lucy-Entfaltung auf OpenCL-kompatiblen GPUs#

Richardson-Lucy-Entfaltung ist ein gängiger und doch grundlegender Algorithmus zur Bildentfaltung in der Mikroskopie. In diesem Notebook werden wir eine GPU-beschleunigte Version davon verwenden, die im napari-Plugin RedLionFish implementiert ist. Daher können Sie denselben Algorithmus auch über die grafische Benutzeroberfläche in napari verwenden.

from skimage.io import imread
from pyclesperanto_prototype import imshow
import RedLionfishDeconv as rl
import matplotlib.pyplot as plt

Wir werden ein Bild laden, das die Fluoreszenzintensität entlang von Linien zeigt. Dieses 3D-Bild wurde mit einem Konfokalmikroskop aufgenommen.

image = imread('../../data/DeconvolutionSampleVerticalGrid1AU-crop.tif')
image.shape
(21, 150, 150)
imshow(image, colorbar=True)
../_images/dcb7253afa0708bc1466100c38ca84c604606d441c48a94631fc9f7b7d6212ac.png

Das folgende PSF-Bild wurde aus Bildern extrahiert, die mit demselben Mikroskop aufgenommen wurden, unter Verwendung des zuvor erklärten Verfahrens.

psf = imread('../../data/psf.tif')

imshow(psf, colorbar=True)
../_images/a9ef73e14ebfd8a086446101509d41b76b27e3fc686670b9e4d076e15758902b.png

Wir können nun das Bild mit dem Richardson-Lucy-Entfaltungsalgorithmus von RedLionFish entfalten. Wir sollten angeben, dass der Algorithmus auf der gpu ausgeführt werden soll.

iterations = 50

deconvolved = rl.doRLDeconvolutionFromNpArrays(image, 
                                               psf, 
                                               niter=iterations, 
                                               method='gpu', 
                                               resAsUint8=False )
imshow(deconvolved)
ERROR:root:Failed to setup Reikna with OpenCL.
ERROR:root:No module named 'reikna'
../_images/6196b1264f6a72457f0b4c418c842f03d15c187f3d5a0e3b47dcb093596f0c33.png

Um genauer zu visualisieren, wie sich das Originalbild und die entfaltete Version unterscheiden, können wir die Intensität entlang einer Linie von links nach rechts plotten. Wir erhalten diese Zahlen aus einer Maximumintensitätsprojektion entlang der Z-Achse.

max_intensity_image = image.max(axis=0)
max_intensity_image.shape
(150, 150)
max_intensity_deconvolved = deconvolved.max(axis=0)
max_intensity_deconvolved.shape
(150, 150)
plt.plot(max_intensity_image[80])
plt.plot(max_intensity_deconvolved[80])
plt.show()
../_images/784be31367ebbb4a870b07ac894f215ce8a9376033cce6227646848b6b76325a.png

Wie Sie sehen können, hat sich der Intensitätsbereich durch die Entfaltung verändert. Dies hängt vom Algorithmus und der Implementierung ab. Wenn Sie eine Entfaltung anwenden, sollten Sie überprüfen, ob die Gesamtintensität im Originalbild und im entfalteten Bild im gleichen Bereich liegt:

image.min(), image.max()
(1, 8)
deconvolved.min(), deconvolved.max()
(0.0, 28.122286)