1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-19 15:17:10 +01:00
dotSCAD/examples/rose.scad

57 lines
1.4 KiB
OpenSCAD
Raw Normal View History

2020-05-23 16:15:02 +08:00
use <sweep.scad>;
2020-01-27 21:35:29 +08:00
use <util/reverse.scad>;
2019-10-31 21:46:07 +08:00
thickness = 0.05;
theta_from = PI * 1.75;
theta_to = PI * 15;
theta_step = 0.05;
rf_to = 1;
rf_step = 0.025;
color("red") rose();
2019-10-31 15:46:51 +08:00
module rose() {
function phi(theta) =
(PI / 2) * exp(-theta / (8 * PI));
function wave(theta) =
1 - 0.5 * pow(1.25 * pow(1- ((3.6 * theta) % (2 * PI)) / PI - (theta > 0 ? 0 : 2), 2) - 0.25, 2);
function g(rf, theta) =
let(angle = phi(theta) * 57.2958)
1.95653 * pow(rf, 2) * pow(1.27689 * rf - 1, 2) * sin(angle);
function r(rf,theta) =
let(angle = phi(theta) * 180 / PI)
wave(theta) * (rf * sin(angle) + g(rf, theta) * cos(angle));
2019-11-01 06:52:08 +08:00
sf = 1 + thickness;
2019-10-31 15:46:51 +08:00
sections = [
for(theta = [theta_from:theta_step:theta_to])
let(
path = [
for(rf = [0:rf_step:rf_to])
let(
r = r(rf,theta),
angle = theta * 57.2958,
angle2 = phi(theta)* 57.2958,
x = r*sin(angle),
y = r*cos(angle),
z = wave(theta)*(rf*cos(angle2)-g(rf,theta)*sin(angle2))
)
[x, y, z]
]
)
concat(
[
for(p = path)
2019-11-01 06:52:08 +08:00
[p[0] * sf, p[1] * sf, p[2]] - [0, 0, thickness]
2019-10-31 15:46:51 +08:00
],
reverse(path)
)
];
2020-05-23 16:15:02 +08:00
sweep(sections);
2019-10-31 21:46:07 +08:00
}