Помогите создать проект с АЦП и ШИМ на Аттини13
Добавлено: Ср мар 09, 2022 15:55:15
Друзья, здравствуйте. Помогите советом! Вопрос конечно глупый, но вспомните себя, когда учились!
Пришло время создавать нечто более серьезное, чем мигающие светодиоды. В общем, требуется создать регулятор яркости лампы в зависимости от положения движка потенциометра. В простейшем случае используем светодиод (когда научусь писать код, поставлю туда транзистор).
Итак. У единственного в Аттини 13 таймер/счетчика Т0 включаем режим "быстрый ШИМ", к выходу его OC0B подключаем светодиод (см. рис). До сих пор яркость задавали прописыванием в регистр OC0B какого то числа от 0 до 120, например, 90, которое и определяло скважность ШИМ-сигнала, а стало быть, и яркость светодиода.
Теперь хочу регулировать яркость потенциометром. Подключаем его к 2 ножке (ADC3)? включаем АЦП. Результат этого АЦП должен быть занесен в регистр OC0B (?)
По факту ничего не работает. Что я делаю не так?
Код программы Code Vision
#include <tiny13a.h>
#include <delay.h>
#define ADC_VREF_TYPE 0x20
// Read the 8 most significant bits
// of the AD conversion result
unsigned char read_adc(unsigned char adc_input)
{
ADMUX=adc_input | (ADC_VREF_TYPE & 0xff);
// Delay needed for the stabilization of the ADC input voltage
delay_us(10);
// Start the AD conversion
ADCSRA|=0x40;
// Wait for the AD conversion to complete
while ((ADCSRA & 0x10)==0);
ADCSRA|=0x10;
return ADCH;
}
// Declare your global variables here
void main(void)
{
// Declare your local variables here
// Crystal Oscillator division factor: 1
#pragma optsize-
CLKPR=0x80;
CLKPR=0x00;
#ifdef _OPTIMIZE_SIZE_
#pragma optsize+
#endif
// Input/Output Ports initialization
// Port B initialization
// Func5=Out Func4=Out Func3=In Func2=Out Func1=Out Func0=Out
// State5=0 State4=0 State3=T State2=0 State1=0 State0=0
PORTB=0x00;
DDRB=0x37;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: 4,688 kHz
// Mode: Fast PWM top=0xFF
// OC0A output: Non-Inverted PWM
// OC0B output: Non-Inverted PWM
TCCR0A=0xA3;
TCCR0B=0x04;
TCNT0=0x00;
OCR0A=ADCH;
OCR0B=ADCH;
// External Interrupt(s) initialization
// INT0: Off
// Interrupt on any change on pins PCINT0-5: Off
GIMSK=0x00;
MCUCR=0x00;
// Timer/Counter 0 Interrupt(s) initialization
TIMSK0=0x00;
// Analog Comparator initialization
// Analog Comparator: Off
ACSR=0x80;
ADCSRB=0x00;
DIDR0=0x00;
// ADC initialization
// ADC Clock frequency: 300,000 kHz
// ADC Bandgap Voltage Reference: Off
// ADC Auto Trigger Source: Free Running
// Only the 8 most significant bits of
// the AD conversion result are used
// Digital input buffers on ADC0: On, ADC1: On, ADC2: On, ADC3: On
DIDR0&=0x03;
DIDR0|=0x00;
ADMUX=ADC_VREF_TYPE & 0xff;
ADCSRA=0xA2;
ADCSRB&=0xF8;
while (1)
{
// Place your code here
}
}
Пришло время создавать нечто более серьезное, чем мигающие светодиоды. В общем, требуется создать регулятор яркости лампы в зависимости от положения движка потенциометра. В простейшем случае используем светодиод (когда научусь писать код, поставлю туда транзистор).
Итак. У единственного в Аттини 13 таймер/счетчика Т0 включаем режим "быстрый ШИМ", к выходу его OC0B подключаем светодиод (см. рис). До сих пор яркость задавали прописыванием в регистр OC0B какого то числа от 0 до 120, например, 90, которое и определяло скважность ШИМ-сигнала, а стало быть, и яркость светодиода.
Теперь хочу регулировать яркость потенциометром. Подключаем его к 2 ножке (ADC3)? включаем АЦП. Результат этого АЦП должен быть занесен в регистр OC0B (?)
По факту ничего не работает. Что я делаю не так?
Код программы Code Vision
#include <tiny13a.h>
#include <delay.h>
#define ADC_VREF_TYPE 0x20
// Read the 8 most significant bits
// of the AD conversion result
unsigned char read_adc(unsigned char adc_input)
{
ADMUX=adc_input | (ADC_VREF_TYPE & 0xff);
// Delay needed for the stabilization of the ADC input voltage
delay_us(10);
// Start the AD conversion
ADCSRA|=0x40;
// Wait for the AD conversion to complete
while ((ADCSRA & 0x10)==0);
ADCSRA|=0x10;
return ADCH;
}
// Declare your global variables here
void main(void)
{
// Declare your local variables here
// Crystal Oscillator division factor: 1
#pragma optsize-
CLKPR=0x80;
CLKPR=0x00;
#ifdef _OPTIMIZE_SIZE_
#pragma optsize+
#endif
// Input/Output Ports initialization
// Port B initialization
// Func5=Out Func4=Out Func3=In Func2=Out Func1=Out Func0=Out
// State5=0 State4=0 State3=T State2=0 State1=0 State0=0
PORTB=0x00;
DDRB=0x37;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: 4,688 kHz
// Mode: Fast PWM top=0xFF
// OC0A output: Non-Inverted PWM
// OC0B output: Non-Inverted PWM
TCCR0A=0xA3;
TCCR0B=0x04;
TCNT0=0x00;
OCR0A=ADCH;
OCR0B=ADCH;
// External Interrupt(s) initialization
// INT0: Off
// Interrupt on any change on pins PCINT0-5: Off
GIMSK=0x00;
MCUCR=0x00;
// Timer/Counter 0 Interrupt(s) initialization
TIMSK0=0x00;
// Analog Comparator initialization
// Analog Comparator: Off
ACSR=0x80;
ADCSRB=0x00;
DIDR0=0x00;
// ADC initialization
// ADC Clock frequency: 300,000 kHz
// ADC Bandgap Voltage Reference: Off
// ADC Auto Trigger Source: Free Running
// Only the 8 most significant bits of
// the AD conversion result are used
// Digital input buffers on ADC0: On, ADC1: On, ADC2: On, ADC3: On
DIDR0&=0x03;
DIDR0|=0x00;
ADMUX=ADC_VREF_TYPE & 0xff;
ADCSRA=0xA2;
ADCSRB&=0xF8;
while (1)
{
// Place your code here
}
}