mirror of
git://projects.qi-hardware.com/ben-counterweight.git
synced 2025-01-28 16:41:05 +02:00
Improved the mold for better yield.
- cw.py: added another air escape for remaining corner with occasional air pockets - cw.py: inlets terminate in a cylinder, to allow for piece tolerances (the real piece I use is in fact a bit smaller than I tell HeeksCAD, so that HeeksCAD flattens the entire surface) - cw.py: commented the parameters for inlets and escapes
This commit is contained in:
parent
16b7cc9562
commit
e910ea067e
29
cw.py
29
cw.py
@ -28,10 +28,26 @@ y_axis = 16.0
|
|||||||
off_x = -15+18
|
off_x = -15+18
|
||||||
off_y = -46+5
|
off_y = -46+5
|
||||||
|
|
||||||
|
#
|
||||||
|
# Radius for lead inlets and air escapes
|
||||||
|
#
|
||||||
channel_radius = 1 # mm
|
channel_radius = 1 # mm
|
||||||
inlet_radius = 7
|
|
||||||
|
#
|
||||||
|
# Inlets have a large opening on the outside: first a cylinder of radius
|
||||||
|
# "inlet_radius" and depth "inlet_streight", then a cone to the channel radius.
|
||||||
|
# The cone's height is variable. At the end, there is a channel of length
|
||||||
|
# "shaft". The goals are to have a wide opening to make it easy to pour the
|
||||||
|
# metal, and to create a buffer for thermal energy.
|
||||||
|
#
|
||||||
|
inlet_radius = 6.5
|
||||||
|
inlet_straight = 3
|
||||||
shaft = 3
|
shaft = 3
|
||||||
ymax_piece = 50
|
|
||||||
|
#
|
||||||
|
# This maximum y dimension of the piece from which the mold is machined
|
||||||
|
#
|
||||||
|
ymax_piece = 45
|
||||||
|
|
||||||
total_mass = 0
|
total_mass = 0
|
||||||
total_torque = 0
|
total_torque = 0
|
||||||
@ -106,10 +122,14 @@ def channel(sk, x, y, r0, r1):
|
|||||||
else:
|
else:
|
||||||
cad.cylinder(x, y, 0, r0, shaft)
|
cad.cylinder(x, y, 0, r0, shaft)
|
||||||
cyl = cad.getlastobj()
|
cyl = cad.getlastobj()
|
||||||
cad.cone(x, y, shaft, r0, r1, ymax_piece-y-shaft)
|
cad.cone(x, y, shaft, r0, r1, ymax_piece-y-shaft-inlet_straight)
|
||||||
cone = cad.getlastobj()
|
cone = cad.getlastobj()
|
||||||
cad.fuse(cyl, cone)
|
cad.fuse(cyl, cone)
|
||||||
obj = cad.getlastobj()
|
obj = cad.getlastobj()
|
||||||
|
cad.cylinder(x, y, ymax_piece-inlet_straight-y, r1, inlet_straight)
|
||||||
|
cyl = cad.getlastobj()
|
||||||
|
cad.fuse(obj, cyl)
|
||||||
|
obj = cad.getlastobj()
|
||||||
cad.rotate(obj, x, y, 0, 1, 0, 0, -math.pi/2)
|
cad.rotate(obj, x, y, 0, 1, 0, 0, -math.pi/2)
|
||||||
cad.cut(sk, obj)
|
cad.cut(sk, obj)
|
||||||
return cad.getlastobj()
|
return cad.getlastobj()
|
||||||
@ -241,7 +261,7 @@ make_base()
|
|||||||
if __name__ != "__main__":
|
if __name__ != "__main__":
|
||||||
cad.translate(group, -15, -46, -5)
|
cad.translate(group, -15, -46, -5)
|
||||||
cad.translate(group, 18, 5, 0)
|
cad.translate(group, 18, 5, 0)
|
||||||
sk = do_rect_cad(0, 0, 0, 120, 45, 0)
|
sk = do_rect_cad(0, 0, 0, 120, ymax_piece, 0)
|
||||||
cad.extrude(sk, -10)
|
cad.extrude(sk, -10)
|
||||||
sk = cad.getlastobj()
|
sk = cad.getlastobj()
|
||||||
cad.cut(sk, group)
|
cad.cut(sk, group)
|
||||||
@ -252,6 +272,7 @@ if __name__ != "__main__":
|
|||||||
sk = escape(sk, 100-channel_radius, 69)
|
sk = escape(sk, 100-channel_radius, 69)
|
||||||
sk = escape(sk, 60.5-channel_radius, 65)
|
sk = escape(sk, 60.5-channel_radius, 65)
|
||||||
sk = escape(sk, 62.5+channel_radius, 65)
|
sk = escape(sk, 62.5+channel_radius, 65)
|
||||||
|
sk = escape(sk, 82.5-channel_radius, 65)
|
||||||
sk = inlet(sk, 50, 65)
|
sk = inlet(sk, 50, 65)
|
||||||
|
|
||||||
print >>sys.stderr, "total mass =", total_mass, "g"
|
print >>sys.stderr, "total mass =", total_mass, "g"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user