props_to_image
ΒΆ
Values from the regionprops_3D
function can be mapped back onto the original image.
import porespy as ps
import numpy as np
import matplotlib.pyplot as plt
import scipy.ndimage as spim
[19:13:21] ERROR PARDISO solver not installed, run `pip install pypardiso`. Otherwise, _workspace.py:56 simulations will be slow. Apple M chips not supported.
np.random.seed(7)
im = ~ps.generators.overlapping_spheres([100, 100], r=10, porosity=0.6)
plt.imshow(im, origin='lower', interpolation='none');
data:image/s3,"s3://crabby-images/b242c/b242c544eb3804ae3697b93a37afa97e8f9e02b5" alt="../../../_images/cd3e7c3643a02125a18b40c81680186bc795d7fc5e4411d3dcffa48d73acc969.png"
regions = spim.label(im)[0]
props = ps.metrics.regionprops_3D(regions)
plt.imshow(regions, origin='lower', interpolation='none');
data:image/s3,"s3://crabby-images/fbe87/fbe8718ce151728784a09a43e8f22198c21a0f13" alt="../../../_images/9a898101ec946e0bfd368e2dee5e2e9f8e7ca2f1d8a05be070cb61e4d0d548a2.png"
im1 = ps.metrics.prop_to_image(props, im.shape, 'convex_volume')
im2 = ps.metrics.prop_to_image(props, im.shape, 'sphericity')
im3 = ps.metrics.prop_to_image(props, im.shape, 'orientation')
fig, ax = plt.subplots(1, 3, figsize=[15, 5])
ax[0].imshow(im1, origin='lower', interpolation='none')
ax[1].imshow(im2, origin='lower', interpolation='none')
ax[2].imshow(im3, origin='lower', interpolation='none');
data:image/s3,"s3://crabby-images/0a4a6/0a4a6c470b507649c412cdfc3437853af817f917" alt="../../../_images/228e916dc9f683b5e278836de33798773a90cb76cff1baa003f037b496119288.png"