질문게시판 > 아두이노 l298n frequency sweep 관련 질문

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

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


BASIC4MCU | 질문게시판 | 아두이노 l298n frequency sweep 관련 질문

페이지 정보

작성자 sdwdjangwon 작성일2022-12-07 19:11 조회1,513회 댓글2건

본문

	

reference code로 l298n에 frequency sweep sine sample로 전달함수를 매트랩 systemIdentification으로 구하려고 하고 있습니다.

코드 해석을 해봤을 때, frequency가 0.1Hz일 때 sample이 한 주기, 즉 500개, 0.2Hz일 때 한 주기 500개, 0.3Hz에서 2 주기, 1000개, ... 14Hz까지 변화시켰을 때 70 주기, 35000개라고 파악했고 sample의 갯수를 더해서 계산하면 432000개가 나오고, 이와 똑같은 갯수의 output을 serial monitor로 받았습니다.

그려보면 다음과 같구요.

2444b4b6cad8a34287e800dedd68a5af_1670407813_2227.jpg
 

하지만 input 함수를 파악하지 못해 systemIdentification을 사용하는 데 제약이 있습니다. input함수와 output함수를 어떻게 파악할 수 있을까요?

#include // For the ATOMIC_BLOCK macro
#define encoder0PinA 2 //encoder pin 2 and 3
#define encoder0PinB 3
int encoder0Pos = 0;
const int elements = 40; // number of frequencies
int Fs = 500; //sampling frequency of sin wave
int n = 500;//500; // number of samples
byte samples[500];
 // frequncy look up table
float t ,freq_arra[elements] = {0.1000000000000,  0.200000000000000, 0.300000000000000, 0.400000000000000, 0.500000000000000, 0.600000000000000, 0.700000000000000, 0.800000000000000, 0.900000000000000, 1.00000000000000,  1.10000000000000,  1.20000000000000,  1.30000000000000,  1.40000000000000,  1.50000000000000,  1.60000000000000,  1.70000000000000,  1.80000000000000,  1.90000000000000,  2, 2.50000000000000,  3, 3.50000000000000,  4, 4.50000000000000,  5, 5.50000000000000,  6, 6.50000000000000,  7, 7.50000000000000,  8, 8.50000000000000,  9, 9.50000000000000,  10, 11,12,13,14};
int samling_interval, no_samples;
 
void setup() {
pinMode(encoder0PinA, INPUT_PULLUP);
pinMode(encoder0PinB, INPUT_PULLUP);
attachInterrupt(0, doEncoderA, CHANGE); //interrupts to capture encoder data
attachInterrupt(1, doEncoderB, CHANGE);
Serial.begin (230400); // initialize serail monitor
  pinMode(10,OUTPUT);// declaration of PWM pins
  pinMode(11,OUTPUT);
for (int k = 0; k < n; k++)//calculating Sin wave values
{  t = (float)k / Fs;
   samples[k] = (byte) (127.0/1 * sin(2 * 3.142*t*1) + 127.0/1);
  }
}
 
void loop() {
  char value; //declaraing input variable
if(Serial.available()>0)
{    
  value = Serial.read();
  if(value == 'a'){
for(int m = 0; m < elements;m++){// loop for changing the frequencies
  samling_interval = (float)1000000/(freq_arra[m]*n);
  no_samples = (float)(freq_arra[m]*n/(50));
  digitalWrite(10 , HIGH); // All motor pin are '0'to avoid inertia for 1 second
  digitalWrite(11 , HIGH);
  delay(1000); // wait for 1 second
  encoder0Pos = 0; // to reset the position of encoder
for (int p = 0; p < 5*freq_arra[m]; p++){// to have 5sec signal starting from 0 degree
  for(int j = 0; j ){;j++
    if(j>=n/4 && j<3*n/4){ //signal between 90-270 degree
    analogWrite(10 , samples[j]);
    digitalWrite(11 , LOW);      
    }
     else{ //signal between 270->90 degree
    analogWrite(11 , samples[j]);
    digitalWrite(10 , LOW);      
    }
    Serial.print (encoder0Pos);
    Serial.write(13);
    Serial.write(10);
      if(freq_arra[m]<=1){
      delay(samling_interval/1000);// delay for sampling 2/frequency ms
      }
      else
      {
      delayMicroseconds(samling_interval); // delay for sampling 2000/frequency microseconds
    }
    }
}
}
Serial.print ('b'); // When sweep process complete 'b' is sent and motor stops motion
Serial.write(13);
Serial.write(10);
digitalWrite(10 , LOW);
digitalWrite(11 , LOW);
  }
  }
  }

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

댓글 2

조회수 1,513

master님의 댓글

master 작성일

for(int j = 0; j ){;j++
깨진 곳이 있네요?

sdwdjangwon님의 댓글

sdwdjangwon 댓글의 댓글 작성일

댓글이 달리면 수정이 안되는군요 for(int j=0; j<n; j++)입니다

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

MCU, AVR, 아두이노 등 전자공학에 관련된 질문을 무료회원가입 후 작성해주시면 전문가가 답변해드립니다.
ATMEGA128PWMLED초음파
아두이노AVR블루투스LCD
UART모터적외선ATMEGA
전체 스위치 센서
질문게시판 목록
제목 작성자 작성일 조회
질문 atmega128 분초시계에서 초부분이 잘안돼고있어요댓글[2] 이미지 rpdla 23-05-08 726
질문 가변 저항 입력을 0∼4095로 7-세그먼트에 표시한걸 0∼33 으로 7-세그먼트에 표시하는법댓글[2] 수포자 23-05-08 609
질문 아두이노 서보모터 제어 질문이있습니다댓글[1] apzk3 23-05-06 644
질문 atmega128로 분초 전자시계를 어떻게 만들어야하나요?댓글[5] 이미지첨부파일 rpdla 23-05-05 1631
질문 mpu 6050 과 gps 센서 질문댓글[1] Mick 23-05-05 500
질문 아두이노 GPS 확장 SPI통신 쉴드댓글[3] 이미지첨부파일 Mick 23-05-04 871
질문 gps 확장 spi통신 쉴드댓글[1] 이미지첨부파일 Mick 23-05-04 458
질문 아두이노 우노 보드 구입하려고 하는데 두 부품의 차이점이 뭔지 알려주시면 감사하겠습니다댓글[1] 나도할수있어아두 23-05-03 1130
질문 온도 센서 오류댓글[1] 핸찌니 23-05-03 534
질문 hm10으로 pwm모델을 제어하려고 합니다.댓글[6] 용용이 23-05-01 1445
질문 비콘댓글[1] 앋우이노 23-05-01 470
질문 atmega128 dc모터 코딩 질문입니다. 김자라 23-04-30 620
답변 답변글 답변 : atmega128 dc모터 코딩 질문입니다.댓글[4] master 23-04-30 1436
질문 여러센서 아두이노 연결관련 코드 핸찌니 23-04-29 785
질문 Ph 블루투스로 앱인벤터 출력 안녕하세요13 23-04-28 443
답변 답변글 답변 : Ph 블루투스로 앱인벤터 출력댓글[15] master 23-04-29 5642
질문 아두이노 프로젝트 - 여러센서연결문의댓글[6] 이미지 핸찌니 23-04-27 2254
질문 atmega128 fnd 24시간 시계댓글[1] 마이크로어려워 23-04-27 998
질문 아두이노 초음파센서와 HC06(블루투스)를 이용, 릴레이동작댓글[3] 나도할수있어아두 23-04-27 1370
질문 학부수업에서 마이크로프로세서를 배우고 있는데 혹시 작은 프로젝트 해볼거 없을까요??댓글[2] E10n 23-04-26 931
질문 아두이노 블루투스 서보 제어서 튐댓글[2] 첨부파일 타이지 23-04-24 1045
질문 AVR 질문입니다.댓글[1] 모지리학부생 23-04-22 580
질문 아트메가128 전류증폭 질문드립니다 ..!!댓글[5] 순길 23-04-21 1154
질문 아두이노 질문댓글[2] 이미지 1233 23-04-20 896
질문 스텝모터 감속 코딩 질문입니다. 무야더싱 23-04-19 472
답변 답변글 답변 : 스텝모터 감속 코딩 질문입니다.댓글[2] master 23-04-19 702
질문 atmega128 스위치로 스피커 제어하기댓글[6] 호구마 23-04-19 2250
질문 아트멜7.0 서보모터 스위치 제어 질문 드립니다.댓글[1] 순길 23-04-18 669
질문 모터드라이버와 모터 연결 문의댓글[1] 오후 23-04-14 625
질문 아두이노에 이산화탄소 센서 여러개 연결방법댓글[1] 생물공학도 23-04-14 847
게시물 검색

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