blobs
¶
blobs
is a simple function to generate a test image. It works by generating random noise, applying a guassian blur, renormalizing the result back to a uniform distribution, then thresholding the result to produce a binary image.
import porespy as ps
import matplotlib.pyplot as plt
import numpy as np
[19:11:56] ERROR PARDISO solver not installed, run `pip install pypardiso`. Otherwise, _workspace.py:56 simulations will be slow. Apple M chips not supported.
shape
¶
Both 2D and 3D images can be generated. Sending a scalar (shape=100
) will produce a 3D image of size 100^3
.
shape = [200, 200]
im = ps.generators.blobs(shape=shape)
fig, ax = plt.subplots(1, 1, figsize=[4, 4])
ax.imshow(im, origin='lower', interpolation='none')
ax.axis(False);
data:image/s3,"s3://crabby-images/ee907/ee907c13cac1b9f668e2ee1bcf7991b43751085a" alt="../../../_images/ed70e70e56081d734e33449929a7f227a0ac5ad095886b66a211589443a245d3.png"
porosity
¶
The fraction of the True
to False
pores can be set by specifying the porosity. The default is 0.5.
e = 0.75
im = ps.generators.blobs(shape=[500, 500], porosity=e)
fig, ax = plt.subplots(1, 1, figsize=[4, 4])
ax.imshow(im, origin='lower', interpolation='none')
ax.axis(False);
data:image/s3,"s3://crabby-images/5d91d/5d91d9da54b801bbf25c6c75cab440cb4535a96d" alt="../../../_images/5381fd2603029b5c9d9d84bbac1d76278a3b31474599ba83339bd21073d39a81.png"
Specifying porosity=None
will return a greyscale image which can then be thresholded to get a boolean image. The greyscale value are adjusted to a unifrom distribution:
im = ps.generators.blobs(shape=[500, 500], porosity=None)
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
ax[0].imshow(im, origin='lower', interpolation='none')
ax[0].axis(False)
ax[1].hist(im.flatten(), edgecolor='k');
data:image/s3,"s3://crabby-images/56e12/56e129d52670001cc0331158c0e3f0bd70fea4f5" alt="../../../_images/76eda89dc8402fcbfd064e29912ad6fbdd103957ea9446304d7780c64ba15abd.png"
im = ps.generators.blobs(shape=[500, 500], porosity=None, blobiness=1)
fig, ax = plt.subplots(1, 3, figsize=[12, 4])
ax[0].imshow(im, origin='lower', interpolation='none')
ax[0].axis(False)
ax[1].imshow(im < 0.5, origin='lower', interpolation='none')
ax[1].axis(False)
ax[2].imshow(im < 0.75, origin='lower', interpolation='none')
ax[2].axis(False);
data:image/s3,"s3://crabby-images/5c52f/5c52f90bfdf218c9ce23482a58587fb62a8f3ece" alt="../../../_images/685c6669d6efd44eb5c3a994e1080e1fa68ac9720ca9fe9f32d31b4fd48511a9.png"
blobiness
¶
The size and anisotropy of the blobs can be changed:
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
im1 = ps.generators.blobs(shape=shape, porosity=e, blobiness=1)
ax[0].imshow(im1, origin='lower', interpolation='none')
ax[0].axis(False)
im2 = ps.generators.blobs(shape=shape, porosity=e, blobiness=2)
ax[1].imshow(im2, origin='lower', interpolation='none')
ax[1].axis(False);
data:image/s3,"s3://crabby-images/196a3/196a353792622b1cf6ab5275b5262cbb9d2f9ca7" alt="../../../_images/a6a0b90b1a96d7125221f096314ae327b1b863e9d38d0cc91becc2dd95c65c71.png"
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
im1 = ps.generators.blobs(shape=shape, porosity=e, blobiness=[2, 1])
ax[0].imshow(im1, origin='lower', interpolation='none')
ax[0].axis(False)
im2 = ps.generators.blobs(shape=shape, porosity=e, blobiness=[1, 3])
ax[1].imshow(im2, origin='lower', interpolation='none')
ax[1].axis(False);
data:image/s3,"s3://crabby-images/e2cd1/e2cd144bb5af8733cec6f2124779581e05df089a" alt="../../../_images/db50b8d60a42a95745556453fb08e91b5500c7552868191d713600d20cb4c7fe.png"
Reproducing Images¶
The random is controlled by numpy’s random number generator so the same image can be produced by setting the seed:
np.random.seed(0)
im1 = ps.generators.blobs(shape=[500, 500], porosity=0.5)
np.random.seed(0)
im2 = ps.generators.blobs(shape=[500, 500], porosity=0.5)
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
ax[0].imshow(im1, origin='lower', interpolation='none')
ax[0].axis(False)
ax[1].imshow(im2, origin='lower', interpolation='none')
ax[1].axis(False);
data:image/s3,"s3://crabby-images/f6de8/f6de8baf062669305fa6ec29d5c1b8d7d1b0b855" alt="../../../_images/0988884e645acc8da5c966dc01b92d3c2f4f153ec2c242a302b35723cc1816a1.png"