extrapolate parity if we cannot trust the separator

pull/11/head
Ahmet Inan 2024-04-24 17:02:42 +02:00
rodzic 475b0198c5
commit acd7a59bc9
1 zmienionych plików z 5 dodań i 0 usunięć

Wyświetl plik

@ -17,6 +17,7 @@ public class Robot_36_Color implements Mode {
private final int separatorBeginSamples; private final int separatorBeginSamples;
private final int chrominanceBeginSamples; private final int chrominanceBeginSamples;
private final int endSamples; private final int endSamples;
private boolean lastEven;
@SuppressWarnings("UnnecessaryLocalVariable") @SuppressWarnings("UnnecessaryLocalVariable")
Robot_36_Color(int sampleRate) { Robot_36_Color(int sampleRate) {
@ -66,7 +67,11 @@ public class Robot_36_Color implements Mode {
for (int i = 0; i < separatorSamples; ++i) for (int i = 0; i < separatorSamples; ++i)
separator += scanLineBuffer[prevPulseIndex + separatorBeginSamples + i]; separator += scanLineBuffer[prevPulseIndex + separatorBeginSamples + i];
separator /= separatorSamples; separator /= separatorSamples;
separator -= frequencyOffset;
boolean even = separator < 0; boolean even = separator < 0;
if (separator < -1.1 || separator > -0.9 && separator < 0.9 || separator > 1.1)
even = !lastEven;
lastEven = even;
lowPassFilter.cutoff(evenBuffer.length, 2 * luminanceSamples, 2); lowPassFilter.cutoff(evenBuffer.length, 2 * luminanceSamples, 2);
lowPassFilter.reset(); lowPassFilter.reset();
for (int i = prevPulseIndex + beginSamples; i < prevPulseIndex + endSamples; ++i) for (int i = prevPulseIndex + beginSamples; i < prevPulseIndex + endSamples; ++i)