AND_sierpinski_triangle.pl 797 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #!/usr/bin/perl
  2. # Daniel "Trizen" Șuteu
  3. # License: GPLv3
  4. # Date: 20 January 2017
  5. # https://github.com/trizen
  6. # Generation of the Sierpinski triangle,
  7. # by plotting the values of the function
  8. #
  9. # f(n) = n AND n^2
  10. #
  11. # See also:
  12. # https://oeis.org/A213541
  13. # https://en.wikipedia.org/wiki/Sierpinski_triangle
  14. use 5.010;
  15. use strict;
  16. use warnings;
  17. use Imager;
  18. my $size = 1300;
  19. my $factor = 100;
  20. my $red = Imager::Color->new('#ff0000');
  21. my $img = Imager->new(xsize => $size,
  22. ysize => $size);
  23. foreach my $n (1 .. $size * $factor) {
  24. $img->setpixel(
  25. x => $n / $factor,
  26. y => $size - ($n & ($n * $n)) / $factor,
  27. color => $red
  28. );
  29. }
  30. $img->write(file => 'sierpinski_triangle.png');