File: test_silence_remover.cpp

package info (click to toggle)
chromaprint 1.6.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,336 kB
  • sloc: cpp: 58,922; python: 4,402; ansic: 3,461; sh: 440; makefile: 366
file content (47 lines) | stat: -rw-r--r-- 1,324 bytes parent folder | download | duplicates (6)
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
45
46
47
#include <gtest/gtest.h>
#include <algorithm>
#include <vector>
#include <fstream>
#include "test_utils.h"
#include "silence_remover.h"
#include "audio_buffer.h"
#include "utils.h"

using namespace chromaprint;

TEST(SilenceRemover, PassThrough)
{
	short samples[] = { 1000, 2000, 3000, 4000, 5000, 6000 };
	std::vector<short> data(samples, samples + NELEMS(samples));

	AudioBuffer buffer;
	SilenceRemover processor(&buffer);
	processor.Reset(44100, 1);
	processor.Consume(data.data(), data.size());
	processor.Flush();

	ASSERT_EQ(data.size(), buffer.data().size());
	for (size_t i = 0; i < data.size(); i++) {
		ASSERT_EQ(data[i], buffer.data()[i]) << "Signals differ at index " << i;
	}
}

TEST(SilenceRemover, RemoveLeadingSilence)
{
	short samples1[] = { 0, 60, 0, 1000, 2000, 0, 4000, 5000, 0 };
	std::vector<short> data1(samples1, samples1 + NELEMS(samples1));

	short samples2[] = { 1000, 2000, 0, 4000, 5000, 0 };
	std::vector<short> data2(samples2, samples2 + NELEMS(samples2));

	AudioBuffer buffer;
	SilenceRemover processor(&buffer, 100);
	processor.Reset(44100, 1);
	processor.Consume(data1.data(), data1.size());
	processor.Flush();

	ASSERT_EQ(data2.size(), buffer.data().size());
	for (size_t i = 0; i < data2.size(); i++) {
		ASSERT_EQ(data2[i], buffer.data()[i]) << "Signals differ at index " << i;
	}
}