Add some smoothing to mandelbrot example

This commit is contained in:
dcodeIO
2018-04-20 05:06:05 +02:00
parent 9cd3304e13
commit b53b3e08ec
16 changed files with 1441 additions and 810 deletions

View File

@ -1,10 +1,13 @@
(module
(type $iiiv (func (param i32 i32 i32)))
(type $FF (func (param f64) (result f64)))
(import "JSMath" "log" (func $~lib/math/JSMath.log (param f64) (result f64)))
(import "JSMath" "LN2" (global $~lib/math/JSMath.LN2 f64))
(global $HEAP_BASE i32 (i32.const 4))
(memory $0 1)
(export "compute" (func $assembly/index/compute))
(export "memory" (memory $0))
(func $assembly/index/compute (; 0 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(func $assembly/index/compute (; 1 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(local $3 f64)
(local $4 f64)
(local $5 f64)
@ -12,12 +15,14 @@
(local $7 f64)
(local $8 i32)
(local $9 f64)
(local $10 i32)
(local $10 f64)
(local $11 f64)
(local $12 f64)
(local $13 f64)
(local $14 f64)
(local $14 i32)
(local $15 f64)
(local $16 i32)
(local $17 f64)
;;@ assembly/index.ts:5:2
(set_local $3
;;@ assembly/index.ts:5:19
@ -44,10 +49,25 @@
(set_local $5
;;@ assembly/index.ts:7:14
(f64.div
(f64.const 4)
(f64.convert_u/i32
;;@ assembly/index.ts:7:20
(get_local $0)
(f64.const 10)
;;@ assembly/index.ts:7:21
(f64.min
;;@ assembly/index.ts:7:25
(f64.mul
(f64.const 3)
(f64.convert_u/i32
;;@ assembly/index.ts:7:29
(get_local $0)
)
)
;;@ assembly/index.ts:7:36
(f64.mul
(f64.const 4)
(f64.convert_u/i32
;;@ assembly/index.ts:7:40
(get_local $1)
)
)
)
)
)
@ -117,112 +137,105 @@
(get_local $5)
)
)
;;@ assembly/index.ts:12:6
(set_local $10
;;@ assembly/index.ts:12:22
;;@ assembly/index.ts:14:6
(block
(set_local $10
;;@ assembly/index.ts:14:15
(f64.const 0)
)
(set_local $11
;;@ assembly/index.ts:14:25
(f64.const 0)
)
)
;;@ assembly/index.ts:15:6
(set_local $14
;;@ assembly/index.ts:15:27
(i32.const 0)
)
;;@ assembly/index.ts:13:6
(nop)
;;@ assembly/index.ts:14:6
;;@ assembly/index.ts:16:6
(block $break|2
(block
(set_local $13
;;@ assembly/index.ts:14:20
(f64.const 0)
)
(set_local $14
;;@ assembly/index.ts:14:30
(f64.const 0)
)
)
(loop $continue|2
(if
;;@ assembly/index.ts:14:35
;;@ assembly/index.ts:16:13
(f64.le
(f64.add
(tee_local $11
;;@ assembly/index.ts:14:43
(tee_local $12
;;@ assembly/index.ts:16:21
(f64.mul
(get_local $13)
;;@ assembly/index.ts:14:48
(get_local $13)
(get_local $10)
;;@ assembly/index.ts:16:26
(get_local $10)
)
)
;;@ assembly/index.ts:14:54
(tee_local $12
;;@ assembly/index.ts:14:62
;;@ assembly/index.ts:16:32
(tee_local $13
;;@ assembly/index.ts:16:40
(f64.mul
(get_local $14)
;;@ assembly/index.ts:14:67
(get_local $14)
(get_local $11)
;;@ assembly/index.ts:16:45
(get_local $11)
)
)
)
;;@ assembly/index.ts:14:74
;;@ assembly/index.ts:16:52
(f64.const 4)
)
(block
(block
;;@ assembly/index.ts:15:8
;;@ assembly/index.ts:17:8
(set_local $15
;;@ assembly/index.ts:15:16
;;@ assembly/index.ts:17:16
(f64.add
(f64.sub
(get_local $11)
;;@ assembly/index.ts:15:23
(get_local $12)
;;@ assembly/index.ts:17:23
(get_local $13)
)
;;@ assembly/index.ts:15:30
;;@ assembly/index.ts:17:30
(get_local $9)
)
)
;;@ assembly/index.ts:16:8
(set_local $14
;;@ assembly/index.ts:16:13
;;@ assembly/index.ts:18:8
(set_local $11
;;@ assembly/index.ts:18:13
(f64.add
(f64.mul
(f64.mul
(f64.const 2)
;;@ assembly/index.ts:16:19
(get_local $13)
;;@ assembly/index.ts:18:19
(get_local $10)
)
;;@ assembly/index.ts:16:24
(get_local $14)
;;@ assembly/index.ts:18:24
(get_local $11)
)
;;@ assembly/index.ts:16:29
;;@ assembly/index.ts:18:29
(get_local $7)
)
)
;;@ assembly/index.ts:17:8
(set_local $13
;;@ assembly/index.ts:17:13
;;@ assembly/index.ts:19:8
(set_local $10
;;@ assembly/index.ts:19:13
(get_local $15)
)
;;@ assembly/index.ts:18:8
;;@ assembly/index.ts:20:8
(if
;;@ assembly/index.ts:18:12
;;@ assembly/index.ts:20:12
(i32.ge_u
(tee_local $10
(i32.add
;;@ assembly/index.ts:18:14
(get_local $10)
(i32.const 1)
)
)
;;@ assembly/index.ts:18:27
(get_local $14)
;;@ assembly/index.ts:20:25
(get_local $2)
)
;;@ assembly/index.ts:18:32
;;@ assembly/index.ts:20:32
(br $break|2)
)
)
;;@ assembly/index.ts:14:79
(set_local $10
(i32.add
;;@ assembly/index.ts:14:81
(get_local $10)
(i32.const 1)
;;@ assembly/index.ts:21:8
(set_local $14
(i32.add
;;@ assembly/index.ts:21:10
(get_local $14)
(i32.const 1)
)
)
)
(br $continue|2)
@ -230,27 +243,217 @@
)
)
)
;;@ assembly/index.ts:21:6
(i32.store8
;;@ assembly/index.ts:21:16
(i32.add
(i32.mul
(get_local $6)
;;@ assembly/index.ts:21:20
(get_local $0)
)
;;@ assembly/index.ts:21:28
(get_local $8)
;;@ assembly/index.ts:25:6
(block $break|3
;;@ assembly/index.ts:25:11
(set_local $16
;;@ assembly/index.ts:25:19
(i32.const 0)
)
;;@ assembly/index.ts:21:31
(i32.div_u
(i32.mul
(get_local $10)
;;@ assembly/index.ts:21:43
(i32.const 255)
(loop $continue|3
(if
;;@ assembly/index.ts:25:22
(i32.lt_s
(get_local $16)
;;@ assembly/index.ts:25:26
(i32.const 4)
)
(block
(block
;;@ assembly/index.ts:26:8
(set_local $15
;;@ assembly/index.ts:26:16
(f64.add
(f64.sub
(tee_local $12
;;@ assembly/index.ts:26:24
(f64.mul
(get_local $10)
;;@ assembly/index.ts:26:29
(get_local $10)
)
)
;;@ assembly/index.ts:26:35
(tee_local $13
;;@ assembly/index.ts:26:43
(f64.mul
(get_local $11)
;;@ assembly/index.ts:26:48
(get_local $11)
)
)
)
;;@ assembly/index.ts:26:54
(get_local $9)
)
)
;;@ assembly/index.ts:27:8
(set_local $11
;;@ assembly/index.ts:27:13
(f64.add
(f64.mul
(f64.mul
(f64.const 2)
;;@ assembly/index.ts:27:19
(get_local $10)
)
;;@ assembly/index.ts:27:24
(get_local $11)
)
;;@ assembly/index.ts:27:29
(get_local $7)
)
)
;;@ assembly/index.ts:28:8
(set_local $10
;;@ assembly/index.ts:28:13
(get_local $15)
)
)
;;@ assembly/index.ts:25:29
(set_local $16
(i32.add
;;@ assembly/index.ts:25:31
(get_local $16)
(i32.const 1)
)
)
(br $continue|3)
)
)
)
)
;;@ assembly/index.ts:32:6
(set_local $15
;;@ assembly/index.ts:32:22
(f64.div
;;@ assembly/index.ts:32:29
(call $~lib/math/JSMath.log
;;@ assembly/index.ts:32:40
(call $~lib/math/JSMath.log
;;@ assembly/index.ts:32:44
(f64.sqrt
;;@ assembly/index.ts:32:49
(f64.add
(f64.mul
(get_local $10)
;;@ assembly/index.ts:32:54
(get_local $10)
)
;;@ assembly/index.ts:32:59
(f64.mul
(get_local $11)
;;@ assembly/index.ts:32:64
(get_local $11)
)
)
)
)
)
;;@ assembly/index.ts:32:72
(get_global $~lib/math/JSMath.LN2)
)
)
;;@ assembly/index.ts:33:6
(if
;;@ assembly/index.ts:33:10
(f64.gt
(get_local $15)
;;@ assembly/index.ts:33:17
(f64.const 0)
)
;;@ assembly/index.ts:33:20
(block
;;@ assembly/index.ts:34:8
(set_local $17
;;@ assembly/index.ts:34:24
(f64.max
;;@ assembly/index.ts:34:33
(f64.min
;;@ assembly/index.ts:34:42
(f64.div
(f64.sub
;;@ assembly/index.ts:34:43
(f64.convert_u/i32
;;@ assembly/index.ts:34:49
(i32.add
(get_local $14)
;;@ assembly/index.ts:34:61
(i32.const 1)
)
)
;;@ assembly/index.ts:34:66
(get_local $15)
)
(f64.convert_u/i32
;;@ assembly/index.ts:34:74
(get_local $2)
)
)
;;@ assembly/index.ts:34:81
(f64.const 1)
)
;;@ assembly/index.ts:34:87
(f64.const 0)
)
)
;;@ assembly/index.ts:35:8
(i32.store16
;;@ assembly/index.ts:35:19
(i32.shl
(i32.add
;;@ assembly/index.ts:35:20
(i32.mul
(get_local $6)
;;@ assembly/index.ts:35:24
(get_local $0)
)
;;@ assembly/index.ts:35:32
(get_local $8)
)
;;@ assembly/index.ts:35:38
(i32.const 1)
)
;;@ assembly/index.ts:35:41
(i32.trunc_u/f64
;;@ assembly/index.ts:35:47
(f64.mul
(f64.convert_u/i32
(i32.const 2047)
)
;;@ assembly/index.ts:35:54
(get_local $17)
)
)
)
)
;;@ assembly/index.ts:37:8
(i32.store16
;;@ assembly/index.ts:37:19
(i32.shl
(i32.add
;;@ assembly/index.ts:37:20
(i32.mul
(get_local $6)
;;@ assembly/index.ts:37:24
(get_local $0)
)
;;@ assembly/index.ts:37:32
(get_local $8)
)
;;@ assembly/index.ts:37:38
(i32.const 1)
)
;;@ assembly/index.ts:37:41
(i32.div_u
(i32.mul
(get_local $14)
;;@ assembly/index.ts:37:53
(i32.const 2047)
)
;;@ assembly/index.ts:37:60
(get_local $2)
)
;;@ assembly/index.ts:21:49
(get_local $2)
)
)
)