147 lines
4.2 KiB
Plaintext
147 lines
4.2 KiB
Plaintext
// Exhaust Manifold
|
|
// A welded exhaust header for an inline 4-cylinder engine
|
|
|
|
// Set units
|
|
@settings(defaultLengthUnit = in, kclVersion = 1.0)
|
|
|
|
// Define parameters
|
|
primaryTubeDiameter = 1.625
|
|
wallThickness = 0.080
|
|
plateHeight = 0.125
|
|
bendRadius = 3
|
|
|
|
// Create a function to draw each primary tube with specified lengths and angles
|
|
fn primaryTube(n, angle001, length001, length002, length003) {
|
|
// Create an index for the function
|
|
pos001 = n * 2
|
|
|
|
// Define a plane for each sweep path defined by an angle
|
|
sweepPlane = {
|
|
origin = [pos001, 0.0, 0],
|
|
xAxis = [sin(-angle001), cos(-angle001), 0.0],
|
|
yAxis = [0.0, 0.0, 1.0],
|
|
zAxis = [1.0, 0.0, 0.0]
|
|
}
|
|
|
|
// Draw a path for each sweep
|
|
sweepPath = startSketchOn(sweepPlane)
|
|
|> startProfile(at = [0, plateHeight])
|
|
|> line(end = [0, length001])
|
|
|> tangentialArc(angle = -80, radius = bendRadius, tag = $arc01)
|
|
|> angledLine(angle = tangentToEnd(arc01), length = length002)
|
|
|> tangentialArc(angle = 85, radius = bendRadius, tag = $arc02)
|
|
|> angledLine(angle = tangentToEnd(arc02), length = length003)
|
|
|
|
// Create the cross section of each tube and sweep them
|
|
sweepProfile = startSketchOn(XY)
|
|
|> circle(center = [pos001, 0], radius = primaryTubeDiameter / 2)
|
|
|> subtract2d(tool = circle(center = [pos001, 0], radius = primaryTubeDiameter / 2 - wallThickness))
|
|
|> sweep(path = sweepPath)
|
|
|
|
return { }
|
|
}
|
|
|
|
// Draw a primary tube for each cylinder with specified lengths and angles
|
|
primaryTube(
|
|
n = 0,
|
|
angle001 = 0,
|
|
length001 = 3,
|
|
length002 = 6,
|
|
length003 = 5,
|
|
)
|
|
primaryTube(
|
|
n = 1,
|
|
angle001 = 1,
|
|
length001 = 3,
|
|
length002 = 6,
|
|
length003 = 5,
|
|
)
|
|
primaryTube(
|
|
n = 2,
|
|
angle001 = 24.3,
|
|
length001 = 5,
|
|
length002 = 5,
|
|
length003 = 3,
|
|
)
|
|
primaryTube(
|
|
n = 3,
|
|
angle001 = 25.2,
|
|
length001 = 5,
|
|
length002 = 5,
|
|
length003 = 3,
|
|
)
|
|
|
|
// Create the mounting flange for the header
|
|
flangeSketch = startSketchOn(XY)
|
|
|> startProfile(at = [3 + 1.3, -1.25])
|
|
|> xLine(length = -2.6, tag = $seg01)
|
|
|> tangentialArc(radius = .3, angle = -40)
|
|
|> tangentialArc(radius = .9, angle = 80)
|
|
|> tangentialArc(radius = .3, angle = -40)
|
|
|> xLine(length = -1.4, tag = $seg03)
|
|
|> yLine(length = segLen(seg01), tag = $seg04)
|
|
|> xLine(length = 3.1, tag = $seg05)
|
|
|> tangentialArc(radius = .3, angle = -40)
|
|
|> tangentialArc(radius = 1.5, angle = 80)
|
|
|> tangentialArc(radius = .3, angle = -40)
|
|
|> xLine(length = segLen(seg05), tag = $seg07)
|
|
|> yLine(endAbsolute = profileStartY(%), tag = $seg08)
|
|
|> xLine(length = -segLen(seg03), tag = $seg09)
|
|
|> tangentialArc(radius = .3, angle = -40)
|
|
|> tangentialArc(radius = .9, angle = 80)
|
|
|> tangentialArc(endAbsolute = [profileStartX(%), profileStartY(%)])
|
|
|> close()
|
|
|
|
// Create openings in the flange to accommodate each tube
|
|
|> subtract2d(tool = circle(center = [0, 0], radius = primaryTubeDiameter / 2 - wallThickness))
|
|
|> subtract2d(tool = circle(center = [2, 0], radius = primaryTubeDiameter / 2 - wallThickness))
|
|
|> subtract2d(tool = circle(center = [4, 0], radius = primaryTubeDiameter / 2 - wallThickness))
|
|
|> subtract2d(tool = circle(center = [6, 0], radius = primaryTubeDiameter / 2 - wallThickness))
|
|
|
|
// Add mounting holes to the flange
|
|
|> subtract2d(tool = circle(
|
|
center = [
|
|
-primaryTubeDiameter * .6,
|
|
-primaryTubeDiameter * .6
|
|
],
|
|
radius = 0.25 / 2,
|
|
))
|
|
|> subtract2d(tool = circle(
|
|
center = [
|
|
primaryTubeDiameter * .6,
|
|
primaryTubeDiameter * .6
|
|
],
|
|
radius = 0.25 / 2,
|
|
))
|
|
|> subtract2d(tool = circle(
|
|
center = [
|
|
3 * 2 - (primaryTubeDiameter * .6),
|
|
primaryTubeDiameter * .6
|
|
],
|
|
radius = 0.25 / 2,
|
|
))
|
|
|> subtract2d(tool = circle(
|
|
center = [
|
|
3 * 2 + primaryTubeDiameter * .6,
|
|
-primaryTubeDiameter * .6
|
|
],
|
|
radius = 0.25 / 2,
|
|
))
|
|
|
|
// Extrude the flange and fillet the edges
|
|
|> extrude(length = plateHeight)
|
|
|> fillet(
|
|
radius = 1.5,
|
|
tags = [
|
|
getNextAdjacentEdge(seg04),
|
|
getNextAdjacentEdge(seg07)
|
|
],
|
|
)
|
|
|> fillet(
|
|
radius = .25,
|
|
tags = [
|
|
getNextAdjacentEdge(seg03),
|
|
getNextAdjacentEdge(seg08)
|
|
],
|
|
)
|