summaryrefslogtreecommitdiff
path: root/src/tests/test_dct.cc
blob: b40f392cf93f245ccd8bfa8743df94510f9dd0c1 (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
// This file is part of the 64k demo project.
// It tests the DCT implementation for correctness and coverage.

#include "audio/dct.h"
#include <vector>
#include <cmath>
#include <cassert>
#include <iostream>
#include <cstdlib>

void test_fdct_idct() {
    float input[DCT_SIZE];
    float freq[DCT_SIZE];
    float output[DCT_SIZE];

    // Initialize with random data
    srand(12345); // Fixed seed for reproducibility
    for (int i = 0; i < DCT_SIZE; ++i) {
        input[i] = (float)rand() / RAND_MAX * 2.0f - 1.0f;
    }

    fdct_512(input, freq);
    idct_512(freq, output);

    // Verify reconstruction
    float max_error = 0.0f;
    for (int i = 0; i < DCT_SIZE; ++i) {
        float err = std::abs(input[i] - output[i]);
        if (err > max_error) max_error = err;
    }
    std::cout << "Max reconstruction error: " << max_error << std::endl;
    
    // Allow some error due to float precision and iterative sum
    // 512 sums can accumulate error.
    assert(max_error < 1e-4f);
}

int main() {
    std::cout << "Running DCT tests..." << std::endl;
    test_fdct_idct();
    std::cout << "DCT tests PASSED" << std::endl;
    return 0;
}