질문게시판 > 답변 : atmega128fh 라인트레이서 제작중 방향 문제에 관해서

TODAY1,257 TOTAL2,170,207
사이트 이용안내
Login▼/회원가입
최신글보기 질문게시판 기술자료 동영상강좌

아두이노 센서 ATMEGA128 PWM LED 초음파 AVR 블루투스 LCD UART 모터 적외선


BASIC4MCU | 질문게시판 | 답변 : atmega128fh 라인트레이서 제작중 방향 문제에 관해서

페이지 정보

작성자 master 작성일2018-12-19 20:14 조회3,561회 댓글0건

본문

	

 

// DateTime : 2018-12-19 오후 7:44:58
// by Ok-Hyun Park
//
안녕하세요 라인트레이서 제작중인 학생입니다.
서툴지만 직진은 가능하나 좌우회전이 안됩니다.
돌아도 크게 돕니다.다음은 사용중인 코드인데
어느 부분을 수정하면 좋을지 조언부탁드립니다.
참고로 발광센서는  쌍을 사용중입니다.
//
#include <avr/io.h>
#include <avr/interrupt.h>
#define F_CPU 16000000UL // 16 MHz
#include <util/delay.h>
//
typedef unsigned int  WORD;
typedef unsigned char BYTE;
//
#define SenserNum  3
//
WORD speed_L,speed_R;
WORD ADC_Data[SenserNum+1]={0,};
//
int state=0,count_R=0,count_L=0,CrossCount=0,StopState=0;
//
unsigned char left_motor[8] ={0x99,0x88,0xcc,0x44,0x66,0x22,0x33,0x11};
unsigned char right_motor[8]={0x11,0x33,0x22,0x66,0x44,0xcc,0x88,0x99};
//
void Set_Speed(void){
  int L,C,R;
  L=ADC_Data[1]; C=ADC_Data[2]; R=ADC_Data[3];
  if     (L>800 && C<550 && R<500){ speed_L=30000speed_R=50000state=1; } //Left Corner
  else if(L>800 && C>550 && R<500){ speed_L=35000speed_R=50000state=2; } //Left
  else if(L<500 && C<550 && R>800){ speed_L=50000speed_R=30000state=3; } //Right Corner
  else if(L<500 && C>550 && R>800){ speed_L=50000speed_R=35000state=4; } //Right
  else if(         C>800         ){ speed_L=50000speed_R=50000state=5; } //Straight
  else                            { speed_L=0;     speed_R=0;     state=6; } //Stop
}
//
unsigned char Rxd0Byte(){ while(!(UCSR0A&0x80)); return UDR0; }
unsigned char Rxd1Byte(){ while(!(UCSR1A&0x80)); return UDR1; }
//
void Txd0Byte(char d){ while(!(UCSR0A&0x20)); UDR0=d; }
void Txd1Byte(char d){ while(!(UCSR1A&0x20)); UDR1=d; }
//
void Txd0String(char *s){ while(*s)Txd0Byte(*s++); }
void Txd1String(char *s){ while(*s)Txd1Byte(*s++); }
//
void Txd0Dec(int dec){
  char i,String[5];
  for(i=0i<=4i++){ String[i]=0x30+(dec%10); dec/=10; }
  for(i=4i>=0i--)Txd0Byte(String[i]);
}
//
void Txd1Dec(int dec){
  char i,String[5];
  for(i=0i<=4i++){ String[i]=0x30+(dec%10); dec/=10; }
  for(i=4i>=0i--)Txd1Byte(String[i]);
}
//
SIGNAL(TIMER1_OVF_vect){
  PORTB=right_motor[count_R]; if(++count_R>7)count_R=0;
  Set_Speed();
  
}
//
SIGNAL(TIMER3_OVF_Vect){
  PORTC=left_motor[count_L]; if(++count_L>7)count_L=0;
  Set_Speed();
  TCNT3=speed_L;
}
//
SIGNAL(ADC_vect){
  ADC_Data[ADMUX++]=ADC;
  ADMUX%=SenserNum+1;
  ADCSRA|=0x40// ADSC
}
//
int main(void){
  DDRA=0XFF;
  DDRB=0xFF;
  DDRC=0xFFPORTC=0xFF;
  DDRE=0xFF;
  DDRD=0xFFPORTD=0xFF;
  //
  UCSR0B=0x08UBRR0L=25// 38400
  UCSR1B=0x08UBRR1L=25// 38400
  //
  TCNT1=speed_RTCCR1B=1TIMSK=4;
  TCNT3=speed_LTCCR3B=1ETIMSK=4;
  //
  ADCSRA=0xCF;
  //
  SREG=0x80;
  for(;;){
    _delay_ms(100);
    Txd1Dec(ADC_Data[3]); Txd1Byte(' ');
    Txd1Dec(ADC_Data[2]); Txd1Byte(' ');
    Txd1Dec(ADC_Data[1]); Txd1Byte(' ');
    // Txd1Dec(ADC_Data[4]); Txd1Byte(' '); Txd1Dec(ADC_Data[5]); Txd1Byte(' ');
    Txd0Dec(ADC_Data[3]); Txd0Byte(' ');
    Txd0Dec(ADC_Data[2]); Txd0Byte(' ');
    Txd0Dec(ADC_Data[1]); Txd0Byte(' ');
    // Txd0Dec(ADC_Data[4]); Txd0Byte(' '); Txd0Dec(ADC_Data[5]); Txd0Byte(' ');
    if     (state==1)Txd1String("Left Corner");
    else if(state==2)Txd1String("Left");
    else if(state==3)Txd1String("Right Corner");
    else if(state==4)Txd1String("Right");
    else if(state==5)Txd1String("Straight");
    else             Txd1String("Stop");
    Txd1Byte('\n');
  }
  return 0;
}

 

void Set_Speed(void){
  int L,C,R;
  L=ADC_Data[1]; C=ADC_Data[2]; R=ADC_Data[3];
  if     (L>800 && C<550 && R<500){ speed_L=30000speed_R=50000state=1; } //Left Corner
  else if(L>800 && C>550 && R<500){ speed_L=35000speed_R=50000state=2; } //Left
  else if(L<500 && C<550 && R>800){ speed_L=50000speed_R=30000state=3; } //Right Corner
  else if(L<500 && C>550 && R>800){ speed_L=50000speed_R=35000state=4; } //Right
  else if(         C>800         ){ speed_L=50000speed_R=50000state=5; } //Straight
  else                            { speed_L=0;     speed_R=0;     state=6; } //Stop
}

하나는 정지, 다른 하나는 전진 해야지 회전을 합니다.

하나는 2ms, 다른 하나는 1ms로 하면 회전 반경이 커질 수 밖에 없겠죠

 

//

 speed_L=30000speed_R=50000 

5000 이든 3000 이든 변경하지말고 한 값으로 고정시키면

타이머는 1개만 있으면 되겠죠

 

void Set_Speed(void){
  char s=0;
  if(ADC_Data[1]>700)s|=1;
  if(ADC_Data[2]>700)s|=2;
  if(ADC_Data[3]>700)s|=4;
  //
  switch(s){ // RCL
    case 0b000: break;
    case 0b001: break//Left Corner
    case 0b011: break//Left
    case 0b100: break//Right Corner
    case 0b110: break//Right
    case 0b010: break//Straight
    case 0b111: break//Straight
    case 0b101: break//Straight
  }
}

Set_Speed 함수에서 센서를 이런식으로 체크 할 수도 있겠죠

 

 

//
void R_up(){ if(++count_R>7)count_R=0PORTB=right_motor[count_R]; }
void L_up(){ if(++count_L>7)count_L=0PORTC=right_motor[count_L];  }
//
void R_dn(){ if(--count_R<0)count_R=7PORTB=right_motor[count_R]; }
void L_dn(){ if(--count_L<0)count_L=7PORTC=right_motor[count_L]; }
//
SIGNAL(TIMER1_OVF_vect){
  char s;
  TCNT1=50000;
  //
  s=0;
  if(ADC_Data[1]>700)s|=1;
  if(ADC_Data[2]>700)s|=2;
  if(ADC_Data[3]>700)s|=4;
  //
  switch(s){ // RCL
    case 0b000:                 break// stop
    case 0b001: L_dn(); R_up(); break// Left Corner 제자리 회전
    case 0b011:         R_up(); break// Left
    case 0b100: L_up(); R_dn(); break// Right Corner 제자리 회전
    case 0b110: L_up();         break// Right
    case 0b010:
    case 0b111:
    case 0b101: L_up(); R_up(); break// Straight
  }
}

모터를 돌리고 안돌리고는 이렇게 처리하면 됩니다

 

 

// DateTime : 2018-12-19 오후 8:19:22
// by Ok-Hyun Park
//
#include <avr/io.h>
#include <avr/interrupt.h>
#define F_CPU 16000000UL // 16 MHz
#include <util/delay.h>
#include <stdio.h>
//
typedef unsigned int  U16;
typedef unsigned char U08;
typedef   signed char S08;
//
U16 adBuf[4]={0,};
U08 str[50];
S08 state=0,R_cnt=0,L_cnt=0;
//
unsigned char L_motor[8]={0x99,0x88,0xcc,0x44,0x66,0x22,0x33,0x11};
unsigned char R_motor[8]={0x11,0x33,0x22,0x66,0x44,0xcc,0x88,0x99};
//
char Rx0_Char(){ while(!(UCSR0A&0x80)); return UDR0; }
char Rx1_Char(){ while(!(UCSR1A&0x80)); return UDR1; }
//
void Tx0_Char(char d){ while(!(UCSR0A&0x20)); UDR0=d; }
void Tx1_Char(char d){ while(!(UCSR1A&0x20)); UDR1=d; }
//
void Tx0_Str(char *s){ while(*s)Tx0_Char(*s++); }
void Tx1_Str(char *s){ while(*s)Tx1_Char(*s++); }
//
void Txd0Dec(int dec){
  char i,String[5];
  for(i=0i<=4i++){ String[i]=0x30+(dec%10); dec/=10; }
  for(i=4i>=0i--)Tx0_Char(String[i]);
}
//
void Txd1Dec(int dec){
  char i,String[5];
  for(i=0i<=4i++){ String[i]=0x30+(dec%10); dec/=10; }
  for(i=4i>=0i--)Tx1_Char(String[i]);
}
//
void R_up(){ if(++R_cnt>7)R_cnt=0PORTB=R_motor[R_cnt]; }
void L_up(){ if(++L_cnt>7)L_cnt=0PORTC=R_motor[L_cnt];  }
//
void R_dn(){ if(--R_cnt<0)R_cnt=7PORTB=R_motor[R_cnt]; }
void L_dn(){ if(--L_cnt<0)L_cnt=7PORTC=R_motor[L_cnt]; }
//
ISR(TIMER0_COMP_vect){ // 1ms
  char s=0;
  if(adBuf[1]>700)s|=1;
  if(adBuf[2]>700)s|=2;
  if(adBuf[3]>700)s|=4;
  //
  switch(s){ // RCL
    case 0b000:                 state=0break// stop
    case 0b001L_dn(); R_up(); state=1break// Left Corner 제자리 회전
    case 0b011:         R_up(); state=2break// Left
    case 0b100L_up(); R_dn(); state=3break// Right Corner 제자리 회전
    case 0b110L_up();         state=4break// Right
    case 0b010:
    case 0b111:
    case 0b101L_up(); R_up(); state=5break// Straight
  }
}
//
SIGNAL(ADC_vect){
  adBuf[ADMUX]=ADC;
  if(++ADMUX==4)ADMUX=1;
  ADCSRA|=0x40// ADSC
}
//
int main(void){
  DDRA=0XFF;
  DDRB=0xFF;
  DDRC=0xFFPORTC=0xFF;
  DDRE=0xFF;
  DDRD=0xFFPORTD=0xFF;
  //
  UCSR0B=0x08UBRR0L=25// 38400
  UCSR1B=0x08UBRR1L=25// 38400
  //
  TCCR0=0x0DOCR0=124TIMSK=2//16000000/128/(1+124),1ms
  //
  ADMUX=1ADCSRA=0xCF;
  //
  SREG=0x80;
  for(;;){
    _delay_ms(100);
    sprintf(str,"%04d %04d %04d ",adBuf[3],adBuf[2],adBuf[1]); Tx0_Char(str); Tx1_Char(str);
    //
    switch(state){
      case 0Tx1_Str("Stop\n");         break;
      case 1Tx1_Str("Left Corner\n");  break;
      case 2Tx1_Str("Left\n");         break;
      case 3Tx1_Str("Right Corner\n"); break;
      case 4Tx1_Str("Right\n");        break;
      case 5Tx1_Str("Straight\n");     break;
    }
  }
}

 

  • BASIC4MCU 작성글 SNS에 공유하기
  • 페이스북으로 보내기
  • 트위터로 보내기
  • 구글플러스로 보내기

댓글 0

조회수 3,561

등록된 댓글이 없습니다.

질문게시판HOME > 질문게시판 목록

MCU, AVR, 아두이노 등 전자공학에 관련된 질문을 무료회원가입 후 작성해주시면 전문가가 답변해드립니다.
ATMEGA128PWMLED초음파
아두이노AVR블루투스LCD
UART모터적외선ATMEGA
전체 스위치 센서
질문게시판 목록
제목 작성자 작성일 조회
공지 MCU, AVR, 아두이노 등 전자공학에 관련된 질문은 질문게시판에서만 작성 가능합니다. 스태프 19-01-15 9675
공지 사이트 이용 안내댓글[24] master 17-10-29 29757
질문 adc, uart dma댓글[2] 새글첨부파일 hiㅡO3O 13:10 15
질문 ADC,uart DMA댓글[1] 이미지새글첨부파일 hiㅡO3O 12:23 15
질문 아두이노 스텝모터 리미트 문의드립니다.댓글[1] 이미지새글첨부파일 스트렌져 22-05-24 16
질문 진동센서와 서보모터 연결 코드 질문입니다!댓글[1] 새글 제리 22-05-24 17
질문 atmega128 GPS,블루투스 질문드립니다.댓글[1] 새글 코딩초보1 22-05-24 27
질문 서보모터 제어에 관하여 궁금합니다댓글[2] 이미지새글첨부파일 오소로롯 22-05-24 32
질문 atmega 128 타이머 작성 중 질문 드립니다.댓글[6] 이미지새글 마프하나 22-05-23 45
질문 아두이노와 휴대폰을 HC-06으로 연결시켜서 블루투스연결이 끊기면 부저에서 소리가 나게 할려하는데 어떻게 해…댓글[1] 새글 졸작부수다 22-05-23 137
답변 답변글 답변 : 아두이노와 휴대폰을 HC-06으로 연결시켜서 블루투스연결이 끊기면 부저에서 소리가 나게 할려하는데 … 새글 master 22-05-24 19
질문 보드레이트 질문댓글[1] 새글 죠르디 22-05-23 20
질문 atmega 128 블루투스 질문 입니다댓글[1] 새글 yhj2644 22-05-23 36
질문 아트메가 공부중에 질문있습니다..댓글[1] suid82 22-05-23 22
질문 Atmega128 UART통신 echo 반복 질문댓글[2] ming2ming 22-05-23 31
질문 아두이노의 지속 시간에 대해 질문합니다. merry 22-05-23 35
답변 답변글 답변 : 아두이노의 지속 시간에 대해 질문합니다. master 22-05-23 29
질문 초음파+스텝모터 도꺼비 22-05-22 25
답변 답변글 답변 : 초음파+스텝모터 master 22-05-23 30
질문 아두이노 인터럽트 질문있습니다.댓글[1] 띵꽁 22-05-22 36
답변 답변글 답변 : 아두이노 인터럽트 질문있습니다.댓글[3] master 22-05-22 35
질문 atmega128 스톱워치 작성 중 외부 인터럽트 관련 질문 드립니다.댓글[4] 이미지 마프하나 22-05-22 54
답변 답변글 답변 : atmega128 스톱워치 작성 중 외부 인터럽트 관련 질문 드립니다.댓글[1] 이미지 master 22-05-23 32
질문 서보모터제어 해당코드에서 어떤걸 추가해야할까요댓글[3] 이미지첨부파일 오소로롯 22-05-22 38
질문 Atmega128 UART통신에서 ECHO 관련 질문드립니다. dsfdfsa 22-05-22 39
답변 답변글 답변 : Atmega128 UART통신에서 ECHO 관련 질문드립니다.댓글[1] master 22-05-22 31
질문 아두이노 서보모터제어 하나도 모르겠습니다 ㅠ댓글[2] 이미지첨부파일 오소로롯 22-05-21 57
질문 아트메가 128 을 이용해서적외선 센서 코딩 중 물어볼게있습니다!!댓글[5] noster 22-05-21 61
질문 아두이노 에러질문댓글[2] 이미지첨부파일 리니어 22-05-21 57
질문 아두이노 블루투스 통신 관련 질문 있습니다!! 블루툿 22-05-21 46
게시물 검색

2022년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
2021년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
2020년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
2019년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
2018년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
Privacy Policy
MCU BASIC ⓒ 2020
모바일버전으로보기