2022-04-23 02:15:51 +02:00
|
|
|
; Prog8 definitions for floating point handling on the VirtualMachine
|
|
|
|
|
|
|
|
%option enable_floats
|
|
|
|
|
|
|
|
floats {
|
|
|
|
|
|
|
|
const float PI = 3.141592653589793
|
|
|
|
const float TWOPI = 6.283185307179586
|
|
|
|
|
|
|
|
sub print_f(float value) {
|
|
|
|
; ---- prints the floating point value (without a newline).
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2023-04-10 16:59:08 +02:00
|
|
|
loadm.f fr65535,floats.print_f.value
|
2023-05-12 23:26:36 +02:00
|
|
|
syscall 25 (fr65535.f)
|
2022-04-30 00:10:07 +02:00
|
|
|
return
|
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub pow(float value, float power) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.pow.value
|
|
|
|
loadm.f fr1,floats.pow.power
|
2022-05-11 22:09:46 +02:00
|
|
|
fpow.f fr0,fr1
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub sin(float angle) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.sin.angle
|
2022-05-01 00:09:03 +02:00
|
|
|
fsin.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-04-30 00:10:07 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub cos(float angle) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.cos.angle
|
2022-05-01 00:09:03 +02:00
|
|
|
fcos.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub tan(float value) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.tan.value
|
2022-05-01 00:09:03 +02:00
|
|
|
ftan.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub atan(float value) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.atan.value
|
2022-05-01 00:09:03 +02:00
|
|
|
fatan.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub ln(float value) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.ln.value
|
2022-05-01 00:09:03 +02:00
|
|
|
fln.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub log2(float value) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%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
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub rad(float angle) -> float {
|
|
|
|
; -- convert degrees to radians (d * pi / 180)
|
2022-05-01 00:09:03 +02:00
|
|
|
return angle * PI / 180.0
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub deg(float angle) -> float {
|
|
|
|
; -- convert radians to degrees (d * (1/ pi * 180))
|
2022-05-01 00:09:03 +02:00
|
|
|
return angle * 180.0 / PI
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub round(float value) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.round.value
|
2022-05-01 00:09:03 +02:00
|
|
|
fround.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub floor(float value) -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.floor.value
|
2022-05-01 00:09:03 +02:00
|
|
|
ffloor.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub ceil(float value) -> float {
|
|
|
|
; -- ceil: tr = int(f); if tr==f -> return else return tr+1
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2022-09-15 23:08:41 +02:00
|
|
|
loadm.f fr0,floats.ceil.value
|
2022-05-01 00:09:03 +02:00
|
|
|
fceil.f fr0,fr0
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub rndf() -> float {
|
2022-09-30 14:05:11 +02:00
|
|
|
%ir {{
|
2023-05-12 23:26:36 +02:00
|
|
|
syscall 35 () : fr0.f
|
2023-04-11 22:28:19 +02:00
|
|
|
returnr.f fr0
|
2022-05-01 00:09:03 +02:00
|
|
|
}}
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|
2022-10-22 13:33:35 +02:00
|
|
|
|
2022-11-06 22:41:23 +01:00
|
|
|
sub rndseedf(float seed) {
|
2022-10-22 13:33:35 +02:00
|
|
|
%ir {{
|
2023-04-10 16:59:08 +02:00
|
|
|
loadm.f fr65535,floats.rndseedf.seed
|
2023-05-12 23:26:36 +02:00
|
|
|
syscall 32 (fr65535.f)
|
|
|
|
return
|
2022-10-22 13:33:35 +02:00
|
|
|
}}
|
|
|
|
}
|
|
|
|
|
2023-05-17 23:03:59 +02:00
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-05-17 23:03:59 +02:00
|
|
|
sub clampf(float value, float minimum, float maximum) -> float {
|
|
|
|
if value<minimum
|
|
|
|
value=minimum
|
|
|
|
if value<maximum
|
|
|
|
return value
|
|
|
|
return maximum
|
|
|
|
}
|
|
|
|
|
2022-04-23 02:15:51 +02:00
|
|
|
}
|