math_basic_js.odin 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. //+build js
  2. package math
  3. import "base:intrinsics"
  4. foreign import "odin_env"
  5. @(default_calling_convention="c")
  6. foreign odin_env {
  7. @(link_name="sin", require_results)
  8. sin_f64 :: proc(θ: f64) -> f64 ---
  9. @(link_name="cos", require_results)
  10. cos_f64 :: proc(θ: f64) -> f64 ---
  11. @(link_name="pow", require_results)
  12. pow_f64 :: proc(x, power: f64) -> f64 ---
  13. @(link_name="fmuladd", require_results)
  14. fmuladd_f64 :: proc(a, b, c: f64) -> f64 ---
  15. @(link_name="ln", require_results)
  16. ln_f64 :: proc(x: f64) -> f64 ---
  17. @(link_name="exp", require_results)
  18. exp_f64 :: proc(x: f64) -> f64 ---
  19. }
  20. @(require_results)
  21. sqrt_f64 :: proc "contextless" (x: f64) -> f64 {
  22. return intrinsics.sqrt(x)
  23. }
  24. @(require_results) sqrt_f16 :: proc "c" (x: f16) -> f16 { return f16(sqrt_f64(f64(x))) }
  25. @(require_results) sin_f16 :: proc "c" (θ: f16) -> f16 { return f16(sin_f64(f64(θ))) }
  26. @(require_results) cos_f16 :: proc "c" (θ: f16) -> f16 { return f16(cos_f64(f64(θ))) }
  27. @(require_results) pow_f16 :: proc "c" (x, power: f16) -> f16 { return f16(pow_f64(f64(x), f64(power))) }
  28. @(require_results) fmuladd_f16 :: proc "c" (a, b, c: f16) -> f16 { return f16(fmuladd_f64(f64(a), f64(a), f64(c))) }
  29. @(require_results) ln_f16 :: proc "c" (x: f16) -> f16 { return f16(ln_f64(f64(x))) }
  30. @(require_results) exp_f16 :: proc "c" (x: f16) -> f16 { return f16(exp_f64(f64(x))) }
  31. @(require_results) sqrt_f32 :: proc "c" (x: f32) -> f32 { return f32(sqrt_f64(f64(x))) }
  32. @(require_results) sin_f32 :: proc "c" (θ: f32) -> f32 { return f32(sin_f64(f64(θ))) }
  33. @(require_results) cos_f32 :: proc "c" (θ: f32) -> f32 { return f32(cos_f64(f64(θ))) }
  34. @(require_results) pow_f32 :: proc "c" (x, power: f32) -> f32 { return f32(pow_f64(f64(x), f64(power))) }
  35. @(require_results) fmuladd_f32 :: proc "c" (a, b, c: f32) -> f32 { return f32(fmuladd_f64(f64(a), f64(a), f64(c))) }
  36. @(require_results) ln_f32 :: proc "c" (x: f32) -> f32 { return f32(ln_f64(f64(x))) }
  37. @(require_results) exp_f32 :: proc "c" (x: f32) -> f32 { return f32(exp_f64(f64(x))) }
  38. @(require_results) ln_f16le :: proc "contextless" (x: f16le) -> f16le { return #force_inline f16le(ln_f64(f64(x))) }
  39. @(require_results) ln_f16be :: proc "contextless" (x: f16be) -> f16be { return #force_inline f16be(ln_f64(f64(x))) }
  40. @(require_results) ln_f32le :: proc "contextless" (x: f32le) -> f32le { return #force_inline f32le(ln_f64(f64(x))) }
  41. @(require_results) ln_f32be :: proc "contextless" (x: f32be) -> f32be { return #force_inline f32be(ln_f64(f64(x))) }
  42. @(require_results) ln_f64le :: proc "contextless" (x: f64le) -> f64le { return #force_inline f64le(ln_f64(f64(x))) }
  43. @(require_results) ln_f64be :: proc "contextless" (x: f64be) -> f64be { return #force_inline f64be(ln_f64(f64(x))) }
  44. ln :: proc{
  45. ln_f16, ln_f16le, ln_f16be,
  46. ln_f32, ln_f32le, ln_f32be,
  47. ln_f64, ln_f64le, ln_f64be,
  48. }