mirror of
https://github.com/fluencelabs/assemblyscript
synced 2025-06-12 22:41:27 +00:00
Improve mandelbort example (#308)
This commit is contained in:
@ -186,7 +186,213 @@
|
||||
f64.mul
|
||||
f64.add
|
||||
)
|
||||
(func $../../examples/mandelbrot/assembly/index/computeLine (; 1 ;) (type $iiiiv) (param $0 i32) (param $1 i32) (param $2 i32) (param $3 i32)
|
||||
(func $~lib/math/NativeMath.log2 (; 1 ;) (type $FF) (param $0 f64) (result f64)
|
||||
(local $1 f64)
|
||||
(local $2 i32)
|
||||
(local $3 i32)
|
||||
(local $4 i32)
|
||||
(local $5 i64)
|
||||
(local $6 f64)
|
||||
(local $7 f64)
|
||||
(local $8 f64)
|
||||
get_local $0
|
||||
i64.reinterpret/f64
|
||||
tee_local $5
|
||||
i64.const 32
|
||||
i64.shr_u
|
||||
i32.wrap/i64
|
||||
tee_local $2
|
||||
i32.const 1048576
|
||||
i32.lt_u
|
||||
tee_local $3
|
||||
i32.eqz
|
||||
if
|
||||
get_local $2
|
||||
i32.const 31
|
||||
i32.shr_u
|
||||
set_local $3
|
||||
end
|
||||
get_local $3
|
||||
if
|
||||
get_local $5
|
||||
i64.const 1
|
||||
i64.shl
|
||||
i64.const 0
|
||||
i64.eq
|
||||
if
|
||||
f64.const -1
|
||||
get_local $0
|
||||
get_local $0
|
||||
f64.mul
|
||||
f64.div
|
||||
return
|
||||
end
|
||||
get_local $2
|
||||
i32.const 31
|
||||
i32.shr_u
|
||||
if
|
||||
get_local $0
|
||||
get_local $0
|
||||
f64.sub
|
||||
f64.const 0
|
||||
f64.div
|
||||
return
|
||||
end
|
||||
i32.const -54
|
||||
set_local $4
|
||||
get_local $0
|
||||
f64.const 18014398509481984
|
||||
f64.mul
|
||||
i64.reinterpret/f64
|
||||
tee_local $5
|
||||
i64.const 32
|
||||
i64.shr_u
|
||||
i32.wrap/i64
|
||||
set_local $2
|
||||
else
|
||||
get_local $2
|
||||
i32.const 2146435072
|
||||
i32.ge_u
|
||||
if
|
||||
get_local $0
|
||||
return
|
||||
else
|
||||
get_local $2
|
||||
i32.const 1072693248
|
||||
i32.eq
|
||||
tee_local $3
|
||||
if
|
||||
get_local $5
|
||||
i64.const 32
|
||||
i64.shl
|
||||
i64.const 0
|
||||
i64.eq
|
||||
set_local $3
|
||||
end
|
||||
get_local $3
|
||||
if
|
||||
f64.const 0
|
||||
return
|
||||
end
|
||||
end
|
||||
end
|
||||
get_local $2
|
||||
i32.const 614242
|
||||
i32.add
|
||||
tee_local $2
|
||||
i32.const 20
|
||||
i32.shr_u
|
||||
i32.const 1023
|
||||
i32.sub
|
||||
get_local $4
|
||||
i32.add
|
||||
set_local $4
|
||||
get_local $5
|
||||
i64.const 4294967295
|
||||
i64.and
|
||||
get_local $2
|
||||
i32.const 1048575
|
||||
i32.and
|
||||
i32.const 1072079006
|
||||
i32.add
|
||||
i64.extend_u/i32
|
||||
i64.const 32
|
||||
i64.shl
|
||||
i64.or
|
||||
f64.reinterpret/i64
|
||||
f64.const 1
|
||||
f64.sub
|
||||
tee_local $1
|
||||
f64.const 2
|
||||
get_local $1
|
||||
f64.add
|
||||
f64.div
|
||||
tee_local $6
|
||||
get_local $6
|
||||
f64.mul
|
||||
tee_local $7
|
||||
get_local $7
|
||||
f64.mul
|
||||
set_local $0
|
||||
get_local $1
|
||||
get_local $1
|
||||
f64.const 0.5
|
||||
get_local $1
|
||||
f64.mul
|
||||
get_local $1
|
||||
f64.mul
|
||||
tee_local $1
|
||||
f64.sub
|
||||
i64.reinterpret/f64
|
||||
i64.const -4294967296
|
||||
i64.and
|
||||
f64.reinterpret/i64
|
||||
tee_local $8
|
||||
f64.sub
|
||||
get_local $1
|
||||
f64.sub
|
||||
get_local $6
|
||||
get_local $1
|
||||
get_local $7
|
||||
f64.const 0.6666666666666735
|
||||
get_local $0
|
||||
f64.const 0.2857142874366239
|
||||
get_local $0
|
||||
f64.const 0.1818357216161805
|
||||
get_local $0
|
||||
f64.const 0.14798198605116586
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.mul
|
||||
get_local $0
|
||||
f64.const 0.3999999999940942
|
||||
get_local $0
|
||||
f64.const 0.22222198432149784
|
||||
get_local $0
|
||||
f64.const 0.15313837699209373
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.add
|
||||
f64.mul
|
||||
f64.add
|
||||
tee_local $0
|
||||
get_local $8
|
||||
f64.add
|
||||
f64.const 1.6751713164886512e-10
|
||||
f64.mul
|
||||
get_local $0
|
||||
f64.const 1.4426950407214463
|
||||
f64.mul
|
||||
f64.add
|
||||
set_local $6
|
||||
get_local $4
|
||||
f64.convert_s/i32
|
||||
tee_local $7
|
||||
get_local $8
|
||||
f64.const 1.4426950407214463
|
||||
f64.mul
|
||||
tee_local $1
|
||||
f64.add
|
||||
set_local $0
|
||||
get_local $6
|
||||
get_local $7
|
||||
get_local $0
|
||||
f64.sub
|
||||
get_local $1
|
||||
f64.add
|
||||
f64.add
|
||||
get_local $0
|
||||
f64.add
|
||||
)
|
||||
(func $../../examples/mandelbrot/assembly/index/computeLine (; 2 ;) (type $iiiiv) (param $0 i32) (param $1 i32) (param $2 i32) (param $3 i32)
|
||||
(local $4 f64)
|
||||
(local $5 f64)
|
||||
(local $6 f64)
|
||||
@ -196,15 +402,13 @@
|
||||
(local $10 f64)
|
||||
(local $11 f64)
|
||||
(local $12 f64)
|
||||
get_local $1
|
||||
f64.convert_u/i32
|
||||
tee_local $6
|
||||
f64.const 1.6
|
||||
f64.div
|
||||
set_local $12
|
||||
(local $13 f64)
|
||||
(local $14 f64)
|
||||
f64.const 10
|
||||
f64.const 3
|
||||
get_local $6
|
||||
get_local $1
|
||||
f64.convert_u/i32
|
||||
tee_local $8
|
||||
f64.mul
|
||||
f64.const 4
|
||||
get_local $2
|
||||
@ -217,12 +421,34 @@
|
||||
get_local $0
|
||||
f64.convert_u/i32
|
||||
get_local $4
|
||||
f64.const 2
|
||||
f64.div
|
||||
f64.const 0.5
|
||||
f64.mul
|
||||
f64.sub
|
||||
get_local $9
|
||||
f64.mul
|
||||
set_local $10
|
||||
get_local $8
|
||||
f64.const 0.625
|
||||
f64.mul
|
||||
get_local $9
|
||||
f64.mul
|
||||
set_local $12
|
||||
get_local $0
|
||||
get_local $1
|
||||
i32.mul
|
||||
i32.const 1
|
||||
i32.shl
|
||||
set_local $0
|
||||
f64.const 1
|
||||
get_local $3
|
||||
f64.convert_u/i32
|
||||
tee_local $6
|
||||
f64.div
|
||||
set_local $13
|
||||
f64.const 8
|
||||
get_local $6
|
||||
f64.min
|
||||
set_local $8
|
||||
loop $repeat|0
|
||||
get_local $7
|
||||
get_local $1
|
||||
@ -230,10 +456,10 @@
|
||||
if
|
||||
get_local $7
|
||||
f64.convert_u/i32
|
||||
get_local $12
|
||||
f64.sub
|
||||
get_local $9
|
||||
f64.mul
|
||||
get_local $12
|
||||
f64.sub
|
||||
set_local $11
|
||||
f64.const 0
|
||||
set_local $4
|
||||
@ -245,11 +471,11 @@
|
||||
get_local $4
|
||||
get_local $4
|
||||
f64.mul
|
||||
tee_local $6
|
||||
tee_local $14
|
||||
get_local $5
|
||||
get_local $5
|
||||
f64.mul
|
||||
tee_local $8
|
||||
tee_local $6
|
||||
f64.add
|
||||
f64.const 4
|
||||
f64.le
|
||||
@ -263,8 +489,8 @@
|
||||
get_local $10
|
||||
f64.add
|
||||
set_local $5
|
||||
get_local $14
|
||||
get_local $6
|
||||
get_local $8
|
||||
f64.sub
|
||||
get_local $11
|
||||
f64.add
|
||||
@ -281,15 +507,10 @@
|
||||
end
|
||||
end
|
||||
end
|
||||
f64.const 8
|
||||
get_local $3
|
||||
f64.convert_u/i32
|
||||
f64.min
|
||||
set_local $6
|
||||
loop $repeat|2
|
||||
loop $continue|2
|
||||
get_local $2
|
||||
f64.convert_u/i32
|
||||
get_local $6
|
||||
get_local $8
|
||||
f64.lt
|
||||
if
|
||||
get_local $4
|
||||
@ -301,7 +522,7 @@
|
||||
f64.sub
|
||||
get_local $11
|
||||
f64.add
|
||||
set_local $8
|
||||
set_local $6
|
||||
f64.const 2
|
||||
get_local $4
|
||||
f64.mul
|
||||
@ -310,22 +531,20 @@
|
||||
get_local $10
|
||||
f64.add
|
||||
set_local $5
|
||||
get_local $8
|
||||
get_local $6
|
||||
set_local $4
|
||||
get_local $2
|
||||
i32.const 1
|
||||
i32.add
|
||||
set_local $2
|
||||
br $repeat|2
|
||||
br $continue|2
|
||||
end
|
||||
end
|
||||
get_local $0
|
||||
get_local $1
|
||||
i32.mul
|
||||
get_local $7
|
||||
i32.add
|
||||
i32.const 1
|
||||
i32.shl
|
||||
get_local $0
|
||||
i32.add
|
||||
get_local $4
|
||||
get_local $4
|
||||
f64.mul
|
||||
@ -333,27 +552,23 @@
|
||||
get_local $5
|
||||
f64.mul
|
||||
f64.add
|
||||
f64.sqrt
|
||||
call $~lib/math/NativeMath.log
|
||||
call $~lib/math/NativeMath.log
|
||||
f64.const 0.6931471805599453
|
||||
f64.div
|
||||
tee_local $6
|
||||
get_local $6
|
||||
f64.sub
|
||||
f64.const 0
|
||||
f64.eq
|
||||
f64.const 1
|
||||
f64.gt
|
||||
if (result i32)
|
||||
f64.const 2047
|
||||
get_local $2
|
||||
i32.const 1
|
||||
i32.add
|
||||
f64.convert_u/i32
|
||||
f64.const 0.5
|
||||
get_local $6
|
||||
call $~lib/math/NativeMath.log
|
||||
f64.mul
|
||||
call $~lib/math/NativeMath.log2
|
||||
f64.sub
|
||||
get_local $3
|
||||
f64.convert_u/i32
|
||||
f64.div
|
||||
get_local $13
|
||||
f64.mul
|
||||
f64.const 0
|
||||
f64.max
|
||||
f64.const 1
|
||||
@ -372,7 +587,7 @@
|
||||
end
|
||||
end
|
||||
)
|
||||
(func $null (; 2 ;) (type $v)
|
||||
(func $null (; 3 ;) (type $v)
|
||||
nop
|
||||
)
|
||||
)
|
||||
|
Reference in New Issue
Block a user