Lineart: Difference between revisions

From wikiluntti
Line 48: Line 48:
** Resize the original image such that one pixel corresponds to the diameter of the thread.
** Resize the original image such that one pixel corresponds to the diameter of the thread.
** Blurring: Downscale by a factor <math>d</math> and add transparency of <math>1/d</math>.
** Blurring: Downscale by a factor <math>d</math> and add transparency of <math>1/d</math>.
* Use [https://www.middle-engine.com/blog/posts/2020/07/28/bresenhams-line-algorithm Bresenham's line algorithm] for the line.


== Datagenetics ==
== Datagenetics ==

Revision as of 16:49, 24 October 2024

Introduction

String art

  • Radon transform (inverse of)
  • 2d FFT
  • Optimization

Radon Transform

The sum of the intensities in each direction (a line integral).

The new image will be

Virtually Passed YT

White canvas with nails around the circumference and add straight black lines between the nails.

Video: The Mathematics of String Art

  • Starting nail angle and ending nail angle . Maximum number of lines is
  • Convert image array to vectors, and make the linear combination: . Solve .
  • Problems:
    • Line darkness. Use some antialiasing algorithm; from step function to some other.
    • Pseudoinverse gives not binary result. Greedy algorithm.
  • FFT in part II gives much better results

Video: How To Make a Computer Create Something Beautiful: String Art

  • Radon transform; density function .
  • plot sinogram: .
  • Make linear transform where are the binary weights.
  • Need a Radon transform for lines.
  • max because the lines are of different length.

Michael Crum

https://michael-crum.com/string_art_generator/

Datagenetics

https://datagenetics.com/blog/december12019/index.html

References