Superellipse: Difference between revisions

m
→‎{{header|Perl}}: a little nicer with v5.36
m (→‎{{header|Raku}}: redundant 'flat's)
m (→‎{{header|Perl}}: a little nicer with v5.36)
Line 1,062:
=={{header|Perl}}==
{{trans|Raku}}
<lang perl>myuse $a = 200v5.36;
my($a, $b, $n, @q) = (200, 200, 2.5);
my $n = 2.5;
 
# y in terms of x
sub y_from_x ($x) { int $b * abs(1 - ($x/$a) ** $n ) ** (1/$n) }
my($x) = @_;
int $b * abs(1 - ($x / $a) ** $n ) ** (1/$n)
}
 
# find point pairs for one quadrant
push @q, $_, y_from_x($_) for 0..200$a;
 
# Generate an SVG image
open $fh, '>', 'superellipse.svg';
print $fh
Line 1,085 ⟶ 1,080:
'</svg>';
 
sub pline ($sx, $sy, @q) {
my(@q[2*$_] *= $sx,$sy, @q)[1+2*$_] *= @_$sy) for 0 .. $#q/2;
qq|<polyline points="@{[join ' ',@q]}"
 
for (0..$#q/2) {
$q[ 2*$_] *= $sx;
$q[1+2*$_] *= $sy;
}
 
qq|<polyline points="@{[join ' ',@q]}"
style="fill:none;stroke:black;stroke-width:3"
transform="translate($a, $b)" />\n|
2,392

edits