Цитата(zombi @ Mar 5 2016, 16:52)

А почему интервалы между "вспомогательные импульсы" разные?
Эти вспомогательные импульсы формируются тоже в цикле "for(i=0; i < 16; i++)", просто в моем первом посте я для упрощения кода их не показал. А интервалы между ними разные потому что эти интервалы зависят от количества сдвигаемых разрядов в данный момент цикла, т.е. от 15 до 0.
Цитата(controller_m30 @ Mar 5 2016, 16:52)

Приведите ещё настройки всех регистров компаратора и Таймера_1.
Настройки регистров были произведены с помощью CodeVizardAVR:
CODE
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: 8000,000 kHz
// Mode: Normal top=FFFFh
// OC1A output: Discon.
// OC1B output: Discon.
// Noise Canceler: Off
// Input Capture on Rising Edge
// Timer1 Overflow Interrupt: Off
// Input Capture Interrupt: On
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=0x00;
TCCR1B=0x41;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x20;
// Analog Comparator initialization
// Analog Comparator: On
// Analog Comparator Input Capture by Timer/Counter 1: On
ACSR=0x04;
SFIOR=0x00;
Цитата(controller_m30 @ Mar 5 2016, 16:52)

А ещё, если так можно, пусть программа прерывания TC1, выводит каждый раз не вычисленную разность, а просто текущее значение ICR1, которое там зафиксировалось. Желательно, чтоб на скрине поместилось два подряд идущих числа - чтоб можно было самим оценивать и их разность, и при этом видеть абсолютное значение каждого числа. Может это что-то подскажет...
Можно будет так попробовать. Но только уже после выходных...