Outro relógio ou quando é uma vergonha para o microcontrolador

Na escola, ele gostava de microeletrônica, foi ao clube de rádio, montou vários dispositivos simples. Então a universidade, o trabalho, o casamento e muito raramente se lembraram de seu hobby.

Com o advento da Internet em minha casa, descobri os detalhes dos microcontroladores, observei os preços e fiquei muito apaixonado por coletar algo no AVR ou STM. Reli muitos fóruns e seleções de projetos em microcontroladores, mas tudo estava errado e não conseguia entender o que estava errado. Parece ser uma coisa interessante: um music player que reproduz arquivos de um cartão de memória ou um despertador com termômetro, mas há muito mais, mas a sensação de que eu quero isso não surgiu ...

Eu me deparei com vários artigos sobre relógios em indicadores de descarga de gás da série IN e similares, uma lembrança surgiu da minha infância, pois em uma loja eu olhava os números nas escalas, e eles são separados lá na forma de fios finos e um deles brilha.

Está decidido - eu farei o relógio. Os indicadores de descarga de gás funcionam a uma voltagem de cerca de 180 volts; portanto, para coordenação com o controlador, o chip k155id1 é usado com mais freqüência - o único chip de alta tensão, um decodificador binário decimal. Para obter alta tensão, a maioria dos projetos também usa um chip PWM especializado separado. E em muitos projetos, também há um relógio em tempo real na forma de um chip separado ou de uma montagem finalizada.

Lendo a descrição no site da loja para um Atmega8 simples, imaginei que houvesse um conversor analógico-digital e modulação por largura de pulso, interfaces seriais, etc. Foi uma pena para o microcontrolador, é tão "poderoso" e eles não permitem que ele se vire.

Como resultado, contornando o circuito, comecei imediatamente a desenhar uma placa de circuito impresso no SprintLayout e esse casal nasceu em algumas semanas:

Imagem dos álbuns de fotos do E1.ru

em uma placa, tudo está com força, e na outra apenas indicadores:

Imagem dos álbuns de fotos do E1.ru

O microcontrolador atmega8 deste projeto usa todos os três temporizadores, um dos quais funciona de forma assíncrona a partir de um relógio externo de quartzo. O próprio controlador opera a uma frequência de 8 megahertz da cadeia RC interna. O PWM é usado para gerar alta tensão no conversor de reforço, e a tensão é controlada por uma entrada analógica, e o ciclo de trabalho é ajustado, se necessário. Bem, 28 pernas foram suficientes para iluminar os quatro indicadores IN 12 e mais algumas lâmpadas permaneciam.

Aqui está como fica a forma montada:

Imagem dos álbuns de fotos do E1.ru

E acende:

Imagem dos álbuns de fotos do E1.ru

Algumas das funções do controlador certamente não foram utilizadas, mas não são tão ofensivas quando não há PWM e RTC separados por perto.

BB adicionou parte do esquema, pintado em um proteus, o casal ficou duro: eu


peguei o esquema principal daqui

Código do projeto SI
#define F_CPU 8000000UL

#include <avr/io.h>
#include <avr/interrupt.h>
#include <util/delay.h>

//

void init_pwm (void)
{
//
DDRB=0xFF; //OC1A,OC1B,OC2 —
TCCR1A=(1<<COM1B1)|(1<<WGM10)|(1<<WGM11); // OC1A
TCCR1B=(1<<CS10)|(1<<WGM12)|(1<<WGM13); // OC1B

//
OCR1A=250;
OCR1B=215; // 0 200/170 250/215
}

volatile unsigned char second, minute, hour, h, m;
int voltage_ADC, dimm;
// 2
ISR (TIMER2_OVF_vect)
{
if(second++ >= 59)
{
second = 0;
minute++;
}
if(minute > 59)
{
minute = 0;
hour++;
}
if(hour > 23)
hour = 0;

//set_time(hour,minute,second); //
}

ISR (TIMER0_OVF_vect)
{

PORTC |= (1 << PC2);

}

ISR (ADC_vect)//
{
voltage_ADC = ADCW;//

if(voltage_ADC<260 && OCR1A<300){OCR1A++;OCR1B=OCR1A-dimm;}
if(voltage_ADC>260 && OCR1A>170){OCR1A--;OCR1B=OCR1A-dimm;}

ADCSR |= (1<<ADSC);//
}

//

int main(void)
{
unsigned char r;
unsigned char mode;
init_pwm(); //
PORTD=0x00; // D 0, D
DDRD=0xFF; // D , 5
PORTC = 0b00000000; DDRC = 0b11101111;

TIMSK &= ~(1 << OCIE2)|(1 << TOIE2); // T2
ASSR |= (1 << AS2); // T2
TCNT2 = 0; //
TCCR2 |= (1 << CS22)|(0 << CS21)|(1 << CS20); // 128-(32768/128 = 256 /c)
TIMSK |= (1 << TOIE2); // 2

TCCR0|=(0<<CS02)|(1<<CS00);
//TIMSK |= (1 << TOIE0); // 2

//ads
ADMUX|= (1<<REFS0)|(1<<REFS1)|(1<<MUX2); //
//ADCSRA|=(1<<ADEN)|(1<<ADFR)|(1<<ADIE)|(1<<ADPS1)|(1<<ADPS0);
ADCSRA |= (1<<ADEN) | (1<<ADSC) | (1<<ADIE) | (1<<ADPS2) | (1<<ADPS1) | (1<<ADPS0);
sei(); //

hour = 23; //
minute = 13;
second = 23;

mode=1;

while (1) //
{
/*
PORTD |= (1 << PD1); // 1
PORTD &= ~ (1 << PD1); // 1
*/
dimm=35;
PORTC &= ~ (1 << PC2);
if(mode==1){m=minute; h=hour;}
if(mode==2){m=second; h=minute;}
if(mode==3){m=voltage_ADC%100; h=voltage_ADC/100;};

for (r=0;r<4;r++)
{
if(r==1)
{
PORTC |= (1 << PC3);//
if (m/10==0) PORTD |= (1 << PD3);//0
if (m/10==1) PORTD |= (1 << PD2);//1
if (m/10==2) PORTB |= (1 << PB1);//2
if (m/10==3) PORTB |= (1 << PB3);//3
if (m/10==4) PORTB |= (1 << PB4);//4
if (m/10==5) PORTD |= (1 << PD5);//5
if (m/10==6) PORTD |= (1 << PD6);//6
if (m/10==7) PORTD |= (1 << PD7);//7
if (m/10==8) PORTB |= (1 << PB0);//8
if (m/10==9) PORTD |= (1 << PD4);//9

}

if(r==0)
{
PORTC |= (1 << PC5);//
if (m%10==0) PORTD |= (1 << PD3);//0
if (m%10==1) PORTD |= (1 << PD2);//1
if (m%10==2) PORTB |= (1 << PB1);//2
if (m%10==3) PORTB |= (1 << PB3);//3
if (m%10==4) PORTB |= (1 << PB4);//4
if (m%10==5) PORTD |= (1 << PD5);//5
if (m%10==6) PORTD |= (1 << PD6);//6
if (m%10==7) PORTD |= (1 << PD7);//7
if (m%10==8) PORTB |= (1 << PB0);//8
if (m%10==9) PORTD |= (1 << PD4);//9
}

if(r==2)
{
PORTD |= (1 << PD1);//
if (h/10==0) PORTD |= (1 << PD3);//0
if (h/10==1) PORTD |= (1 << PD2);//1
if (h/10==2) PORTB |= (1 << PB1);//2
if (h/10==3) PORTB |= (1 << PB3);//3
if (h/10==4) PORTB |= (1 << PB4);//4
if (h/10==5) PORTD |= (1 << PD5);//5
if (h/10==6) PORTD |= (1 << PD6);//6
if (h/10==7) PORTD |= (1 << PD7);//7
if (h/10==8) PORTB |= (1 << PB0);//8
if (h/10==9) PORTD |= (1 << PD4);//9

}

if(r==3)

{
PORTD |= (1 << PD0);//
if (h%10==0) PORTD |= (1 << PD3);//0
if (h%10==1) PORTD |= (1 << PD2);//1
if (h%10==2) PORTB |= (1 << PB1);//2
if (h%10==3) PORTB |= (1 << PB3);//3
if (h%10==4) PORTB |= (1 << PB4);//4
if (h%10==5) PORTD |= (1 << PD5);//5
if (h%10==6) PORTD |= (1 << PD6);//6
if (h%10==7) PORTD |= (1 << PD7);//7
if (h%10==8) PORTB |= (1 << PB0);//8
if (h%10==9) PORTD |= (1 << PD4);//9
}

_delay_ms(3);
PORTC &= ~ (1 << PC3);
PORTC &= ~ (1 << PC1);
PORTC &= ~ (1 << PC5);
PORTD &= ~ (1 << PD1);
PORTB=0x00;PORTC=0x00;PORTD=0x00;
_delay_ms(1);
}

}
}

Source: https://habr.com/ru/post/pt386755/


All Articles