* Change to unzip * Download kcl-samples as zip to public dir * Fix fetch:samples, e2e electron still not working * Change error message to be clearer * Refactor so that input and output directories of sim tests can be different * Add kcl samples test implementation * Update output since adding kcl_samples tests * Update kcl-samples branch * Fix git-ignore pattern to only apply to the root * Fix yarn install and yarn fetch:samples to work the first time * Remove unneeded exists check * Change to use kcl-samples in public directory * Add kcl-samples * Update output since updating kcl-samples * Update output files * Change to not fetch samples during yarn install * Update output after merge * Ignore kcl-samples in codespell * WIP: Don't run e2e if only kcl-samples changed * Conditionally run cargo tests * Fix to round floating point values in program memory arrays * Update output since merge and rounding numbers in memory * Fix memory redaction for floating point to find more values * Fix float redaction pattern * Update output since rounding floating point numbers * Add center to floating point pattern * Fix trigger to use picomatch syntax * Update output since rounding center * Remove kcl-samples github workflows * Enable Rust backtrace * Update output after re-running * Update output after changing order of post-extrude commands * Fix to have deterministic order of commands * Update output after reverting ordering changes * Update kcl-samples * Update output after updating samples * Fix error messages to show the names of all samples that failed * Change cargo test command to match current one * Update kcl-samples * Update output since updating kcl-samples * Add generate manifest workflow and yarn script * Fix error check to actually work * Change util function to be what we actually need * Move new files after merge * Fix paths since directory move * Add dependabot updates for kcl-samples * Add GitHub workflow to make PR to kcl-samples repo * Add GitHub workflow to check kcl-samples header comments * Fix worfklow to change to the right directory * Add auto-commit simulation test output changes * Add permissions to workflows * Fix to run git commit step * Install just if needed * Fix directory of justfile * Add installation of cargo-insta * Fix to use underscore * Fix to allow just command failure * Change to always install CLI tools and cache them * Trying to fix overwrite failing * Combine commands * Change reviewer * Change to PR targeting the next branch * Change git commands to not do unnecessary fetch * Comment out trigger for creating a PR * Update kcl-samples from next branch * Update outputs after kcl-samples change * Fix to use bash pipefail * Add rust backtrace * Print full env from sim tests * Change command to use long option name * Fix to use ci profile even when calling through just * Add INSTA_UPDATE=always * Fix git push by using an app token on checkout * Add comments * Fix to use bash options * Change to echo when no changes are found * Fix so that kcl-samples updates don't trigger full run * Fix paths to reflect new crate location * Fix path detection * Fix e2e job to ignore kcl_samples simulation test output * Fix the fetch logic for the KCL samples after vendoring (#5661) Fixes the last 2 E2E tests for #5460. --------- Co-authored-by: Pierre Jacquier <pierre@zoo.dev> Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> Co-authored-by: Frank Noirot <frank@zoo.dev>
113 lines
3.0 KiB
Plaintext
113 lines
3.0 KiB
Plaintext
// Spur Gear
|
|
// A rotating machine part having cut teeth or, in the case of a cogwheel, inserted teeth (called cogs), which mesh with another toothed part to transmit torque. Geared devices can change the speed, torque, and direction of a power source. The two elements that define a gear are its circular shape and the teeth that are integrated into its outer edge, which are designed to fit into the teeth of another gear.
|
|
|
|
// Set Units
|
|
@settings(defaultLengthUnit = in)
|
|
|
|
// Define constants
|
|
nTeeth = 21
|
|
module = 0.5
|
|
pitchDiameter = module * nTeeth
|
|
pressureAngle = 20
|
|
addendum = module
|
|
deddendum = 1.25 * module
|
|
baseDiameter = pitchDiameter * cos(toRadians(pressureAngle))
|
|
tipDiameter = pitchDiameter + 2 * module
|
|
gearHeight = 3
|
|
|
|
// Interpolate points along the involute curve
|
|
cmo = 101
|
|
rs = map([0..cmo], fn (i) {
|
|
return baseDiameter / 2 + i / cmo * (tipDiameter - baseDiameter) / 2
|
|
})
|
|
|
|
// Calculate operating pressure angle
|
|
angles = map(rs, fn (r) {
|
|
return toDegrees( acos(baseDiameter / 2 / r))
|
|
})
|
|
|
|
// Calculate the involute function
|
|
invas = map(angles, fn (a) {
|
|
return tan(toRadians(a)) - toRadians(a)
|
|
})
|
|
|
|
// Map the involute curve
|
|
xs = map([0..cmo], fn (i) {
|
|
return rs[i] * cos(invas[i])
|
|
})
|
|
|
|
ys = map([0..cmo], fn (i) {
|
|
return rs[i] * sin(invas[i])
|
|
})
|
|
|
|
// Extrude the gear body
|
|
body = startSketchOn('XY')
|
|
|> circle(
|
|
center = [0, 0],
|
|
radius = baseDiameter / 2
|
|
)
|
|
|> extrude(length = gearHeight)
|
|
|
|
toothAngle = 360 / nTeeth / 1.5
|
|
|
|
// Plot the involute curve
|
|
fn leftInvolute(i, sg) {
|
|
j = 100 - i // iterate backwards
|
|
return line(sg, endAbsolute = [xs[j], ys[j]])
|
|
}
|
|
|
|
fn rightInvolute(i, sg) {
|
|
x = rs[i] * cos(toRadians(-toothAngle + toDegrees(atan(ys[i] / xs[i]))))
|
|
y = -rs[i] * sin(toRadians(-toothAngle + toDegrees(atan(ys[i] / xs[i]))))
|
|
return line(sg, endAbsolute = [x, y])
|
|
}
|
|
|
|
// Draw gear teeth
|
|
start = startSketchOn('XY')
|
|
|> startProfileAt([xs[101], ys[101]], %)
|
|
teeth = reduce([0..100], start, leftInvolute)
|
|
|> arc({
|
|
angleStart = 0,
|
|
angleEnd = toothAngle,
|
|
radius = baseDiameter / 2
|
|
}, %)
|
|
|> reduce([1..101], %, rightInvolute)
|
|
|> close()
|
|
|> extrude(length = gearHeight)
|
|
|> patternCircular3d(
|
|
axis = [0, 0, 1],
|
|
center = [0, 0, 0],
|
|
instances = nTeeth,
|
|
arcDegrees = 360,
|
|
rotateDuplicates = true
|
|
)
|
|
|
|
// Define the constants of the keyway and the bore hole
|
|
keywayWidth = 0.250
|
|
keywayDepth = keywayWidth / 2
|
|
holeDiam = 2
|
|
holeRadius = 1
|
|
startAngle = asin(keywayWidth / 2 / holeRadius)
|
|
|
|
// Sketch the keyway and center hole and extrude
|
|
keyWay = startSketchOn(body, 'END')
|
|
|> startProfileAt([
|
|
holeRadius * cos(startAngle),
|
|
holeRadius * sin(startAngle)
|
|
], %)
|
|
|> xLine(keywayDepth, %)
|
|
|> yLine(-keywayWidth, %)
|
|
|> xLine(-keywayDepth, %)
|
|
|> arc({
|
|
angleEnd = 180,
|
|
angleStart = -1 * 180 / PI * startAngle + 360,
|
|
radius = holeRadius
|
|
}, %)
|
|
|> arc({
|
|
angleEnd = 180 / PI * startAngle,
|
|
angleStart = 180,
|
|
radius = holeRadius
|
|
}, %)
|
|
|> close()
|
|
|> extrude(length = -gearHeight)
|