porosity_profile
¶
Computes the porosity profile along the given axis of an image.
import porespy as ps
import numpy as np
import matplotlib.pyplot as plt
[19:13:09] ERROR PARDISO solver not installed, run `pip install pypardiso`. Otherwise, _workspace.py:56 simulations will be slow. Apple M chips not supported.
im
¶
The porosity is computed by summing the voxels with a value of 1. This means that in a boolean image the void space is indicated by True
. If the image is multiphase (i.e. voxel values of 1, 2, …) then only the 1’s will be counted.
im = ps.generators.overlapping_spheres(shape=[50, 50, 50], r=5, porosity=0.65)
prf = ps.metrics.porosity_profile(im)
plt.plot(prf, 'b.-')
plt.plot([0, 50], [0.65, 0.65], 'r--')
plt.ylim([0, 1]);
data:image/s3,"s3://crabby-images/aec23/aec235983ece4c41aaf280bcae30506e64dd7e57" alt="../../../_images/3c5b299ef238745ee54c9fe52e08ab2d21cc6cec3c31ab9d214cafde81633f70.png"
axis
¶
The axis along which to compute the profile. The default is axis=0
.
prf0 = ps.metrics.porosity_profile(im, axis=0)
prf1 = ps.metrics.porosity_profile(im, axis=1)
prf2 = ps.metrics.porosity_profile(im, axis=2)
plt.plot(prf0, 'b.-')
plt.plot(prf1, 'g.-')
plt.plot(prf2, 'c.-')
plt.plot([0, 50], [0.65, 0.65], 'r--')
plt.ylim([0, 1]);
data:image/s3,"s3://crabby-images/4fbd3/4fbd30175afe7789b9a8cd0c38c4784ae76d459b" alt="../../../_images/43f79471314dedde756bec7f99439e6d58dfd7fae9f7add70ea3dc808bfddd8e.png"