lattice_spheres
¶
Generates a cubic packing of spheres in a specified lattice arrangement.
import matplotlib.pyplot as plt
import porespy as ps
[19:13:30] ERROR PARDISO solver not installed, run `pip install pypardiso`. Otherwise, _workspace.py:56 simulations will be slow. Apple M chips not supported.
import inspect
b = inspect.signature(ps.generators.lattice_spheres)
print(b)
(shape: List, r: int = 5, spacing: int = None, offset: int = None, smooth: bool = True, lattice: Literal['sc', 'tri', 'fcc', 'bcc'] = 'sc')
radius
¶
Controls the size of the spheres.
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
shape = [200, 200]
r=10
im1 = ps.generators.lattice_spheres(shape=shape, r=r)
ax[0].imshow(im1, interpolation='none')
ax[0].axis(False)
ax[0].set_title(f'radius = {r}')
r= 20
im2 = ps.generators.lattice_spheres(shape=shape, r=r)
ax[1].imshow(im2, interpolation='none')
ax[1].axis(False)
ax[1].set_title(f'radius = {r}');
data:image/s3,"s3://crabby-images/5441a/5441afc0eadb410a3ef2b99147b1838ad010089c" alt="../../../_images/120e386c3e560a9d2479854f59bb9aa2c06d79c6e385b88ceeb14e1e6a2ebce4.png"
spacing
¶
The center-to-center spacing between the spheres. If this value is less than the sphere diamter then the spheres will overlap.
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
s = 35
im1 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s)
ax[0].imshow(im1, interpolation='none')
ax[0].axis(False)
ax[0].set_title(f'spacing = {s}')
s = 50
im2 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s)
ax[1].imshow(im2, interpolation='none')
ax[1].axis(False)
ax[1].set_title(f'spacing = {s}');
data:image/s3,"s3://crabby-images/61da6/61da6489fd892f4230f7d1a91f829c300fa84d7c" alt="../../../_images/e669c59ff483a3bf82d664d0b46dca847ae8d3c55a268087a695d513998f0c50.png"
offset
¶
Controls how far away from the edge the first sphere is located. The default is the sphere radius but it can be more or less depending on the desired effect:
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
o = 0
im1 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o)
ax[0].imshow(im1, interpolation='none')
ax[0].axis(False)
ax[0].set_title(f'offset = {o}')
o = 25
im2 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o)
ax[1].imshow(im2, interpolation='none')
ax[1].axis(False)
ax[1].set_title(f'offset = {o}');
data:image/s3,"s3://crabby-images/3ab60/3ab60a3f5f3873c99445e171b8dfa3ce194a52b9" alt="../../../_images/b367db6cd99049f670c4092ff71066c48a585ccd3fe67f42f2cea35e67121fb6.png"
lattice
¶
Controls the arrange of spheres. In 2D the options are simple cubic (‘sc’) and triangular (‘tri’). Note that the offset
and spacing
apply to the outer spheres when lattice='tri'
.
fig, ax = plt.subplots(1, 2, figsize=[8, 4])
L='sc'
r = 10
im1 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o, lattice=L)
ax[0].imshow(im1, interpolation='none')
ax[0].axis(False)
ax[0].set_title(f'lattice = {L}')
L='tri'
im2 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o, lattice=L)
ax[1].imshow(im2, interpolation='none')
ax[1].axis(False)
ax[1].set_title(f'lattice = {L}');
data:image/s3,"s3://crabby-images/4c555/4c555677d896e609c5f05dd672246eae7a76aee3" alt="../../../_images/f79e30174a0e7bb09acd0aea73454191122849c1bb8bb7eb2af93fd497811150.png"
In 3D the options are simple cubic (‘sc’), face centered cubic (‘fcc’), and body centered cubic (‘bcc’). It’s more difficult to visualize in 3D but PoreSpy has a basic function called “show_3D” that works if the image is small:
fig, ax = plt.subplots(1, 3, figsize=[9, 3])
r = 10
s = 25
shape = [100, 100, 100]
L = 'sc'
im1 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o, lattice=L)
ax[0].imshow(ps.visualization.show_3D(im1))
ax[0].axis(False)
ax[0].set_title(f'lattice = {L}')
L = 'fcc'
im2 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o, lattice=L)
ax[1].imshow(ps.visualization.show_3D(im2))
ax[1].axis(False)
ax[1].set_title(f'lattice = {L}');
L = 'bcc'
im3 = ps.generators.lattice_spheres(shape=shape, r=r, spacing=s, offset=o, lattice=L)
ax[2].imshow(ps.visualization.show_3D(im3))
ax[2].axis(False)
ax[2].set_title(f'lattice = {L}');
data:image/s3,"s3://crabby-images/08cfe/08cfe14e6c65d3686dd57ea77ac2978ddfb56c9d" alt="../../../_images/068812aad4f07bf63f8ca183b45658aac36636c161747ae7196274c25d1685da.png"