Deskriptive Statistik von [vielen] Linien in einem Bild#

Bei der Untersuchung der Intensität entlang vieler Linien in einem Bild kann dies parallel auf einer GPU durchgeführt werden. Dieses Notebook demonstriert dies anhand von nur zwei Linien zu Illustrationszwecken. Es kann davon ausgegangen werden, dass das parallele Auslesen von Hunderten oder Tausenden von Linien auf GPUs leistungsmäßig sinnvoll ist.

import pyclesperanto_prototype as cle
from skimage.data import cells3d
import numpy as np

Um einen möglichen Anwendungsfall zu demonstrieren, betrachten wir ein Bild von Zellen, die einen Membranmarker exprimieren, genauer.

membranes = cells3d()[30, 0, 110:150, 110:150]
cle.imshow(membranes)
../_images/52c9a11c9c46b1c1a0d820f6637017c43a43856343674aaced7fdc51494a27df.png

Wir definieren Koordinaten von vier Punkten, die zu zwei Linien verbunden werden. Die Verbindung wird mit einer Touch-Matrix hergestellt, die es ermöglicht, n Punkte mit n Punkten zu verbinden.

coords = np.asarray([
    [0, 17],  # line 1 start (x, y)
    [10, 24], # line 1 end
    [20, 21], # line 2
    [35, 21]
]).T
connection_matrix = cle.symmetric_maximum_matrix(np.asarray([
    [0, 0, 0, 0, 0],
    [0, 0, 1, 0, 0], # this connects the two points of line 1
    [0, 0, 0, 0, 0],
    [0, 0, 0, 0, 1], # this connects the two points of line 2
    [0, 0, 0, 0, 0]
]))
connection_matrix
cle.array([[0. 0. 0. 0. 0.]
 [0. 0. 1. 0. 0.]
 [0. 1. 0. 0. 0.]
 [0. 0. 0. 0. 1.]
 [0. 0. 0. 1. 0.]], dtype=float32)

Zuerst visualisieren wir diese Linien über dem Membranbild.

mesh = cle.create_like(membranes)
mesh = cle.touch_matrix_to_mesh(coords, connection_matrix, mesh)

cle.imshow(membranes, continue_drawing=True)
cle.imshow(mesh, alpha=0.5, colormap='jet')
../_images/3685c1c3424b4e4209ce5588a4e23e4224059a141caaabbe7da49736df0224c7.png

Messung der mittleren Intensität entlang der Linien#

Als Nächstes verwenden wir die oben konfigurierte Matrix, um die durchschnittliche Intensität entlang der Linien zu messen. Wir müssen auch angeben, wie viele Proben entlang der Linien genommen werden sollen.

num_samples = 10

mean_intensity_matrix = cle.generate_mean_intensity_between_points_matrix(
                                membranes, coords, connection_matrix, num_samples=num_samples)
mean_intensity_matrix
cle.array([[   0.     0.     0.     0.     0. ]
 [   0.     0.  7317.8    0.     0. ]
 [   0.  7317.8    0.     0.     0. ]
 [   0.     0.     0.     0.  4482.6]
 [   0.     0.     0.  4482.6    0. ]], dtype=float32)

Wir können diese Messungen auch wieder als Linien visualisieren. Da wir Punkte und Verbindungen zwischen Punkten als Matrix übergeben, ist dies technisch gesehen ein Netz.

mean_intensity_mesh = cle.create_like(membranes)
mean_intensity_mesh = cle.touch_matrix_to_mesh(coords, mean_intensity_matrix, mean_intensity_mesh)
mean_intensity_mesh
cle._ image
shape(40, 40)
dtypefloat32
size6.2 kB
min0.0
max7317.8

Wir können dieses quantitative Netz auch über dem ursprünglichen Membranbild visualisieren.

cle.imshow(membranes, continue_drawing=True)
cle.imshow(mean_intensity_mesh, alpha=0.5, colormap='jet', colorbar=True)
../_images/8b4160f1966b58d16218cf65ccedc977231b3000994fbb5c41ad974aed89f476.png

Messung der Standardabweichung der Intensität entlang einer Linie#

Das gleiche Verfahren funktioniert auch für die Messung der Standardabweichung entlang der Linien.

stddev_intensity_matrix = cle.generate_standard_deviation_intensity_between_points_matrix(
                                membranes, coords, connection_matrix)
stddev_intensity_matrix
cle.array([[   0.         0.         0.         0.         0.     ]
 [   0.         0.       572.79144    0.         0.     ]
 [   0.       572.79144    0.         0.         0.     ]
 [   0.         0.         0.         0.      3758.1768 ]
 [   0.         0.         0.      3758.1772     0.     ]], dtype=float32)
stddev_intensity_mesh = cle.create_like(membranes)
stddev_intensity_mesh = cle.touch_matrix_to_mesh(coords, stddev_intensity_matrix, stddev_intensity_mesh)

cle.imshow(membranes, continue_drawing=True)
cle.imshow(stddev_intensity_mesh, alpha=0.5, colormap='jet', colorbar=True)
../_images/8966a2e5cd44bb45d27e55ad7f2b119462c6f8243f3d4cdd79b7aa5f957c4acd.png