Чт дек 04, 2014 15:21:41
int D_1=123, D_2=456, D_3=789, D_4=012, D_5= 045;
unsigned int DHT_Read_Data(unsigned int *humidity, unsigned int *temp){
int data[50];
int counter = 0, sum = 0, i = 0;
// Очистить массив контролльных сумм
data[0] = data[1] = data[2] = data[3] = data[4] = 0;
DDRD.7 = 1; // делаем вывод мк выходом
// Подготока шины для передачи
PORTD.7 = 1;
delay_ms(250);
// Инициализаруем передачу
PORTD.7 = 0; // прижимаем к земле не менее чем на 18 мс
delay_ms(20);
DDRD.7 = 0; // делаем выход мк входом
delay_us(40);
if (PIND.7 == 1) return 1; // если на входе всё ещё "1" то датчик так и не ответил
delay_us(80);
if (PIND.7 == 0) return 2; // если на линии по прежнему 0, то датчик умер
// Если датчик жив и всё хорошо, идём дальше...
while( PIND.7 == 0)
{
delay_us(80); // ждём появления нуля на шине первый раз
while (counter <= 40) // принимаем 40 бит данных
{
while( PIND.7 == 0)
{
// запускаем по битовый приём
if( PIND.7 == 1)
{
data[counter] = 0;
}
delay_us(40); // если 1 держится более 68 мкс, то передаётся 1
if (PIND.7 == 1)
{
data[counter] = 1;
}
delay_us(20); // ждём появления нуля на шине
counter++; // увеличиваем счётчик на один
}
}
}
// пока сделал костыль для наглядности
D_1 = data[0];
D_1 = D_1 <<1;
D_1 = D_1 | data[1];
D_1 = D_1 <<1;
D_1 = D_1 | data[2];
D_1 = D_1 <<1;
D_1 = D_1 | data[3];
D_1 = D_1 <<1;
D_1 = D_1 | data[4];
D_1 = D_1 <<1;
D_1 = D_1 | data[5];
D_1 = D_1 <<1;
D_1 = D_1 | data[6];
D_1 = D_1 <<1;
D_1 = D_1 | data[7];
D_3 = data[16];
D_3 = D_3 <<1;
D_3 = D_3 | data[17];
D_3 = D_3 <<1;
D_3 = D_3 | data[18];
D_3 = D_3 <<1;
D_3 = D_3 | data[19];
D_3 = D_3 <<1;
D_3 = D_3 | data[20];
D_3 = D_3 <<1;
D_3 = D_3 | data[21];
D_3 = D_3 <<1;
D_3 = D_3 | data[22];
D_3 = D_3 <<1;
D_3 = D_3 | data[23];
// проверяем сходимость CRC сумм
// sum = D_1 + D_2 + D_3 + D_4;
// if ((sum != D_5) || (sum == 0x11) || (sum == 0xff)) return 3; // контрольная сумма не сошлась
temp = D_3;
humidity = D_1;
return 0; // всё работает успешно
}
Чт дек 04, 2014 18:04:55
#define DHT_DDR DDRD.7
#define DHT_OUT PORTD.7
#define DHT_IN PIND.7
unsigned char data[5];
char GetHumidity()
{
unsigned char n, k, idx;
data[0] = data[1] = data[2] = data[3] = data[4] = 0;
DHT_OUT = 0;
delay_ms(18);
DHT_OUT = 1;
DHT_DDR = 0;
delay_us(50);
if(DHT_IN != 0)
{
return 1;
}
while(DHT_IN == 0)
{
//может зависнуть - добавить код
}
while(DHT_IN != 0)
{
//может зависнуть - добавить код
}
for(n = 0; n < 5; n++)
{
idx = 0x80;
for(k = 0; k < 8; k++)
{
while(DHT_IN == 0)
{
//может зависнуть - добавить код
}
delay_us(33);
if(DHT_IN != 0) data[n] |= idx;
idx >>= 1;
while(DHT_IN != 0)
{
//может зависнуть - добавить код
}
}
}
return 0;
}
* может зависнуть - добавить код, например проверять значение счетчика таймера
Чт дек 04, 2014 19:08:14
Чт дек 04, 2014 19:11:47
pyzhman писал(а):Поделитесь моделью DHT11 для Протеуса_7, пожалуйста.
oleg110592 писал(а):У меня так нормально работает:
Чт дек 04, 2014 20:11:24
while (1)
{
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
sprintf(lcd_buffer,"Humidity %d",data[0]);
lcd_clear();
lcd_puts(lcd_buffer);
}
Пт дек 05, 2014 09:19:34
oleg110592 писал(а):Проверил в протеусе - работает:
в мэин:
- Код:
while (1)
{
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
sprintf(lcd_buffer,"Humidity %d",data[0]);
lcd_clear();
lcd_puts(lcd_buffer);
}
/*******************************************************
This program was created by the
CodeWizardAVR V3.12 Advanced
Automatic Program Generator
© Copyright 1998-2014 Pavel Haiduc, HP InfoTech s.r.l.
http://www.hpinfotech.com
Project :
Version :
Date : 05.12.2014
Author :
Company :
Comments:
Chip type : ATmega16
Program type : Application
AVR Core Clock frequency: 8,000000 MHz
Memory model : Small
External RAM size : 0
Data Stack size : 256
*******************************************************/
#include <mega16.h>
// Alphanumeric LCD functions
#include <alcd.h>
#include <delay.h>
#include <stdio.h>
#include <io.h>
#include <math.h>
char lcd_buffer[33];
// Declare your global variables here
int test;
#define DHT_DDR DDRD.7
#define DHT_OUT PORTD.7
#define DHT_IN PIND.7
unsigned char data[5];
char GetHumidity()
{
unsigned char n, k, idx;
data[0] = data[1] = data[2] = data[3] = data[4] = 0;
DHT_OUT = 0;
delay_ms(18);
DHT_OUT = 1;
DHT_DDR = 0;
delay_us(50);
if(DHT_IN != 0)
{
return 1;
}
while(DHT_IN == 0)
{
return 2;
//может зависнуть - добавить код
}
while(DHT_IN != 0)
{
return 3;
//может зависнуть - добавить код
}
for(n = 0; n < 5; n++)
{
idx = 0x80;
for(k = 0; k < 8; k++)
{
while(DHT_IN == 0)
{
return 4;
//может зависнуть - добавить код
}
delay_us(33);
if(DHT_IN != 0) data[n] |= idx;
idx >>= 1;
while(DHT_IN != 0)
{
return 5;
//может зависнуть - добавить код
}
}
}
return 0;
}
void main(void)
{
// Declare your local variables here
// Input/Output Ports initialization
// Port A initialization
// Function: Bit7=In Bit6=In Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In
DDRA=(0<<DDA7) | (0<<DDA6) | (0<<DDA5) | (0<<DDA4) | (0<<DDA3) | (0<<DDA2) | (0<<DDA1) | (0<<DDA0);
// State: Bit7=T Bit6=T Bit5=T Bit4=T Bit3=T Bit2=T Bit1=T Bit0=T
PORTA=(0<<PORTA7) | (0<<PORTA6) | (0<<PORTA5) | (0<<PORTA4) | (0<<PORTA3) | (0<<PORTA2) | (0<<PORTA1) | (0<<PORTA0);
// Port B initialization
// Function: Bit7=In Bit6=In Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In
DDRB=(0<<DDB7) | (0<<DDB6) | (0<<DDB5) | (0<<DDB4) | (0<<DDB3) | (0<<DDB2) | (0<<DDB1) | (0<<DDB0);
// State: Bit7=T Bit6=T Bit5=T Bit4=T Bit3=T Bit2=T Bit1=T Bit0=T
PORTB=(0<<PORTB7) | (0<<PORTB6) | (0<<PORTB5) | (0<<PORTB4) | (0<<PORTB3) | (0<<PORTB2) | (0<<PORTB1) | (0<<PORTB0);
// Port C initialization
// Function: Bit7=In Bit6=In Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In
DDRC=(0<<DDC7) | (0<<DDC6) | (0<<DDC5) | (0<<DDC4) | (0<<DDC3) | (0<<DDC2) | (0<<DDC1) | (0<<DDC0);
// State: Bit7=T Bit6=T Bit5=T Bit4=T Bit3=T Bit2=T Bit1=T Bit0=T
PORTC=(0<<PORTC7) | (0<<PORTC6) | (0<<PORTC5) | (0<<PORTC4) | (0<<PORTC3) | (0<<PORTC2) | (0<<PORTC1) | (0<<PORTC0);
// Port D initialization
// Function: Bit7=In Bit6=In Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In
DDRD=(0<<DDD7) | (0<<DDD6) | (0<<DDD5) | (0<<DDD4) | (0<<DDD3) | (0<<DDD2) | (0<<DDD1) | (0<<DDD0);
// State: Bit7=T Bit6=T Bit5=T Bit4=T Bit3=T Bit2=T Bit1=T Bit0=T
PORTD=(0<<PORTD7) | (0<<PORTD6) | (0<<PORTD5) | (0<<PORTD4) | (0<<PORTD3) | (0<<PORTD2) | (0<<PORTD1) | (0<<PORTD0);
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
// Mode: Normal top=0xFF
// OC0 output: Disconnected
TCCR0=(0<<WGM00) | (0<<COM01) | (0<<COM00) | (0<<WGM01) | (0<<CS02) | (0<<CS01) | (0<<CS00);
TCNT0=0x00;
OCR0=0x00;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer1 Stopped
// Mode: Normal top=0xFFFF
// OC1A output: Disconnected
// OC1B output: Disconnected
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=(0<<COM1A1) | (0<<COM1A0) | (0<<COM1B1) | (0<<COM1B0) | (0<<WGM11) | (0<<WGM10);
TCCR1B=(0<<ICNC1) | (0<<ICES1) | (0<<WGM13) | (0<<WGM12) | (0<<CS12) | (0<<CS11) | (0<<CS10);
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer2 Stopped
// Mode: Normal top=0xFF
// OC2 output: Disconnected
ASSR=0<<AS2;
TCCR2=(0<<PWM2) | (0<<COM21) | (0<<COM20) | (0<<CTC2) | (0<<CS22) | (0<<CS21) | (0<<CS20);
TCNT2=0x00;
OCR2=0x00;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=(0<<OCIE2) | (0<<TOIE2) | (0<<TICIE1) | (0<<OCIE1A) | (0<<OCIE1B) | (0<<TOIE1) | (0<<OCIE0) | (0<<TOIE0);
// External Interrupt(s) initialization
// INT0: Off
// INT1: Off
// INT2: Off
MCUCR=(0<<ISC11) | (0<<ISC10) | (0<<ISC01) | (0<<ISC00);
MCUCSR=(0<<ISC2);
// USART initialization
// USART disabled
UCSRB=(0<<RXCIE) | (0<<TXCIE) | (0<<UDRIE) | (0<<RXEN) | (0<<TXEN) | (0<<UCSZ2) | (0<<RXB8) | (0<<TXB8);
// Analog Comparator initialization
// Analog Comparator: Off
// The Analog Comparator's positive input is
// connected to the AIN0 pin
// The Analog Comparator's negative input is
// connected to the AIN1 pin
ACSR=(1<<ACD) | (0<<ACBG) | (0<<ACO) | (0<<ACI) | (0<<ACIE) | (0<<ACIC) | (0<<ACIS1) | (0<<ACIS0);
SFIOR=(0<<ACME);
// ADC initialization
// ADC disabled
ADCSRA=(0<<ADEN) | (0<<ADSC) | (0<<ADATE) | (0<<ADIF) | (0<<ADIE) | (0<<ADPS2) | (0<<ADPS1) | (0<<ADPS0);
// SPI initialization
// SPI disabled
SPCR=(0<<SPIE) | (0<<SPE) | (0<<DORD) | (0<<MSTR) | (0<<CPOL) | (0<<CPHA) | (0<<SPR1) | (0<<SPR0);
// TWI initialization
// TWI disabled
TWCR=(0<<TWEA) | (0<<TWSTA) | (0<<TWSTO) | (0<<TWEN) | (0<<TWIE);
// Alphanumeric LCD initialization
// Connections are specified in the
// Project|Configure|C Compiler|Libraries|Alphanumeric LCD menu:
// RS - PORTA Bit 0
// RD - PORTA Bit 1
// EN - PORTA Bit 2
// D4 - PORTA Bit 4
// D5 - PORTA Bit 5
// D6 - PORTA Bit 6
// D7 - PORTA Bit 7
// Characters/line: 8
lcd_init(8);
while (1)
{
// Place your code here
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
sprintf(lcd_buffer,"Humidity %d",data[0]);
lcd_clear();
lcd_puts(lcd_buffer);
}
}
Пт дек 05, 2014 10:20:18
Пт дек 05, 2014 11:16:03
oleg110592 писал(а):код рассчитан на DHT11, в вашем протеусе DHT22
Пт дек 05, 2014 12:04:57
Пт дек 05, 2014 13:46:05
oleg110592 писал(а):мой вариант
Пт дек 05, 2014 14:51:00
unsigned int h;
while (1)
{
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
h = data[0] * 256 + data[1];
sprintf(lcd_buffer,"Hum = %d.%d",h/10,h%10); //DHT22
//sprintf(lcd_buffer,"Humidity %d",data[0]); //DHT11
lcd_clear();
lcd_puts(lcd_buffer);
}
Сб дек 06, 2014 10:49:34
oleg110592 писал(а):как то так:
- Код:
unsigned int h;
while (1)
{
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
h = data[0] * 256 + data[1];
sprintf(lcd_buffer,"Hum = %d.%d",h/10,h%10); //DHT22
//sprintf(lcd_buffer,"Humidity %d",data[0]); //DHT11
lcd_clear();
lcd_puts(lcd_buffer);
}
Пн июн 15, 2015 15:45:28
oleg110592 писал(а):мой вариант
Вт июн 16, 2015 19:24:58
...
while (1)
{
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
h = data[0] * 256 + data[1];
sprintf(lcd_buffer,"Hum = %d.%d",h/10,h%10); //DHT22
//sprintf(lcd_buffer,"Humidity %d",data[0]); //DHT11
lcd_clear();
lcd_puts(lcd_buffer);
t = data[2] * 256 + data[3];
sprintf(lcd_buffer,"Temp = %d.%d",t/10,t%10); //DHT22
lcd_gotoxy(0, 1);
lcd_puts(lcd_buffer);
}
...
Ср июн 17, 2015 04:50:26
Ср июн 17, 2015 05:14:20
Чт июн 18, 2015 10:35:20
oleg110592 писал(а):Не сложно. Переназначить ноги на индикатор и DHT.
/*****************************************************
This program was produced by the
CodeWizardAVR V2.05.0 Professional
Automatic Program Generator
© Copyright 1998-2010 Pavel Haiduc, HP InfoTech s.r.l.
http://www.hpinfotech.com
Project :
Version :
Date : 18.06.2015
Author :
Company :
Comments:
Chip type : ATmega8
Program type : Application
AVR Core Clock frequency: 8,000000 MHz
Memory model : Small
External RAM size : 0
Data Stack size : 256
*****************************************************/
#include <mega8.h>
#include <delay.h>
#include <stdio.h>
// Alphanumeric LCD Module functions
#include <alcd.h>
// LCD display buffer
char lcd_buffer[33];
#define DHT_DDR DDRD.7
#define DHT_OUT PORTD.7
#define DHT_IN PIND.7
unsigned char data[5];
char GetHumidity()
{
unsigned char n, k, idx;
data[0] = data[1] = data[2] = data[3] = data[4] = 0;
DHT_OUT = 0;
delay_ms(18);
DHT_OUT = 1;
DHT_DDR = 0;
delay_us(50);
if(DHT_IN != 0)
{
return 1;
}
while(DHT_IN == 0)
{
//может зависнуть - добавить код
}
while(DHT_IN != 0)
{
//может зависнуть - добавить код
}
for(n = 0; n < 5; n++)
{
idx = 0x80;
for(k = 0; k < 8; k++)
{
while(DHT_IN == 0)
{
//может зависнуть - добавить код
}
delay_us(33);
if(DHT_IN != 0) data[n] |= idx;
idx >>= 1;
while(DHT_IN != 0)
{
//может зависнуть - добавить код
}
}
}
return 0;
}
void main(void)
{
// Declare your local variables here
// Input/Output Ports initialization
// Port B initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTB=0x00;
DDRB=0x00;
// Port C initialization
// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTC=0x00;
DDRC=0x00;
// Port D initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTD=0x00;
DDRD=0x00;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
TCCR0=0x00;
TCNT0=0x00;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer1 Stopped
// Mode: Normal top=0xFFFF
// OC1A output: Discon.
// OC1B output: Discon.
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=0x00;
TCCR1B=0x00;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer2 Stopped
// Mode: Normal top=0xFF
// OC2 output: Disconnected
ASSR=0x00;
TCCR2=0x00;
TCNT2=0x00;
OCR2=0x00;
// External Interrupt(s) initialization
// INT0: Off
// INT1: Off
MCUCR=0x00;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x00;
// USART initialization
// USART disabled
UCSRB=0x00;
// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;
SFIOR=0x00;
// ADC initialization
// ADC disabled
ADCSRA=0x00;
// SPI initialization
// SPI disabled
SPCR=0x00;
// TWI initialization
// TWI disabled
TWCR=0x00;
// Alphanumeric LCD initialization
// Connections specified in the
// Project|Configure|C Compiler|Libraries|Alphanumeric LCD menu:
// RS - PORTB Bit 0
// RD - PORTB Bit 1
// EN - PORTB Bit 2
// D4 - PORTB Bit 4
// D5 - PORTB Bit 5
// D6 - PORTB Bit 6
// D7 - PORTB Bit 7
// Characters/line: 16
lcd_init(16);
lcd_clear();
lcd_puts("Test");
while (1)
{
DHT_DDR = 1;
DHT_OUT = 1;
delay_ms(200);
GetHumidity();
//h = data[0] * 256 + data[1];
//sprintf(lcd_buffer,"Hum = %d.%d",h/10,h%10); //DHT22
sprintf(lcd_buffer,"Vlaznost' %d",data[0]); //DHT11
lcd_clear();
lcd_puts(lcd_buffer);
//t = data[2] * 256 + data[3];
//sprintf(lcd_buffer,"Temp = %d.%d",t/10,t%10); //DHT22
sprintf(lcd_buffer,"Temperatyra %d",data[2]); //DHT11
lcd_gotoxy(0, 1);
lcd_puts(lcd_buffer);
}
}
Чт июн 18, 2015 20:38:38
Пт июн 19, 2015 03:41:49
Вт мар 08, 2016 19:39:56