Transformations affines utilisant clesperanto#
Ce notebook démontre comment appliquer des transformations affines à des images 3D.
import pyclesperanto_prototype as cle
cle.select_device('TX')
<NVIDIA GeForce GTX 1650 with Max-Q Design on Platform: NVIDIA CUDA (1 refs)>
import numpy as np
import matplotlib
import matplotlib.pyplot as plt
from skimage.io import imread
# Charger les données d'exemple
np_array = imread('../../data/Haase_MRT_tfl3d1.tif')
np_array.shape
(192, 256, 256)
# le pousser vers la mémoire GPU
input_image = cle.push_zyx(np_array)
cle.imshow(input_image)
Rotation#
Pour faire pivoter une image, vous devez fournir des angles correspondant aux axes.
rotated = cle.rotate(input_image, angle_around_z_in_degrees=45)
cle.imshow(rotated)
Les images sont pivotées autour de leur centre par défaut. Vous pouvez changer cela en fournissant un paramètre supplémentaire. L’image sera alors pivotée autour de l’origine.
rotated = cle.rotate(input_image, angle_around_z_in_degrees=15, rotate_around_center=False)
cle.imshow(rotated)
Translation#
Les images peuvent être translatées en fournissant des distances de translation le long des axes :
translated = cle.translate(input_image, translate_x=50, translate_y=-50)
cle.imshow(translated)
Mise à l’échelle#
Vous pouvez mettre l’image à l’échelle en fournissant des facteurs d’échelle.
scaled = cle.scale(input_image, factor_x=0.5, factor_y=2)
cle.imshow(scaled)
Dans ce contexte, le paramètre auto_size peut être utile :
scaled_auto_size = cle.scale(input_image, factor_x=0.5, factor_y=2, auto_size=True)
cle.imshow(scaled_auto_size)
Transformation rigide#
Les transformations rigides permettent d’effectuer des translations et des rotations en une seule fois
rigid_transformed = cle.rigid_transform(input_image, translate_x=50, angle_around_z_in_degrees=45)
cle.imshow(rigid_transformed)
Transformations affines#
Pour effectuer une translation, une rotation, une mise à l’échelle et un cisaillement en une seule fois, utilisez les transformations affines.
Pour configurer une transformation affine, vous pouvez le faire en utilisant une matrice de transformation 4x4 :
transform_matrix = np.asarray([
[1, 0, 0, 50],
[0, 2, 0, 0],
[0, 0, 0.5, 0],
[0, 0, 0, 1]
])
transformed_image = cle.affine_transform(input_image, transform=transform_matrix)
cle.imshow(transformed_image)
Alternativement, vous pouvez configurer un objet de transformation et le passer :
transform = cle.AffineTransform3D()
transform.translate(50)
transform.scale(1, 2, 0.5)
transformed_image = cle.affine_transform(input_image, transform=transform)
cle.imshow(transformed_image)
Cisaillement#
Fournir l’angle de cisaillement cisaillera l’image dans le plan souhaité
Le cisaillement est calculé en utilisant l’angle de cisaillement selon l’équation suivante :
1.0/ tan(shear_angle_in_degrees * pi / 180)
#Par exemple, pour cisailler l'image sur l'axe Y le long du plan YZ en utilisant un angle de cisaillement de 30 degrés
shear_angle = 30.0
transform = cle.AffineTransform3D()
shear_transform= transform.shear_in_z_plane(angle_y_in_degrees=shear_angle)
transformed_image = cle.affine_transform(input_image, transform=shear_transform)
##afficher les images dans chaque plan
print("yz")
cle.imshow(cle.maximum_x_projection(transformed_image))
print("xz")
cle.imshow(cle.maximum_y_projection(transformed_image))
print("xy")
cle.imshow(cle.maximum_z_projection(transformed_image))
yz
xz
xy
Interpolation linéaire versus interpolation du plus proche voisin#
Découpons le nez et transformons-le en utilisant différents modes d’interpolation.
crop = input_image[50,125:150,45:70]
cle.imshow(crop)
Interpolation du plus proche voisin#
# créer une image plus grande
rescaled = cle.create(np.asarray(crop.shape) * 10)
# la remplir avec une version mise à l'échelle de l'image ;
cle.scale(crop, rescaled, factor_x=10, factor_y=10, factor_z=10, linear_interpolation=False)
cle.imshow(rescaled)
Interpolation linéaire#
# la remplir avec une version mise à l'échelle de l'image ;
cle.scale(crop, rescaled, factor_x=10, factor_y=10, factor_z=10, linear_interpolation=True)
cle.imshow(rescaled)