aboutsummaryrefslogtreecommitdiff
path: root/lib/std/unicode/throughput_test.zig
blob: 7265361b31f2b9cafa67918d8b68a8903b25abe3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
const builtin = @import("builtin");
const std = @import("std");

pub fn main() !void {
    const stdout = &std.io.getStdOut().outStream().stream;

    const args = try std.process.argsAlloc(std.heap.page_allocator);

    // Warm up runs
    var buffer0: [32767]u16 align(4096) = undefined;
    _ = try std.unicode.utf8ToUtf16Le(&buffer0, args[1]);
    _ = try std.unicode.utf8ToUtf16Le_better(&buffer0, args[1]);

    @fence(.SeqCst);
    var timer = try std.time.Timer.start();
    @fence(.SeqCst);

    var buffer1: [32767]u16 align(4096) = undefined;
    _ = try std.unicode.utf8ToUtf16Le(&buffer1, args[1]);

    @fence(.SeqCst);
    const elapsed_ns_orig = timer.lap();
    @fence(.SeqCst);

    var buffer2: [32767]u16 align(4096) = undefined;
    _ = try std.unicode.utf8ToUtf16Le_better(&buffer2, args[1]);

    @fence(.SeqCst);
    const elapsed_ns_better = timer.lap();
    @fence(.SeqCst);

    std.debug.warn("original utf8ToUtf16Le: elapsed: {} ns ({} ms)\n", .{
        elapsed_ns_orig, elapsed_ns_orig / 1000000,
    });
    std.debug.warn("new utf8ToUtf16Le: elapsed: {} ns ({} ms)\n", .{
        elapsed_ns_better, elapsed_ns_better / 1000000,
    });
    asm volatile ("nop"
        :
        : [a] "r" (&buffer1),
          [b] "r" (&buffer2)
        : "memory"
    );
}