const int sampleRate = 8000; // Sampling rate (Hz)
const float speedOfSound = 343.0; // Kecepatan suara (m/s)
const float distance = 10.0; // Jarak antara speaker dan mikrofon (meter)
const int reflectionCount = 5; // Jumlah pantulan
const float reflectionDecay = 0.5; // Pelemahan per pantulan
const int maxIRLength = 1000; // Panjang maksimum impulse response
float impulseResponse[maxIRLength]; // Array untuk menyimpan impulse response
void setup() {
Serial.begin(115200);
// Inisialisasi array impulse response
for (int i = 0; i < maxIRLength; i++) {
impulseResponse[i] = 0.0;
}
// Hitung delay utama
int mainDelaySamples = (int)((distance / speedOfSound) * sampleRate);
if (mainDelaySamples < maxIRLength) {
impulseResponse[mainDelaySamples] = 1.0 / (distance * distance); // Amplitudo utama
}
Serial.print("mainDelaySamples: ");
Serial.println(mainDelaySamples);
// Tambahkan pantulan
for (int i = 1; i <= reflectionCount; i++) {
float reflectionDistance = distance + i; // Jarak tambahan pantulan
int reflectionDelaySamples = (int)((reflectionDistance / speedOfSound) * sampleRate);
if (reflectionDelaySamples < maxIRLength) {
impulseResponse[reflectionDelaySamples] +=
(reflectionDecay * i) / (reflectionDistance * reflectionDistance);
}
}
// Tampilkan impulse response
Serial.println("Impulse Response:");
for (int i = 0; i < maxIRLength; i++) {
if (impulseResponse[i] > 0) {
Serial.print("Sample ");
Serial.print(i);
Serial.print(": ");
Serial.println(impulseResponse[i], 6);
}
}
Serial.println("OK");
}
void loop() {
// Tidak ada operasi dalam loop
}
mega:SCL
mega:SDA
mega:AREF
mega:GND.1
mega:13
mega:12
mega:11
mega:10
mega:9
mega:8
mega:7
mega:6
mega:5
mega:4
mega:3
mega:2
mega:1
mega:0
mega:14
mega:15
mega:16
mega:17
mega:18
mega:19
mega:20
mega:21
mega:5V.1
mega:5V.2
mega:22
mega:23
mega:24
mega:25
mega:26
mega:27
mega:28
mega:29
mega:30
mega:31
mega:32
mega:33
mega:34
mega:35
mega:36
mega:37
mega:38
mega:39
mega:40
mega:41
mega:42
mega:43
mega:44
mega:45
mega:46
mega:47
mega:48
mega:49
mega:50
mega:51
mega:52
mega:53
mega:GND.4
mega:GND.5
mega:IOREF
mega:RESET
mega:3.3V
mega:5V
mega:GND.2
mega:GND.3
mega:VIN
mega:A0
mega:A1
mega:A2
mega:A3
mega:A4
mega:A5
mega:A6
mega:A7
mega:A8
mega:A9
mega:A10
mega:A11
mega:A12
mega:A13
mega:A14
mega:A15