boxcount
¶
A method for measuring the fractal dimension of an image
import matplotlib.pyplot as plt
import numpy as np
import porespy as ps
[19:12:26] ERROR PARDISO solver not installed, run `pip install pypardiso`. Otherwise, _workspace.py:56 simulations will be slow. Apple M chips not supported.
The arguments and their defaults for this function are:
import inspect
inspect.signature(ps.metrics.boxcount)
<Signature (im, bins=10)>
im = ps.generators.sierpinski_foam(dmin=5, n=5, ndim=2)
fig, ax = plt.subplots(1, 1, figsize=[6, 6])
ax.imshow(im, interpolation='none', origin='lower')
ax.axis(False);
data:image/s3,"s3://crabby-images/65e0a/65e0ae5e298a31792525c26b5f949764fafc16a3" alt="../../../_images/a777b56ba1f76ed4b1b584868eba5188e1c3cbc6e7fee94c37f59cf6bf0b2bc4.png"
im
¶
The image which is to be analzyed. Can be 2D or 3D.
b = ps.metrics.boxcount(im=im)
print(b)
――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――
Results of boxcount generated at Wed Feb 19 19:12:28 2025
――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――
size Array of size (10,)
count [6505, 4095, 1435, 552, 206, 77, 24, 9, 4, 1]
slope Array of size (10,)
――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――
The returned object is like a dataclass with each computed value stored in an attribute. The result can be printed for inspection. The results can also be plotted as follows:
fig, ax = plt.subplots(1, 2, figsize=[12, 6])
ax[0].loglog(b.size, b.count)
ax[0].set_xlabel('box length')
ax[0].set_ylabel('number of partially filled boxes')
ax[1].semilogx(b.size, b.slope)
ax[1].plot([0, 1000], [1.9, 1.9])
ax[1].set_xlabel('box length')
ax[1].set_ylabel('slope')
ax[1].set_ylim([0, 3]);
data:image/s3,"s3://crabby-images/8a890/8a890f159118a92a99d17e3fe87d222971958c66" alt="../../../_images/6a1201ca65f05a2e893ae5676ea293f74ccd12bd2f0c8c6671928ac05ed495f8.png"
bins
¶
The box sizes to use. The default is 10. If an integer is given it computes the range of box sizes. If an array is given, these are used directly
b = ps.metrics.boxcount(im=im, bins=20)
fig, ax = plt.subplots(1, 2, figsize=[12, 6])
ax[0].loglog(b.size, b.count)
ax[0].set_xlabel('box length')
ax[0].set_ylabel('number of partially filled boxes')
ax[1].semilogx(b.size, b.slope)
ax[1].plot([0, 1000], [1.9, 1.9])
ax[1].set_xlabel('box length')
ax[1].set_ylabel('slope')
ax[1].set_ylim([0, 3]);
data:image/s3,"s3://crabby-images/a2962/a2962a337cf435c67c70ffc5c1c8c30d63c78ca1" alt="../../../_images/dc77df3f5afc8276beda3d6368dc71a0fee8b52813ea9584dea8050322792899.png"