Схема влючения простая. Вход АЦП (PB4) зашунтирован на обший резистором 68 Ом и конденсатором 1000 мкф. Осциллограф и тестер утверждают, что там 0 В. Да и по уму ничему другому там взяться неоткуда. Плата мытая. Результатом преобразования имеем значение 15 или около того. Вход АЦП (PB3) зашунтирован на общий резистором 4,7 кОм. Картина примерно таже самая. Суть проблемы в целом такова, что на нижнем пределе нет устойчивой однозначности результата преобразования. Плавно изменяющееся напряжение, снятое с RC-цепочки (время изменения от 1,03 В до 0 В примерно 1,5 с) демонстрирует даже какое-то подмигивание перед выключением светодиода, но не всегда а только примерно в 20% случаев. Из 10 значащих бит АЦП использую только старшие 8. Монтаж СМД, перекосов общего провода вродебы нет. Контроллер управляет MOSFETами, а они светодиодами. Яркость светодиодов управляется аппаратным ШИМом от таймера. Ну вобщем суть вопроса в том, как избавиться от миганий светодиода при нижних значениях яркости, в т.ч. и при нулевой яркости? Спасибо.
Код
volatile unsigned int c1,c2,adc_data;
volatile unsigned char t1,t2,flag1,flag2;
unsigned int read_adc(unsigned char adc_input)
{
ADMUX=adc_input | 0b01100000;
ADCSRA |= (1<<ADSC); //начать преобразование
while (!(ADCSRA & (1<<ADIF))) {asm("nop");}; //ждем появления флага завершения преобр.
ADCSRA |= (1<<ADIF);//сбросить флаг
//return ADCW;
return ADCH;
}
ISR(TIM0_OVF_vect)
{
if(flag1==1)
{
OCR0A=t1;
flag1=0;
}
if(flag2==1)
{
OCR0B=t2;
flag2=0;
}
}
int main(void)
{
PORTB = 0b00000000;
DDRB = 0b00000111;
OCR0A = 0;
OCR0B = 0;
TCNT0 = 0x01; //set count
TCCR0A = 0b10100001;
TCCR0B = 0b00000100; //start timer
TIMSK0 = 0b00000010;
DIDR0=0b00011000;
ACSR = 0x80;//компаратор выключить
ADCSRA = 0b10000110;
asm("sei");
while(1)
{
if(flag1==0)
{
adc_data=read_adc(2);
c1=0;
for(unsigned char i=0; i<250; i++)
{
adc_data=read_adc(2);
if(adc_data>c1) c1=adc_data;
}
t1=(unsigned char)c1;
if(c1>=250) t1=255;
if(c1<4) t1=0;
flag1=1;
}
if(flag2==0)
{
adc_data=read_adc(3);
c2=0;
for(unsigned char i=0; i<250; i++)
{
adc_data=read_adc(3);
if(adc_data>c2) c2=adc_data;
}
t2=(unsigned char)c2;
if(c2>=250) t2=255;
if(c2<10) t2=0;
flag2=1;
}
// OCR0A=pgm_read_byte(&brightness[t1]);
// OCR0B=pgm_read_byte(&brightness[t2]);
asm("nop");
}
return 0;
}
sigmaN
Oct 24 2010, 13:28
так вам от подмигивания избавиться или со странным поведением ацп разобраться?
А все остальные требования соблюдаются? Ну там филтрация опорного и AVCC....
Вообще странно как-то...
и то и то. Я так понимаю они взаимосвязаны. Опора внутренняя. По питанию 100н и 1000мкф. Стабилизатор LM2940-5. У tiny13 нет AVCC.
Скажите, а последовательно со светодиодами включили резисторы или индуктивность и какого номинала? В смысле интересует ток через светодиоды в импульсе.
660 Ом (2х330) при питании в 9 В. Питание ровное. Все как положено. Весь предидущий опыт (а он есть) говорит о том, что все собрано правильно. Замеры тоже. Вообще больше всего удручает, что при замкнутом входе имеем ненулевые показания АЦП.
rx3apf
Oct 24 2010, 15:41
Цитата(smk @ Oct 24 2010, 19:29)

660 Ом (2х330) при питании в 9 В. Питание ровное. Все как положено. Весь предидущий опыт (а он есть) говорит о том, что все собрано правильно. Замеры тоже. Вообще больше всего удручает, что при замкнутом входе имеем ненулевые показания АЦП.
Сделайте другой макет, никаких внешних устройств, вход ADC на "землю", и смотрите, что намеряет ADC. Если больше 3-4 единиц - это что-то неправильное...
А в затворах МОСФЕТов какие резисторы? Выглядит так, как будто периодически АЦП говорит, что на его входе 0,5-0,6В, программа четко ловит эти моменты за счет отбора самых больших отсчетов... Или накладываются какие-то короткие всплески, или проблемы с кристаллом... А частота тактирования какая?
сколько встречал, в том числе и в даташитах, всюду конец преобразования определяют по "падению" бита ADSC, а не по установке ADIF. сам всегда так делал и никогда никаких подозрительных вариаций показаний АЦП не видел. может, собака тут порылась? объяснений такого подхода не встречал (но и не искал) - неужели причина лишь в том, что его сбрасывать надо перед очередным замером?!
rx3apf
Oct 24 2010, 17:44
Цитата(ARV @ Oct 24 2010, 21:29)

сколько встречал, в том числе и в даташитах, всюду конец преобразования определяют по "падению" бита ADSC, а не по установке ADIF. сам всегда так делал и никогда никаких подозрительных вариаций показаний АЦП не видел. может, собака тут порылась? объяснений такого подхода не встречал (но и не искал) - неужели причина лишь в том, что его сбрасывать надо перед очередным замером?!
Исключено. А обработка по ADSC - это когда обработка по опросу, ADIF да, надо сбрасывать. Если же обработка по прерываниям - то само собой по ADIF. Но никак это все не может быть связано с таким сильным смещением показаний.
ILYAUL
Oct 24 2010, 18:52
Цитата
на обший резистором 68 Ом и конденсатором 1000 мкф
Зашунтируйте это все перемычкой и посмотрите показания АЦП
domowoj
Oct 25 2010, 00:53
Я не силен в СИ, но не вижу "засыпания" на время преобразования АЦП.
И еще.
Можно сделать несколько измерений и усреднить результат.
И зачем в п\п прерывания вот это
"ADCSRA |= (1<<ADSC); //начать преобразование
while (!(ADCSRA & (1<<ADIF))) {asm("nop");}; //ждем появления флага завершения преобр.
ADCSRA |= (1<<ADIF);//сбросить флаг "
преобразование у вас уже начато,
и флаг сбросится автоматически по выходе из прерывания,
почитайте хотя бы у Евстифеева про АЦП.
Цитата(smk @ Oct 24 2010, 12:14)

Суть проблемы в целом такова, что на нижнем пределе нет устойчивой однозначности результата преобразования
Возможно, дело в том, что вы меняете номер канала слишком быстро. Для смены канала по паспорту должен пройти по крайней мере один импульс клока АЦП (с.86 док. 2535), для вашей программы он составляет 64 такта. Попробуйте увеличить частоту клока АЦП, либо поставьте задержки в нужных местах.
Резисторы в цепи затворов 68 Ом. MOSFET IRL520. Закоротка входа не дает ничего. На счет переключения каналов, ставил задержку 0,1 с, убирал переключение вообще - изменений небыло. Наверно действительно нужно собрать на другом контроллере с внешней опорой и отдельным питанием аналоговой части. Есть такое наблюдение - после прошивки иногда бывает все правильно, АЦП выдает ноль, но по прошествии времени опять не ноль причем в хаотическом порядке. Или после включения ноль, подать-снять входное напряжение, опять хаотические ненулевые показания.
В первом посте Вы написали что у Вас еть осцилограф, что он показывает на шине +5В?
Анатолий.
ArtemKAD
Oct 26 2010, 10:54
Цитата
660 Ом (2х330) при питании в 9 В.
Подробнее, пли-из, как подключен светодиод!? Причем тут 9В?
ЗЫ. А вообще - нет ли у тебя на ногах МК напряжения более чем на 0,2В выше напряжения питания. Если есть - убери. А затем посмотри на результат...
TechMike
Oct 26 2010, 11:59
Делал год назад показометр на трех светодиодах, что-то вроде вольтметра с тремя порогами.
В результате пришлось делать макетку под строго определенные элементы и соблюдать правильную разводку платы.
Пришлось програмно: усереднять значения АЦП (среднее из 100 выборок), выключать АЦП в моменты переключения светодиодов, разбить пороги включение/выключения разных светодиодов с зонами тишины, т.е. переключаются не сразу, а есть некий разрыв в значении АЦП при переключении.
Аппаратно: применить внешний правильный опорник lp2950, на входе ацп поставить резисторы делителя 1%.
Температурную нестабильность не мерил, нов озможно в будущем придется с этим бороться.
P.S. Показания АЦП будут скакать всегда, нужно с этим бороться. Девайс был коммерческий.
domowoj
Oct 26 2010, 16:30
Цитата(TechMike @ Oct 26 2010, 18:59)

Аппаратно: применить внешний правильный опорник lp2950, на входе ацп поставить резисторы делителя 1%.
У Тини 13 нет внешнего опорного
Цитата(smk @ Oct 24 2010, 16:14)

Схема влючения простая. Вход АЦП (PB4) зашунтирован на обший резистором 68 Ом и конденсатором 1000 мкф.
Вы наверное перепутали ёмкость на порядок
Цитата(smk @ Oct 26 2010, 09:03)

Закоротка входа не дает ничего. На счет переключения каналов, ставил задержку 0,1 с, убирал переключение вообще - изменений небыло.
Попробуйте на время преобразования остановить АЛУ
Почитайте про калибровку АЦП в апноутах Атмела, там написано про смещение нуля (когда закоротка на входе АЦП не дает 0 в результате преобразования), нелинейность передаточной характеристики и т.п. и описаны методы компенсации этих особенностей конкретного экземпляра МК.
Переделал все на Мегу8 с выводом АЦП в порт компа. Дествительно редко когда ноль. Обычно 1 при короткозамкнутом входе. 0 тоже бывает. Это при внутренней опоре и внешнем конденсаторе 220нФ. Удиволо то, что при внешней опоре (TL431) значение АЦП при короткозамкнутом входе оказалось 4-5.
TechMike
Nov 22 2010, 19:52
Цитата(domowoj @ Oct 26 2010, 19:30)

У Тини 13 нет внешнего опорного
Опорное=питанию.
Для просмотра полной версии этой страницы, пожалуйста,
пройдите по ссылке.