Function log10_int [src]

Alias for std.math.log10.log10_int

Return the log base 10 of integer value x, rounding down to the nearest integer.

Prototype

pub fn log10_int(x: anytype) std.math.Log2Int(@TypeOf(x))

Example

test log10_int { if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO if (builtin.zig_backend == .stage2_c) return error.SkipZigTest; // TODO if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO if (builtin.zig_backend == .stage2_sparc64) return error.SkipZigTest; // TODO if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO if (builtin.zig_backend == .stage2_llvm and comptime builtin.target.cpu.arch.isWasm()) return error.SkipZigTest; // TODO inline for ( .{ u8, u16, u32, u64, u128, u256, u512 }, .{ 2, 4, 9, 19, 38, 77, 154 }, ) |T, max_exponent| { for (0..max_exponent + 1) |exponent_usize| { const exponent: std.math.Log2Int(T) = @intCast(exponent_usize); const power_of_ten = try std.math.powi(T, 10, exponent); if (exponent > 0) { try testing.expectEqual(exponent - 1, log10_int(power_of_ten - 9)); try testing.expectEqual(exponent - 1, log10_int(power_of_ten - 1)); } try testing.expectEqual(exponent, log10_int(power_of_ten)); try testing.expectEqual(exponent, log10_int(power_of_ten + 1)); try testing.expectEqual(exponent, log10_int(power_of_ten + 8)); } try testing.expectEqual(max_exponent, log10_int(@as(T, std.math.maxInt(T)))); } }

Source

pub fn log10_int(x: anytype) std.math.Log2Int(@TypeOf(x)) { const T = @TypeOf(x); const OutT = std.math.Log2Int(T); if (@typeInfo(T) != .int or @typeInfo(T).int.signedness != .unsigned) @compileError("log10_int requires an unsigned integer, found " ++ @typeName(T)); std.debug.assert(x != 0); const bit_size = @typeInfo(T).int.bits; if (bit_size <= 8) { return @as(OutT, @intCast(log10_int_u8(x))); } else if (bit_size <= 16) { return @as(OutT, @intCast(less_than_5(x))); } var val = x; var log: u32 = 0; inline for (0..11) |i| { // Unnecessary branches should be removed by the compiler if (bit_size > (1 << (11 - i)) * 5 * @log2(10.0) and val >= pow10((1 << (11 - i)) * 5)) { const num_digits = (1 << (11 - i)) * 5; val /= pow10(num_digits); log += num_digits; } } if (val >= pow10(5)) { val /= pow10(5); log += 5; } return @as(OutT, @intCast(log + less_than_5(@as(u32, @intCast(val))))); }