This commit is contained in:
42
docs/snippets/zig/advanced/token_reduction_example.md
Normal file
42
docs/snippets/zig/advanced/token_reduction_example.md
Normal file
@@ -0,0 +1,42 @@
|
||||
```zig title="Zig"
|
||||
const std = @import("std");
|
||||
const kreuzberg = @import("kreuzberg");
|
||||
|
||||
pub fn main() !void {
|
||||
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
|
||||
defer _ = gpa.deinit();
|
||||
const allocator = gpa.allocator();
|
||||
|
||||
const config_json =
|
||||
\\{
|
||||
\\ "token_reduction": {
|
||||
\\ "mode": "moderate",
|
||||
\\ "preserve_important_words": true
|
||||
\\ }
|
||||
\\}
|
||||
;
|
||||
|
||||
const result_json = try kreuzberg.extract_file_sync("verbose_document.pdf", null, config_json);
|
||||
defer std.heap.c_allocator.free(result_json);
|
||||
|
||||
var parsed = try std.json.parseFromSlice(std.json.Value, allocator, result_json, .{});
|
||||
defer parsed.deinit();
|
||||
|
||||
const root = parsed.value;
|
||||
if (root != .object) return;
|
||||
|
||||
const stdout = std.io.getStdOut().writer();
|
||||
|
||||
if (root.object.get("original_token_count")) |val| {
|
||||
if (val == .integer) {
|
||||
try stdout.print("Original tokens: {d}\n", .{val.integer});
|
||||
}
|
||||
}
|
||||
|
||||
if (root.object.get("reduced_token_count")) |val| {
|
||||
if (val == .integer) {
|
||||
try stdout.print("Reduced tokens: {d}\n", .{val.integer});
|
||||
}
|
||||
}
|
||||
}
|
||||
```
|
||||
Reference in New Issue
Block a user