assemblyscript/tests/compiler/mandelbrot.untouched.wat

728 lines
12 KiB
Plaintext

(module
(type $iiiiv (func (param i32 i32 i32 i32)))
(type $FF (func (param f64) (result f64)))
(type $FFFF (func (param f64 f64 f64) (result f64)))
(type $v (func))
(memory $0 0)
(table $0 1 funcref)
(elem (i32.const 0) $null)
(global $../../examples/mandelbrot/assembly/index/NUM_COLORS i32 (i32.const 2048))
(global $HEAP_BASE i32 (i32.const 8))
(export "memory" (memory $0))
(export "table" (table $0))
(export "computeLine" (func $../../examples/mandelbrot/assembly/index/computeLine))
(func $~lib/math/NativeMath.log (; 0 ;) (type $FF) (param $0 f64) (result f64)
(local $1 i64)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 f64)
(local $6 f64)
(local $7 f64)
(local $8 f64)
(local $9 f64)
(local $10 f64)
(local $11 f64)
(local $12 f64)
(local $13 i32)
local.get $0
i64.reinterpret_f64
local.set $1
local.get $1
i64.const 32
i64.shr_u
i32.wrap_i64
local.set $2
i32.const 0
local.set $3
local.get $2
i32.const 1048576
i32.lt_u
local.tee $4
if (result i32)
local.get $4
else
local.get $2
i32.const 31
i32.shr_u
end
if
local.get $1
i64.const 1
i64.shl
i64.const 0
i64.eq
if
f64.const -1
local.get $0
local.get $0
f64.mul
f64.div
return
end
local.get $2
i32.const 31
i32.shr_u
if
local.get $0
local.get $0
f64.sub
f64.const 0
f64.div
return
end
local.get $3
i32.const 54
i32.sub
local.set $3
local.get $0
f64.const 18014398509481984
f64.mul
local.set $0
local.get $0
i64.reinterpret_f64
local.set $1
local.get $1
i64.const 32
i64.shr_u
i32.wrap_i64
local.set $2
else
local.get $2
i32.const 2146435072
i32.ge_u
if
local.get $0
return
else
local.get $2
i32.const 1072693248
i32.eq
local.tee $4
if (result i32)
local.get $1
i64.const 32
i64.shl
i64.const 0
i64.eq
else
local.get $4
end
if
f64.const 0
return
end
end
end
local.get $2
i32.const 1072693248
i32.const 1072079006
i32.sub
i32.add
local.set $2
local.get $3
local.get $2
i32.const 20
i32.shr_s
i32.const 1023
i32.sub
i32.add
local.set $3
local.get $2
i32.const 1048575
i32.and
i32.const 1072079006
i32.add
local.set $2
local.get $2
i64.extend_i32_u
i64.const 32
i64.shl
local.get $1
i64.const 4294967295
i64.and
i64.or
local.set $1
local.get $1
f64.reinterpret_i64
local.set $0
local.get $0
f64.const 1
f64.sub
local.set $5
f64.const 0.5
local.get $5
f64.mul
local.get $5
f64.mul
local.set $6
local.get $5
f64.const 2
local.get $5
f64.add
f64.div
local.set $7
local.get $7
local.get $7
f64.mul
local.set $8
local.get $8
local.get $8
f64.mul
local.set $9
local.get $9
f64.const 0.3999999999940942
local.get $9
f64.const 0.22222198432149784
local.get $9
f64.const 0.15313837699209373
f64.mul
f64.add
f64.mul
f64.add
f64.mul
local.set $10
local.get $8
f64.const 0.6666666666666735
local.get $9
f64.const 0.2857142874366239
local.get $9
f64.const 0.1818357216161805
local.get $9
f64.const 0.14798198605116586
f64.mul
f64.add
f64.mul
f64.add
f64.mul
f64.add
f64.mul
local.set $11
local.get $11
local.get $10
f64.add
local.set $12
local.get $3
local.set $13
local.get $7
local.get $6
local.get $12
f64.add
f64.mul
local.get $13
f64.convert_i32_s
f64.const 1.9082149292705877e-10
f64.mul
f64.add
local.get $6
f64.sub
local.get $5
f64.add
local.get $13
f64.convert_i32_s
f64.const 0.6931471803691238
f64.mul
f64.add
)
(func $~lib/math/NativeMath.log2 (; 1 ;) (type $FF) (param $0 f64) (result f64)
(local $1 i64)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 f64)
(local $6 f64)
(local $7 f64)
(local $8 f64)
(local $9 f64)
(local $10 f64)
(local $11 f64)
(local $12 f64)
(local $13 f64)
(local $14 f64)
(local $15 f64)
(local $16 f64)
(local $17 f64)
local.get $0
i64.reinterpret_f64
local.set $1
local.get $1
i64.const 32
i64.shr_u
i32.wrap_i64
local.set $2
i32.const 0
local.set $3
local.get $2
i32.const 1048576
i32.lt_u
local.tee $4
if (result i32)
local.get $4
else
local.get $2
i32.const 31
i32.shr_u
end
if
local.get $1
i64.const 1
i64.shl
i64.const 0
i64.eq
if
f64.const -1
local.get $0
local.get $0
f64.mul
f64.div
return
end
local.get $2
i32.const 31
i32.shr_u
if
local.get $0
local.get $0
f64.sub
f64.const 0
f64.div
return
end
local.get $3
i32.const 54
i32.sub
local.set $3
local.get $0
f64.const 18014398509481984
f64.mul
local.set $0
local.get $0
i64.reinterpret_f64
local.set $1
local.get $1
i64.const 32
i64.shr_u
i32.wrap_i64
local.set $2
else
local.get $2
i32.const 2146435072
i32.ge_u
if
local.get $0
return
else
local.get $2
i32.const 1072693248
i32.eq
local.tee $4
if (result i32)
local.get $1
i64.const 32
i64.shl
i64.const 0
i64.eq
else
local.get $4
end
if
f64.const 0
return
end
end
end
local.get $2
i32.const 1072693248
i32.const 1072079006
i32.sub
i32.add
local.set $2
local.get $3
local.get $2
i32.const 20
i32.shr_u
i32.const 1023
i32.sub
i32.add
local.set $3
local.get $2
i32.const 1048575
i32.and
i32.const 1072079006
i32.add
local.set $2
local.get $2
i64.extend_i32_u
i64.const 32
i64.shl
local.get $1
i64.const 4294967295
i64.and
i64.or
local.set $1
local.get $1
f64.reinterpret_i64
local.set $0
local.get $0
f64.const 1
f64.sub
local.set $5
f64.const 0.5
local.get $5
f64.mul
local.get $5
f64.mul
local.set $6
local.get $5
f64.const 2
local.get $5
f64.add
f64.div
local.set $7
local.get $7
local.get $7
f64.mul
local.set $8
local.get $8
local.get $8
f64.mul
local.set $9
local.get $9
f64.const 0.3999999999940942
local.get $9
f64.const 0.22222198432149784
local.get $9
f64.const 0.15313837699209373
f64.mul
f64.add
f64.mul
f64.add
f64.mul
local.set $10
local.get $8
f64.const 0.6666666666666735
local.get $9
f64.const 0.2857142874366239
local.get $9
f64.const 0.1818357216161805
local.get $9
f64.const 0.14798198605116586
f64.mul
f64.add
f64.mul
f64.add
f64.mul
f64.add
f64.mul
local.set $11
local.get $11
local.get $10
f64.add
local.set $12
local.get $5
local.get $6
f64.sub
local.set $13
local.get $13
i64.reinterpret_f64
local.set $1
local.get $1
i64.const -4294967296
i64.and
local.set $1
local.get $1
f64.reinterpret_i64
local.set $13
local.get $5
local.get $13
f64.sub
local.get $6
f64.sub
local.get $7
local.get $6
local.get $12
f64.add
f64.mul
f64.add
local.set $14
local.get $13
f64.const 1.4426950407214463
f64.mul
local.set $15
local.get $14
local.get $13
f64.add
f64.const 1.6751713164886512e-10
f64.mul
local.get $14
f64.const 1.4426950407214463
f64.mul
f64.add
local.set $16
local.get $3
f64.convert_i32_s
local.set $17
local.get $17
local.get $15
f64.add
local.set $9
local.get $16
local.get $17
local.get $9
f64.sub
local.get $15
f64.add
f64.add
local.set $16
local.get $9
local.set $15
local.get $16
local.get $15
f64.add
)
(func $../../examples/mandelbrot/assembly/index/clamp<f64> (; 2 ;) (type $FFFF) (param $0 f64) (param $1 f64) (param $2 f64) (result f64)
local.get $0
local.get $1
f64.max
local.get $2
f64.min
)
(func $../../examples/mandelbrot/assembly/index/computeLine (; 3 ;) (type $iiiiv) (param $0 i32) (param $1 i32) (param $2 i32) (param $3 i32)
(local $4 f64)
(local $5 f64)
(local $6 f64)
(local $7 f64)
(local $8 f64)
(local $9 i32)
(local $10 f64)
(local $11 f64)
(local $12 i32)
(local $13 f64)
(local $14 f64)
(local $15 f64)
(local $16 f64)
(local $17 f64)
(local $18 i32)
(local $19 f64)
(local $20 i32)
(local $21 f64)
local.get $1
f64.convert_i32_u
f64.const 1
f64.const 1.6
f64.div
f64.mul
local.set $4
local.get $2
f64.convert_i32_u
f64.const 1
f64.const 2
f64.div
f64.mul
local.set $5
f64.const 10
f64.const 3
local.get $1
f64.convert_i32_u
f64.mul
f64.const 4
local.get $2
f64.convert_i32_u
f64.mul
f64.min
f64.div
local.set $6
local.get $0
f64.convert_i32_u
local.get $5
f64.sub
local.get $6
f64.mul
local.set $7
local.get $4
local.get $6
f64.mul
local.set $8
local.get $0
local.get $1
i32.mul
i32.const 1
i32.shl
local.set $9
f64.const 1
local.get $3
f64.convert_i32_u
f64.div
local.set $10
f64.const 8
local.get $3
f64.convert_i32_u
f64.min
local.set $11
block $break|0
i32.const 0
local.set $12
loop $repeat|0
local.get $12
local.get $1
i32.lt_u
i32.eqz
br_if $break|0
block
local.get $12
f64.convert_i32_u
local.get $6
f64.mul
local.get $8
f64.sub
local.set $13
f64.const 0
local.set $14
f64.const 0
local.set $15
i32.const 0
local.set $18
block $break|1
loop $continue|1
local.get $14
local.get $14
f64.mul
local.tee $16
local.get $15
local.get $15
f64.mul
local.tee $17
f64.add
f64.const 4
f64.le
if
block
f64.const 2
local.get $14
f64.mul
local.get $15
f64.mul
local.get $7
f64.add
local.set $15
local.get $16
local.get $17
f64.sub
local.get $13
f64.add
local.set $14
local.get $18
local.get $3
i32.ge_u
if
br $break|1
end
local.get $18
i32.const 1
i32.add
local.set $18
end
br $continue|1
end
end
end
block $break|2
loop $continue|2
local.get $18
f64.convert_i32_u
local.get $11
f64.lt
if
block
local.get $14
local.get $14
f64.mul
local.get $15
local.get $15
f64.mul
f64.sub
local.get $13
f64.add
local.set $19
f64.const 2
local.get $14
f64.mul
local.get $15
f64.mul
local.get $7
f64.add
local.set $15
local.get $19
local.set $14
local.get $18
i32.const 1
i32.add
local.set $18
end
br $continue|2
end
end
end
global.get $../../examples/mandelbrot/assembly/index/NUM_COLORS
i32.const 1
i32.sub
local.set $20
local.get $14
local.get $14
f64.mul
local.get $15
local.get $15
f64.mul
f64.add
local.set $19
local.get $19
f64.const 1
f64.gt
if
f64.const 0.5
local.get $19
call $~lib/math/NativeMath.log
f64.mul
call $~lib/math/NativeMath.log2
local.set $21
global.get $../../examples/mandelbrot/assembly/index/NUM_COLORS
i32.const 1
i32.sub
f64.convert_i32_s
local.get $18
i32.const 1
i32.add
f64.convert_i32_u
local.get $21
f64.sub
local.get $10
f64.mul
f64.const 0
f64.const 1
call $../../examples/mandelbrot/assembly/index/clamp<f64>
f64.mul
i32.trunc_f64_u
local.set $20
end
local.get $9
local.get $12
i32.const 1
i32.shl
i32.add
local.get $20
i32.store16
end
local.get $12
i32.const 1
i32.add
local.set $12
br $repeat|0
unreachable
end
unreachable
end
)
(func $null (; 4 ;) (type $v)
)
)