-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmandel1.go
122 lines (94 loc) · 2.01 KB
/
mandel1.go
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package main
import (
"fmt"
"log"
"math/cmplx"
"os"
"sync"
"time"
"github.com/veandco/go-sdl2/sdl"
)
func main() {
start := time.Now()
var renderer *sdl.Renderer
var width int32 = 1920
var height int32 = 1080
hwidth := int32(width / 2)
hheight := int32(height / 2)
var wid float64 = 4
var xcenter, ycenter float64 = -1, 0
sdl.Init(sdl.INIT_EVERYTHING)
window, err := sdl.CreateWindow("Mandelbrot", sdl.WINDOWPOS_UNDEFINED, sdl.WINDOWPOS_UNDEFINED, width, height, sdl.WINDOW_SHOWN)
if err != nil {
panic(err)
}
defer window.Destroy()
renderer, err = sdl.CreateRenderer(window, -1, sdl.RENDERER_ACCELERATED)
if err != nil {
fmt.Fprintf(os.Stderr, "Failed to create renderer: %s\n", err)
panic(err)
}
defer renderer.Destroy()
renderer.SetDrawColor(0, 0, 128, 0)
renderer.Clear()
renderer.Present()
var c1, c2, c3 uint8 = 0, 0, 0
var xcoord int32
var ycoord int32
var wg sync.WaitGroup
for xcoord = 0; xcoord < width; xcoord++ {
wg.Add(1)
go func(xcoord int32) {
for ycoord = 0; ycoord < height-1; ycoord++ {
ca := float64(xcoord-hwidth)/float64(width)*wid + xcenter
cb := float64(ycoord-hheight)/float64(width)*1*wid + ycenter
res, i := mandelbrot(complex(ca, cb))
var hcolor uint8 = 128
if i != 0 {
hcolor = uint8(10 * i)
}
if res == 0 {
c1 = 0
c2 = 0
c3 = 128
} else if i < 5 {
c1 = 0
c2 = 0
c3 = 128
} else if i > 5 && i < 7 {
c1 = 0
c2 = 0
c3 = hcolor
} else if i > 7 && i < 10 {
c1 = 0
c2 = hcolor
c3 = 0
} else {
c1 = hcolor
c2 = 0
c3 = 0
}
renderer.SetDrawColor(c1, c2, c3, 0)
renderer.DrawPoint(xcoord, ycoord)
}
wg.Done()
}(xcoord)
wg.Wait()
}
renderer.Present()
elapsed := time.Since(start)
log.Printf("took %s sec(s)", elapsed)
sdl.Delay(5000)
sdl.Quit()
}
func mandelbrot(c complex128) (complex128, int) {
var z = c
var i int
for i = 1; i < 20; i++ {
z = z*z + c
if cmplx.Abs(z) > 2 {
return z, i
}
}
return 0, 0
}