194 lines
3.7 KiB
Plaintext
Raw Normal View History

; Prog8 definitions for floating point handling on the VirtualMachine
%option enable_floats, ignore_unused
floats {
const float π = 3.141592653589793
const float PI = π
const float TWOPI = 2*π
sub print(float value) {
2023-12-07 23:10:27 +01:00
; ---- prints the floating point value (without a newline and no leading spaces).
%ir {{
loadm.f fr65535,floats.print.value
syscall 25 (fr65535.f)
2022-04-30 00:10:07 +02:00
return
}}
}
sub tostr(float value) -> str {
2023-12-07 23:10:27 +01:00
; ---- converts the floating point value to a string (no leading spaces)
str @shared buffer=" "*20
%ir {{
load.w r65535,floats.tostr.buffer
loadm.f fr65535,floats.tostr.value
2023-12-07 23:10:27 +01:00
syscall 47 (r65535.w, fr65535.f)
load.w r0,floats.tostr.buffer
2023-12-07 23:10:27 +01:00
returnr.w r0
}}
}
sub parse(str value) -> float {
2023-08-16 14:47:20 +02:00
; -- parse a string value of a number to float
%ir {{
loadm.w r65535,floats.parse.value
2023-08-16 14:47:20 +02:00
syscall 45 (r65535.w): fr0.f
returnr.f fr0
}}
}
sub pow(float value, float power) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.pow.value
loadm.f fr1,floats.pow.power
fpow.f fr0,fr1
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub sin(float angle) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.sin.angle
fsin.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
2022-04-30 00:10:07 +02:00
}}
}
sub cos(float angle) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.cos.angle
fcos.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub tan(float value) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.tan.value
ftan.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub atan(float value) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.atan.value
fatan.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub ln(float value) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.ln.value
fln.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub log2(float value) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.log2.value
2022-05-02 20:16:45 +02:00
flog.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub rad(float angle) -> float {
; -- convert degrees to radians (d * pi / 180)
return angle * PI / 180.0
}
sub deg(float angle) -> float {
; -- convert radians to degrees (d * (1/ pi * 180))
return angle * 180.0 / PI
}
sub round(float value) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.round.value
fround.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub floor(float value) -> float {
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.floor.value
ffloor.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub ceil(float value) -> float {
; -- ceil: tr = int(f); if tr==f -> return else return tr+1
%ir {{
2022-09-15 23:08:41 +02:00
loadm.f fr0,floats.ceil.value
fceil.f fr0,fr0
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub rnd() -> float {
%ir {{
syscall 35 () : fr0.f
2023-04-11 22:28:19 +02:00
returnr.f fr0
}}
}
sub rndseed(float seed) {
%ir {{
loadm.f fr65535,floats.rndseed.seed
syscall 32 (fr65535.f)
return
}}
}
2023-05-17 23:18:14 +02:00
sub minf(float f1, float f2) -> float {
if f1<f2
return f1
return f2
}
sub maxf(float f1, float f2) -> float {
if f1>f2
return f1
return f2
}
sub clampf(float value, float minimum, float maximum) -> float {
if value<minimum
value=minimum
if value<maximum
return value
return maximum
}
2023-12-05 22:54:35 +01:00
sub normalize(float value) -> float {
return value
}
sub push(float value) {
2023-12-26 15:30:18 +01:00
; note: this *should* be inlined, however since the VM has separate program counter and value stacks, this also works
%ir {{
loadm.f fr65535,floats.push.value
push.f fr65535
return
}}
}
sub pop() -> float {
2023-12-26 15:30:18 +01:00
; note: this *should* be inlined, however since the VM has separate program counter and value stacks, this also works
%ir {{
pop.f fr65535
returnr.f fr65535
}}
}
}