Sierpinski pentagon: Difference between revisions

m
Output is vertically centred, use polygon instead of path
(Added Rust solution)
m (Output is vertically centred, use polygon instead of path)
Line 925:
Radius is Size/2 - 2 * Margin,
Side is Radius * sin(pi/5) * 2,
Height is Side * (sin(pi/5) + sin(2 * pi/5)),
X is Size/2,
Y is 3(Size *- MarginHeight)/2,
Scale_factor is 1/(2 + cos(2 * pi/5) * 2),
sierpinski_pentagon(Stream, X, Y, Scale_factor, Side, Order),
Line 934 ⟶ 935:
sierpinski_pentagon(Stream, X, Y, _, Side, 1):-
!,
write(Stream, "<pathpolygon stroke-width='1' stroke='black' fill='blue' dpoints='"),
format(Stream, 'M ~g,~g ', [X, Y]),
Angle is 6 * pi/5,
write_pentagon_points(Stream, Side, Angle, X, Y, 5),
write(Stream, "z'/>\n").
sierpinski_pentagon(Stream, X, Y, Scale_factor, Side, N):-
Side1 is Side * Scale_factor,
Line 951 ⟶ 952:
Y1 is Y - sin(Angle) * Side,
Angle1 is Angle + 2 * pi/5,
format(Stream, 'L ~g,~g ', [X1, Y1]),
write_pentagon_points(Stream, Side, Angle1, X1, Y1, N1).
 
1,777

edits