질문게시판 > atmega128 uart 질문입니다.

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

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


BASIC4MCU | 질문게시판 | atmega128 uart 질문입니다.

페이지 정보

작성자 bme12 작성일2023-06-05 01:03 조회593회 댓글1건

본문

	

#define F_CPU 16000000UL

 

#include

#include

#include

#include

#include

#include

#include

#include

 

#define ADC_VREF_TYPE 0x40

#define moving_size 8

#define diff_size 5

#define lpf_size 5

#define threshold 300

 

volatile unsigned long filter_data = 0;

volatile unsigned short int ecg_data = 0;

volatile unsigned int heart_rate = 0;

volatile unsigned int filter_high, filter_low, moving_high, moving_low =0;

 

volatile bool timerflag = 0;

 

unsigned int read_adc(unsigned char adc_input)

{

ADMUX=adc_input | (ADC_VREF_TYPE & 0xff);     

_delay_us(10);

ADCSRA|=0x40;                               //변환 시작(single conversion mode이기 떄문) 

while ((ADCSRA & 0x10)==0);                 //ADC 변환 확인(값이 0일시 무한루프)

ADCSRA|=0x10;                               //ADC 변환 완료 flag실행

                                  

return ADCW;                                //ADCW = ADCH + ADCL 값 반환

}

 

//8-point moving average

unsigned long moving_avg[moving_size] = {0};   //연산 과정에서 오차를 줄이기 위해 실수 타입 사용

void moving_average(void)

{

    int i=0;

    int moving_sum=0;                           //MA filter result

    moving_avg[0]=ecg_data;                     //refreshing data

    for(i=0;i;i++){<>

        moving_sum += moving_avg[i];            //data summing

    }

    for(i=moving_size-1;i>0;i--){

        moving_avg[i]=moving_avg[i-1];          //data shift

    }

    moving_sum=moving_sum/moving_size;     //averaging data

moving_high = moving_sum>>8; //Moving Average Filter 통과한 값 변수에 저장

    moving_low = moving_sum;

    

}

 

signed long diff_filter[diff_size]= {0};

signed long lpf_filter[lpf_size]= {0};

void ecg_filter(void)                                  //data digital filtering

{

int i;

diff_filter[0]=moving_high | moving_low;

lpf_filter[0]=diff_filter[0]-diff_filter[4];                                             //5SAMPLE HPF

filter_data=lpf_filter[0]+4*lpf_filter[1]+6*lpf_filter[2]+4*lpf_filter[3]+lpf_filter[4]; //FIR LPF

for(i=diff_size-1;i>0;i--){

diff_filter[i]=diff_filter[i-1];                //data spread

}

for(i=lpf_size-1;i>0;i--){

lpf_filter[i]=lpf_filter[i-1];                  //data spread

}

filter_high=filter_data>>8;

filter_low=filter_data;

}

 

unsigned char delay = 0;

void peak_detection()

{

    static int rr_interval = 0;

    static int sampling_rate = 400;

if(filter_data>threshold && delay > 200){           //1CTC당 1ms

heart_rate=60*sampling_rate/rr_interval;        //심박이 60~100의 주파수, 최대주파수 100의 4배

delay=0;

rr_interval=0;

}

else{

delay++;

rr_interval++;

}

}

 

ISR(TIMER0_COMP_vect)

{

    peak_detection();

timerflag=1;

}

 

int main(void)

{

    ADMUX=ADC_VREF_TYPE & 0xff;     //외부 AVCC핀을 기준 전압(reference voltage)로 사용, data 오른쪽 정렬, ADC0 pin 사용

    ADCSRA=0x84;                    //ADC enable, 16 prescaler = 1MHZ (1clock = 1us), single conversion mode

    

    TCCR0=0x05;                     //분주비 128

    OCR0=0x7D;                      //1ms

    TIMSK=0x02;                     //compare-match interrupt enable

    sei(); //global interrupt enable

    DDRD=0xff;                      //portD output mode                                                 

 

    UCSR0A=0x00;                    //8비트데이터, 패리티 없음, 1비트 정지모드

    UCSR0B=0x08;                    //UART송신 기능 활성화

    UCSR0C=0x06;                    //전송 비트수=8

    UBRR0H=0x00;                    //115200 baud rate

    UBRR0L=0x08;                    //for asynchronous mode baud rate

    while (1)

    {   

if(timerflag==1){

OCR0=0x7D;              //1ms

timerflag=0;            //flag reset

}

        ecg_data=read_adc(0);       //ADCW값 입력

       

    putchar(ecg_data); //raw data

        putchar(moving_high<<8 | moving_low); //moving data

putchar(filter_high<<8 | filter_low);               //filter data

        putchar(heart_rate); //heart data    

        

    };

}

ECG는 리얼 데이터가 아니라 시뮬레이터 장비로 테스트를 했습니다.

80 bpm을 출력하도록 시뮬레이터 장비를 설정했습니다.

PORTF0 핀에 ecg신호를 입력했습니다.

 

amtega128에서 moving average filter, ecg filter, peak detector 

등의 알고리즘을 참조했습니다.

 

MCU는 ATMEGA128를 사용했습니다.

 

시리얼 통신을 통하여 데이터를 전송했습니다.

위 코드가 맞는지 확인하기 위해서 EBTerminal이라는 프로그램을 사용하여 putchar로 보낸 데이터 값을 확인하려는 데 밑 사진에 open을 눌러도 아무것도 뜨질 않습니다.

코드가 어디가 잘못됐는지 chat gpt, 인터넷 등을 아무리 뒤져봐도 나오질 않았고 돌고 돌던 중, 이 사이트를 찾아 글을 써봅니다..

혹시 도움을 주실 분이 계실까요..?

 

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

댓글 1

조회수 593

master님의 댓글

master 작성일

while (1){ 
        putchar('1');
        _delay_ms(1000);
    }
}
통신 테스트는 간단한 코드로 하세요

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

MCU, AVR, 아두이노 등 전자공학에 관련된 질문을 무료회원가입 후 작성해주시면 전문가가 답변해드립니다.
ATMEGA128PWMLED초음파
아두이노AVR블루투스LCD
UART모터적외선ATMEGA
전체 스위치 센서
질문게시판 목록
제목 작성자 작성일 조회
공지 MCU, AVR, 아두이노 등 전자공학에 관련된 질문은 질문게시판에서만 작성 가능합니다. 스태프 19-01-15 21054
공지 사이트 이용 안내댓글[29] master 17-10-29 34900
질문 질문있습니다ㅠㅠ 부탁드려요 새글 keldeo 02:57 5
질문 0 ~ 99 이중 for문으로 작성하는법!댓글[2] 새글 상어 23-09-26 11
질문 리튬배터리로 화면 출력 질문드립니다 !댓글[1] 이미지새글 멘탈나간다 23-09-26 9
질문 lcd,바코드,서보모터, 아두이노 질문 드립니다. ㅠㅠ댓글[1] 새글 아두이노개발자 23-09-26 20
질문 stm32에서 변수 값을 유지하는 방법댓글[1] 새글 라칸 23-09-26 15
질문 안녕하세요 스위치로 led 제어 관련 질문이 있습니다댓글[1] 새글 노형빈 23-09-25 17
질문 16X16 도트 매트릭스 구동방법 질문입니다.댓글[1] 새글첨부파일 맹균 23-09-25 16
질문 stm32에서 RTC 시간 함수 쓰는데 의문점댓글[1] 새글 라칸 23-09-25 22
질문 GPS 모듈 관련 질문입니다.댓글[3] 지구과학 23-09-22 29
질문 아두이노 블루투스와 초음파센서를 이용한 장애물 정지댓글[2] 둘둘이 23-09-22 57
답변 답변글 답변 : 아두이노 블루투스와 초음파센서를 이용한 장애물 정지댓글[1] 새글 master 23-09-25 19
질문 stm32 보드에서 시간설정과 불러오기를 하는데댓글[5] 라칸 23-09-22 41
질문 아두이노 인터럽트 질문입니다.댓글[2] Tell 23-09-21 45
답변 답변글 답변 : 아두이노 인터럽트 질문입니다.댓글[1] master 23-09-22 54
질문 아두이노와 거리 감지 센서의 전류 관련댓글[1] hmkim 23-09-21 65
질문 아두이노 코딩 질문있습니다. 도와주세요....댓글[1] 이미지첨부파일 vnpaz 23-09-20 70
질문 아두이노를 사용한 dc모터 위치제어댓글[2] 모터위치 23-09-20 62
질문 stm32 디버깅이나 rst버튼 없이 하는 방법좀댓글[1] 라칸 23-09-20 53
질문 LCD에 숫자 표기법을 바꾸고 싶습니댓글[2] Bs드리프터 23-09-19 125
질문 알코올 측정기(MQ-3) 관련 질문 이미지 소오금 23-09-18 61
답변 답변글 답변 : 알코올 측정기(MQ-3) 관련 질문 master 23-09-19 112
질문 스텝모터 제어하는 소스파일 수정방법 질문드립니다. Bs드리프터 23-09-15 75
답변 답변글 답변 : 스텝모터 제어하는 소스파일 수정방법 질문드립니다.댓글[1] master 23-09-15 109
질문 atmega 128을 이용한 악기 튜너기댓글[1] 아두이노짱 23-09-15 315
질문 stm32 보드 ip주소 찾는법댓글[1] 라칸 23-09-13 67
질문 마이컴 종류 질문댓글[2] stevie8 23-09-12 122
질문 주파수 실수배 체배 관련문의댓글[6] 스쳐두임신 23-09-11 151
질문 스마트 창문 제작 중에 질문 있습니다!댓글[1] 이미지첨부파일 N8008 23-09-09 117
게시물 검색

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
모바일버전으로보기