File: fractal.um

package info (click to toggle)
cloc 2.06-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 8,064 kB
  • sloc: perl: 30,146; cpp: 1,219; python: 623; ansic: 334; asm: 267; makefile: 244; sh: 186; sql: 144; java: 136; ruby: 111; cs: 104; pascal: 52; lisp: 50; haskell: 35; f90: 35; cobol: 35; objc: 25; php: 22; javascript: 15; fortran: 9; ml: 8; xml: 7; tcl: 2
file content (38 lines) | stat: -rw-r--r-- 883 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
 https://github.com/vtereshkov/umka-lang/raw/master/examples/fractal/fractal.um
*/
// Fractal demo in Umka (adapted from a Wren version by Robert Nystrom)

fn main() {
    const (
        yMin = -0.2
        yMax =  0.1
        xMin = -1.5
        xMax = -1.1
    )

    for yPixel := 0; yPixel < 40; yPixel++ {
      y0 := (yPixel / 40.0) * (yMax - yMin) + yMin
      
      for xPixel := 0; xPixel < 79; xPixel++ {
        x0 := (xPixel / 78.0) * (xMax - xMin) + xMin
        x, y := x0, y0
        pixel := ' '       
        
        for iter := 0; iter < 80; iter++ {
          x, y = x * x - y * y + x0, 2 * x * y + y0

          // Stop if the point escaped
          if x * x + y * y > 4 {
            const pixels = " .:;+=xX$&"
            pixel = pixels[iter / 8]
            break
          }
        }

        printf("%c", pixel)
      }

      printf("\n")
    }
}