/* output_utils.c - Common output formatting implementations */

#include "output_utils.h"
#include <stdio.h>

// Output tokenization results in standard format
void output_tokenization_results(
    const char *tokenizer_type,
    uint64_t packet_arrival_time,
    uint64_t tokenize_end_time,
    uint64_t tsc_frequency,
    const char *original_text,
    int num_tokens,
    char tokens[][256],
    int token_ids[]
) {
    printf("%s_TOKENIZATION_START\n", tokenizer_type);
    printf("PACKET_ARRIVAL_TIME: %lu\n", packet_arrival_time);
    printf("TOKENIZE_END_TIME: %lu\n", tokenize_end_time);
    printf("TSC_FREQUENCY: %lu\n", tsc_frequency);
    printf("ORIGINAL_TEXT: %s\n", original_text);
    printf("NUM_TOKENS: %d\n", num_tokens);
    printf("TOKENS: ");
    for (int i = 0; i < num_tokens; i++) {
        printf("%s", tokens[i]);
        if (i < num_tokens - 1) printf(" ");
    }
    printf("\n");
    printf("TOKEN_IDS: ");
    for (int i = 0; i < num_tokens; i++) {
        printf("%d", token_ids[i]);
        if (i < num_tokens - 1) printf(" ");
    }
    printf("\n");
    printf("%s_TOKENIZATION_END\n", tokenizer_type);
    fflush(stdout);
}

// Calculate and print latency
void print_latency(const char *tokenizer_type, uint64_t start_cycles, uint64_t end_cycles, uint64_t tsc_frequency) {
    double total_latency_us = (double)(end_cycles - start_cycles) * 1000000.0 / tsc_frequency;
    fprintf(stderr, "%s_LATENCY: %.2f us\n", tokenizer_type, total_latency_us);
}

// Start JSON output for a single tokenization result
void output_tokenization_result_start(uint64_t packet_number) {
    printf("{\n");
    printf("  \"packet_number\": %lu,\n", packet_number);
}

// End JSON output for a single tokenization result
void output_tokenization_result_end(void) {
    printf("}\n");
    fflush(stdout);
}
