zig/lib/std/math/nan.zig
2023-05-10 15:16:50 -04:00

21 lines
656 B
Zig

const math = @import("../math.zig");
/// Returns the nan representation for type T.
pub inline fn nan(comptime T: type) T {
return switch (math.floatBits(T)) {
16 => math.nan_f16,
32 => math.nan_f32,
64 => math.nan_f64,
80 => math.nan_f80,
128 => math.nan_f128,
else => @compileError("unknown floating point type " ++ @typeName(T)),
};
}
/// Returns the signalling nan representation for type T.
/// Note: A signalling nan is identical to a standard right now by may have a different bit
/// representation in the future when required.
pub inline fn snan(comptime T: type) T {
return nan(T);
}