2023-01-22 01:34:57 +00:00
|
|
|
import type {configDependency} from '../core/Config.js'
|
2023-10-16 02:58:38 +00:00
|
|
|
import type {Dependencies, Signature, RTT, DSignature} from '../interfaces/type.js'
|
|
|
|
import {$reflect, $Dreflect} from '../interfaces/type.js'
|
2023-01-22 01:34:57 +00:00
|
|
|
|
2023-10-16 02:58:38 +00:00
|
|
|
export const add: Signature<'add', number> & RTT = (a, b) => a + b
|
2023-01-22 01:34:57 +00:00
|
|
|
export const unaryMinus: Signature<'unaryMinus', number> = a => -a
|
2023-10-16 02:58:38 +00:00
|
|
|
export const conj: DSignature<'conj', number> = a => a
|
|
|
|
export const subtract = (): Signature<'subtract', number> => (a, b) => a - b
|
2023-01-22 01:34:57 +00:00
|
|
|
export const multiply: Signature<'multiply', number> = (a, b) => a * b
|
|
|
|
export const absquare: Signature<'absquare', number> = a => a * a
|
|
|
|
export const reciprocal: Signature<'reciprocal', number> = a => 1 / a
|
|
|
|
export const divide: Signature<'divide', number> = (a, b) => a / b
|
|
|
|
|
2023-09-29 13:36:22 +00:00
|
|
|
const basicSqrt = (a: number) => isNaN(a) ? NaN : Math.sqrt(a)
|
2023-01-22 01:34:57 +00:00
|
|
|
export const conservativeSqrt: Signature<'conservativeSqrt', number> = basicSqrt
|
2022-12-07 01:21:05 +00:00
|
|
|
|
2023-09-30 22:52:14 +00:00
|
|
|
export const sqrt =
|
|
|
|
(dep: configDependency
|
|
|
|
& Dependencies<'complex', number>): Signature<'sqrt', number> => {
|
2023-09-21 13:02:42 +00:00
|
|
|
if (dep.config.predictable || !dep.complex) {
|
|
|
|
return basicSqrt
|
|
|
|
}
|
|
|
|
return a => {
|
|
|
|
if (isNaN(a)) return NaN
|
|
|
|
if (a >= 0) return Math.sqrt(a)
|
|
|
|
return dep.complex(0, Math.sqrt(unaryMinus(a)))
|
|
|
|
}
|
2023-10-10 04:10:15 +00:00
|
|
|
}
|
2023-10-16 02:58:38 +00:00
|
|
|
$reflect!([add, sqrt, subtract])
|
|
|
|
$Dreflect!([conj])
|