2025-12-13 07:34:01 +00:00
|
|
|
import {iterateBinary, ReturnsAs} from './helpers.js'
|
|
|
|
|
import {plain} from "#number/helpers.js"
|
2025-04-28 16:29:33 +00:00
|
|
|
|
2025-05-07 00:03:49 +00:00
|
|
|
import {Returns, ReturnType, ReturnTyping} from '#core/Type.js'
|
2025-04-25 14:17:34 +00:00
|
|
|
import {match, Any} from '#core/TypePatterns.js'
|
2025-04-08 23:25:01 +00:00
|
|
|
|
2025-05-07 00:03:49 +00:00
|
|
|
export const norm = match(Any, (math, T) => {
|
|
|
|
|
const normsq = math.normsq.resolve(T)
|
|
|
|
|
const sqrt = math.sqrt.resolve(
|
|
|
|
|
ReturnType(normsq), ReturnTyping.conservative)
|
|
|
|
|
return ReturnsAs(sqrt, t => sqrt(normsq(t)))
|
2025-04-28 16:29:33 +00:00
|
|
|
})
|
2025-05-07 00:03:49 +00:00
|
|
|
|
|
|
|
|
export const abs = norm // coincide for most types (scalars)
|
|
|
|
|
|
2025-04-28 16:29:33 +00:00
|
|
|
export const conj = match(Any, (_math, T) => Returns(T, t => t))
|
2025-05-07 00:03:49 +00:00
|
|
|
|
2025-04-28 16:29:33 +00:00
|
|
|
export const square = match(Any, (math, T, strategy) => {
|
|
|
|
|
const mult = math.multiply.resolve([T, T], strategy)
|
2025-05-07 00:03:49 +00:00
|
|
|
return ReturnsAs(mult, t => mult(t, t))
|
2025-04-08 23:25:01 +00:00
|
|
|
})
|
2025-12-13 07:34:01 +00:00
|
|
|
|
|
|
|
|
export const add = iterateBinary('add')
|
|
|
|
|
add.push(plain(() => 0))
|
|
|
|
|
|
|
|
|
|
export const multiply = iterateBinary('multiply')
|
|
|
|
|
multiply.push(plain(() => 1))
|