mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
examples: speed up mandelbrot.v a little, increase iterations/details too
This commit is contained in:
parent
922f003729
commit
ea71ea3ec1
@ -11,6 +11,8 @@ const chunk_height = 2 // the image is recalculated in chunks, each chunk proces
|
|||||||
|
|
||||||
const zoom_factor = 1.1
|
const zoom_factor = 1.1
|
||||||
|
|
||||||
|
const max_iterations = 255
|
||||||
|
|
||||||
struct ViewRect {
|
struct ViewRect {
|
||||||
mut:
|
mut:
|
||||||
x_min f64
|
x_min f64
|
||||||
@ -33,12 +35,13 @@ mut:
|
|||||||
iidx int
|
iidx int
|
||||||
pixels &u32 = unsafe { vcalloc(pwidth * pheight * sizeof(u32)) }
|
pixels &u32 = unsafe { vcalloc(pwidth * pheight * sizeof(u32)) }
|
||||||
npixels &u32 = unsafe { vcalloc(pwidth * pheight * sizeof(u32)) } // all drawing happens here, results are swapped at the end
|
npixels &u32 = unsafe { vcalloc(pwidth * pheight * sizeof(u32)) } // all drawing happens here, results are swapped at the end
|
||||||
view ViewRect = ViewRect{-2.7610033817025625, 1.1788897130338223, -1.824584023871934, 2.1153096311072788}
|
view ViewRect = ViewRect{-3.0773593290970673, 1.4952456603855397, -2.019938598189011, 2.3106642054225945}
|
||||||
|
scale int = 1
|
||||||
ntasks int = runtime.nr_jobs()
|
ntasks int = runtime.nr_jobs()
|
||||||
}
|
}
|
||||||
|
|
||||||
const colors = [gx.black, gx.blue, gx.red, gx.green, gx.yellow, gx.orange, gx.purple, gx.white,
|
const colors = [gx.black, gx.blue, gx.red, gx.green, gx.yellow, gx.orange, gx.purple, gx.white,
|
||||||
gx.indigo, gx.violet, gx.black].map(u32(it.abgr8()))
|
gx.indigo, gx.violet, gx.black, gx.blue, gx.orange, gx.yellow, gx.green].map(u32(it.abgr8()))
|
||||||
|
|
||||||
struct MandelChunk {
|
struct MandelChunk {
|
||||||
cview ViewRect
|
cview ViewRect
|
||||||
@ -83,30 +86,35 @@ fn (mut state AppState) update() {
|
|||||||
}
|
}
|
||||||
// everything is done, swap the buffer pointers
|
// everything is done, swap the buffer pointers
|
||||||
state.pixels, state.npixels = state.npixels, state.pixels
|
state.pixels, state.npixels = state.npixels, state.pixels
|
||||||
println('$state.ntasks threads; $sw.elapsed().milliseconds() ms / frame')
|
println('${state.ntasks:2} threads; ${sw.elapsed().milliseconds():3} ms / frame; scale: ${state.scale:4}')
|
||||||
oview = cview
|
oview = cview
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[direct_array_access]
|
||||||
fn (mut state AppState) worker(id int, input chan MandelChunk, ready chan bool) {
|
fn (mut state AppState) worker(id int, input chan MandelChunk, ready chan bool) {
|
||||||
for {
|
for {
|
||||||
chunk := <-input or { break }
|
chunk := <-input or { break }
|
||||||
yscale := chunk.cview.height() / pheight
|
yscale := chunk.cview.height() / pheight
|
||||||
xscale := chunk.cview.width() / pwidth
|
xscale := chunk.cview.width() / pwidth
|
||||||
|
mut x, mut y, mut iter := 0.0, 0.0, 0
|
||||||
|
mut y0 := chunk.ymin * yscale + chunk.cview.y_min
|
||||||
|
mut x0 := chunk.cview.x_min
|
||||||
for y_pixel := chunk.ymin; y_pixel < chunk.ymax && y_pixel < pheight; y_pixel++ {
|
for y_pixel := chunk.ymin; y_pixel < chunk.ymax && y_pixel < pheight; y_pixel++ {
|
||||||
y0 := y_pixel * yscale + chunk.cview.y_min
|
yrow := unsafe { &state.npixels[int(y_pixel * pwidth)] }
|
||||||
for x_pixel := 0.0; x_pixel < pwidth; x_pixel++ {
|
y0 += yscale
|
||||||
x0 := x_pixel * xscale + chunk.cview.x_min
|
x0 = chunk.cview.x_min
|
||||||
mut x, mut y := x0, y0
|
for x_pixel := 0; x_pixel < pwidth; x_pixel++ {
|
||||||
mut iter := 0
|
x0 += xscale
|
||||||
for ; iter < 80; iter++ {
|
x, y = x0, y0
|
||||||
|
for iter = 0; iter < max_iterations; iter++ {
|
||||||
x, y = x * x - y * y + x0, 2 * x * y + y0
|
x, y = x * x - y * y + x0, 2 * x * y + y0
|
||||||
if x * x + y * y > 4 {
|
if x * x + y * y > 4 {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
unsafe {
|
unsafe {
|
||||||
state.npixels[int(y_pixel * pwidth) + int(x_pixel)] = colors[iter & 7]
|
yrow[x_pixel] = colors[iter & 15]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -128,6 +136,7 @@ fn (mut state AppState) zoom(zoom_factor f64) {
|
|||||||
state.view.x_max = c_x + zoom_factor * d_x
|
state.view.x_max = c_x + zoom_factor * d_x
|
||||||
state.view.y_min = c_y - zoom_factor * d_y
|
state.view.y_min = c_y - zoom_factor * d_y
|
||||||
state.view.y_max = c_y + zoom_factor * d_y
|
state.view.y_max = c_y + zoom_factor * d_y
|
||||||
|
state.scale += if zoom_factor < 1 { 1 } else { -1 }
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (mut state AppState) center(s_x f64, s_y f64) {
|
fn (mut state AppState) center(s_x f64, s_y f64) {
|
||||||
@ -182,7 +191,7 @@ fn graphics_keydown(code gg.KeyCode, mod gg.Modifier, mut state AppState) {
|
|||||||
// movement
|
// movement
|
||||||
mut d_x, mut d_y := 0.0, 0.0
|
mut d_x, mut d_y := 0.0, 0.0
|
||||||
if code == .enter {
|
if code == .enter {
|
||||||
println('> $state.view.x_min | $state.view.x_max | $state.view.y_min | $state.view.y_max')
|
println('> ViewRect{$state.view.x_min, $state.view.x_max, $state.view.y_min, $state.view.y_max}')
|
||||||
}
|
}
|
||||||
if state.gg.pressed_keys[int(gg.KeyCode.left)] {
|
if state.gg.pressed_keys[int(gg.KeyCode.left)] {
|
||||||
d_x -= s_x
|
d_x -= s_x
|
||||||
|
Loading…
Reference in New Issue
Block a user