7.31 Example — Solid Objects STL Array
PDF section 7.31. Source script: KrakenOS/Examples/Examp_Solid_Object_STL_ARRAY.py.
Loads an STL mesh and instantiates an array of copies through the
Solid_3d_stl surface attribute. Useful for assemblies of identical
mechanical parts (mount features, baffles) or arrayed optics.
Figure 38. STL-defined solid objects arrayed in the scene.
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""Examp Solid Objects STL ARRAY"""
"""
Using stl or vtk solid elements in non-sequential mode is not accurate,
it is better to use this shape in applications like lighting,
note that the spot diagram here should be a dot
"""
import matplotlib.pyplot as plt
import numpy as np
import pyvista as pv
from importlib import metadata
required = {'KrakenOS'}
installed = {dist.metadata["Name"] for dist in metadata.distributions() if dist.metadata.get("Name")}
missing = {pkg for pkg in required if pkg not in installed}
if missing:
print("No instalado")
import sys
sys.path.append("../..")
import KrakenOS as Kos
# ______________________________________#
P_Obj = Kos.surf()
P_Obj.Thickness = 7000.0
P_Obj.Glass = "AIR"
P_Obj.Diameter = 5000
P_Obj.Drawing = 1
# ______________________________________#
n = 11
Lx = 100.0
Ly = 100.0
Lz = 0.1
focal = 5000.0
element0 = pv.Cube(center=(0.0, 0.0, 0.0), x_length=0.1, y_length=0.1, z_length=0.1, bounds=None)
for A in range(-n, n + 1):
for B in range(-n, n + 1):
element1 = pv.Cube(center=( 0.0, 0.0, 0.0), x_length=Lx, y_length=Ly, z_length=Lz,)
v = [A * Lx , B * Ly, 0]
Ty = 0.5 * np.rad2deg(np.arctan2(A * Lx, focal))
Tx = -0.5 * np.rad2deg(np.arctan2(B * Ly, focal))
try:
element1.rotate_x(Tx, inplace = True)
element1.rotate_y(Ty, inplace = True)
element1.translate(v, inplace = True)
except:
element1.rotate_x(Tx)
element1.rotate_y(Ty)
element1.translate(v)
element0 = element0 + element1
# element0.save("salida.stl")
# direc = r"salida.stl"
# ______________________________________#
objeto = Kos.surf()
objeto.Diameter = 118.0 * 2.0
objeto.Solid_3d_stl = element0
objeto.Thickness = -5000
objeto.Glass = "MIRROR"
objeto.TiltX = 0
objeto.TiltY = 0
objeto.DespX = 0
objeto.DespY = 0
objeto.AxisMove = 0
# ______________________________________#
P_Ima = Kos.surf()
P_Ima.Rc = 0
P_Ima.Thickness = -1.0
P_Ima.Glass = "AIR"
P_Ima.Diameter = 200.0
P_Ima.Drawing = 1
P_Ima.Name = "Plano imagen"
# ______________________________________#
A = [P_Obj, objeto, P_Ima]
configur = Kos.Setup()
# ______________________________________#
MirrorArray = Kos.system(A, configur)
Rays = Kos.raykeeper(MirrorArray)
# ______________________________________#
W = 0.633
for A in range(-n, n + 1):
for B in range(-n, n + 1):
x_0 = A * Lx
y_0 = B * Ly
r = np.sqrt((x_0 * x_0) + (y_0 * y_0))
tet = 0.0
pSource_0 = [x_0, y_0, 0.0]
dCos = [0.0, np.sin(np.deg2rad(tet)), np.cos(np.deg2rad(tet))]
MirrorArray.NsTrace(pSource_0, dCos, W)
if np.shape(MirrorArray.NAME)[0] != 0:
if MirrorArray.NAME[-1] == "Plano imagen":
plt.plot(MirrorArray.Hit_x[-1], MirrorArray.Hit_y[-1], '.', c="g")
Rays.push()
# ______________________________________#
plt.axis('square')
plt.show()
Kos.display3d(MirrorArray, Rays, 0)