-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlabyrinth_casing.py
More file actions
136 lines (107 loc) · 4.93 KB
/
labyrinth_casing.py
File metadata and controls
136 lines (107 loc) · 4.93 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
from typing import Literal
from solid import *
from solid.utils import *
import numpy as np
from labyrinth_cube import LabyrinthCube
from labyrinth_level import LabyrinthLevel
class LabyrinthCasing:
def __init__(self, lcube: LabyrinthCube, casingThickness: float, tolerance: float):
self.lc: LabyrinthCube = lcube
self.casingThickness: float = casingThickness
self.tolerance: float = tolerance
self.bonusHeight : float = 3
@property
def cubeOffset(self) -> np.ndarray:
cubeOffsetSize = np.ones(3) * (self.casingThickness + self.tolerance)
return cubeOffsetSize
@property
def labyrinthCubeSize(self) -> np.ndarray:
cubeSizeXY = self.lc.levels[0].levelSizeXY
cubeSizeZ = self.lc.spacing * len(self.lc.levels)
cubeSize = np.array([cubeSizeXY, cubeSizeXY, cubeSizeZ])
return cubeSize
@property
def casingSize(self) -> np.ndarray:
return [*2 * self.cubeOffset[:2], self.cubeOffset[2]] + self.labyrinthCubeSize
@property
def casingCenter(self) -> np.ndarray:
return self.casingSize / 2
def getRoomCenter(self, i, j, k) -> np.ndarray:
return self.lc.getRoomCenter(i, j, k) + self.cubeOffset
def getCasingSolid(self) -> OpenSCADObject:
assert self.casingThickness > 0, "Casing Thickness needs to be positive"
# assuming all levels have same measurements as level 0
holeOffsetSize = np.ones(3) * (self.casingThickness)
outCube = cube(self.casingSize + [0,0,self.bonusHeight], center=False)
holeCube = cube(
self.labyrinthCubeSize + np.ones(3) * 2 * self.tolerance + [0,0,self.bonusHeight], center=False
)
solidCasing = difference()([outCube, translate(holeOffsetSize)(holeCube)])
return solidCasing
def getReducedCasingSolid(self) -> OpenSCADObject:
simpleCasing = self.getCasingSolid()
casingSizeXY = self.casingSize[0]
punchoutVertXY = (1/8) * casingSizeXY
punchoutRotXY = (1/2) * casingSizeXY
wallPunchoutVertX = translate(self.casingCenter+[0,0,self.casingThickness+self.bonusHeight/2])(
cube([punchoutVertXY, casingSizeXY, self.casingSize[2]+self.bonusHeight], center=True)
)
wallPunchoutVertY = translate(self.casingCenter+[0,0,self.casingThickness+self.bonusHeight/2])(
cube([casingSizeXY, punchoutVertXY, self.casingSize[2]+self.bonusHeight], center=True)
)
wallPunchoutRotX = translate(self.casingCenter+[0,0,self.casingThickness])(
rotate([0,45,0])(
cube([punchoutRotXY, casingSizeXY, punchoutRotXY], center=True)
)
)
wallPunchoutRotY = translate(self.casingCenter+[0,0,self.casingThickness])(
rotate([45,0,0])(
cube([casingSizeXY, punchoutRotXY, punchoutRotXY], center=True)
)
)
reducedCasing = difference()(
simpleCasing,
wallPunchoutVertX,
wallPunchoutVertY,
wallPunchoutRotX,
wallPunchoutRotY
)
return reducedCasing
def getWindowSolid(
self, i: int, j: int, k: int, dir: Literal["xp, xn, yp, yn"]
) -> OpenSCADObject:
pathSize = self.lc.levels[0].pathThickness
center = self.getRoomCenter(i, j, k)
if dir == "xn":
outside = np.array([0, center[1], center[2]])
distToOutside = np.linalg.norm(outside - center)
size = [distToOutside, pathSize / 3, pathSize / 3]
elif dir == "xp":
outside = np.array([self.casingSize[0], center[1], center[2]])
distToOutside = np.linalg.norm(outside - center)
size = [distToOutside, pathSize / 3, pathSize / 3]
elif dir == "yn":
outside = np.array([center[0], 0, center[2]])
distToOutside = np.linalg.norm(outside - center)
size = [pathSize / 3, distToOutside, pathSize / 3]
elif dir == "yp":
outside = np.array([center[0], self.casingSize[1], center[2]])
distToOutside = np.linalg.norm(outside - center)
size = [pathSize / 3, distToOutside, pathSize / 3]
wcube = translate((center + outside) / 2)(cube(size, center=True))
return wcube
def getCubeInCasingSolid(self) -> OpenSCADObject:
casing = self.getReducedCasingSolid()
lcube = translate(np.ones(3) * (self.casingThickness + self.tolerance))(
self.lc.getCubeSolid()
)
return casing + lcube
def createScadFile(self, name):
scad_render_to_file(self.getReducedCasingSolid(), f"{name}.scad")
if __name__ == "__main__":
ll = LabyrinthLevel(
3, 13, np.ones((4, 4, 3), dtype=bool), np.ones((4, 4), dtype=bool)
)
lc = LabyrinthCube([ll, ll, ll, ll], 17)
lcc = LabyrinthCasing(lc, 3, 0.5)
scad_render_to_file(lcc.getReducedCasingSolid(), "auto3dlab.scad")