Analyze an image stack
[1]:
import astro3d
from astro3d import image_stack
Read the image stack
We again need to set the printer-specific settings and the directory of the slides:
[2]:
stack = image_stack.IStack(
astro3d.get_output('LocalBoxnoweb'),
dpi_x=600, dpi_y=300, dz=27e-4,
)
Print out statistics
[3]:
stack.show_colors()
getting colors from 10 sample images ... Done!
[3]:
(<Figure size 400x100 with 1 Axes>, <Axes:>)
data:image/s3,"s3://crabby-images/63df7/63df7505c6fbc5c2ad95024fc2c02694ee901a28" alt="../../_images/3Dprinting_5_localbox_1_link_5_2.png"
Now we assign the transparent color index
[4]:
stack.empty_indices = [2]
[5]:
stack.show_info()
There are 4 colors in this image:
- [0, 0, 0]
- [0, 0, 255]
- [128, 128, 128] (transp.)
- [255, 0, 0]
858 files
dimension = 10.16 x 10.16 x 2.32 cm
filling fraction: 0.25%
nr of fully transparent columns: 0.05%
most opaque pixel has 45 filled pixels (=5.24% of all layers are filled)
mean counts in non-transparent columns: 3.3, 2.5, 8.6e+02, 1.6
Plots
Show the distribution of materials
[6]:
f, ax = stack.show_counts()
data:image/s3,"s3://crabby-images/d3797/d379780bf54aa30a0759858fed2bdf9c75d46436" alt="../../_images/3Dprinting_5_localbox_1_link_11_0.png"
Show a histogram of the columns that are not fully transparent
[7]:
f, ax = stack.show_histogram()
data:image/s3,"s3://crabby-images/e72c0/e72c03e6193280e3e799fc596368076f15680f11" alt="../../_images/3Dprinting_5_localbox_1_link_13_0.png"
Show fully transparent pixels and the density distribution.
[8]:
f, ax = stack.show_transparency_estimate()
data:image/s3,"s3://crabby-images/19adf/19adfe47500b030964f9d343af329cd705bea236" alt="../../_images/3Dprinting_5_localbox_1_link_15_0.png"
Top view
[9]:
bg = 255
[10]:
stack.show_colors()
[10]:
(<Figure size 400x100 with 1 Axes>, <Axes:>)
data:image/s3,"s3://crabby-images/2cbdb/2cbdbc3774e741c4aefb9464b1369de23bf62d13" alt="../../_images/3Dprinting_5_localbox_1_link_18_1.png"
[11]:
stack.replace_color(1, 255 * image_stack.VeroC_sRGB)
[12]:
stack.replace_color(3, 255 * image_stack.VeroM_sRGB)
[13]:
stack.show_colors()
[13]:
(<Figure size 400x100 with 1 Axes>, <Axes:>)
data:image/s3,"s3://crabby-images/b8fb9/b8fb9ecd09f70872f41ad8e4c6f7c85d7fdfee66" alt="../../_images/3Dprinting_5_localbox_1_link_21_1.png"
[14]:
f, ax = stack.show_top_view(bg=bg)
data:image/s3,"s3://crabby-images/97779/97779c3072f8828f6dc0b7a7430a9c2e7da7a180" alt="../../_images/3Dprinting_5_localbox_1_link_22_0.png"
3 Sides
[15]:
#%%time
# this might take long
# f, ax = stack.three_views(bg=bg)