질문게시판 > 아두이노 esp32 컴파일 에러가 떠요. 아시는분 있다면 도와주세요..ㅜㅜ

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

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


BASIC4MCU | 질문게시판 | 아두이노 esp32 컴파일 에러가 떠요. 아시는분 있다면 도와주세요..ㅜㅜ

페이지 정보

작성자 동규 작성일2020-03-09 22:34 조회96회 댓글1건

본문

	

아두이노 컴파일중 에러가 낫는데 무슨 에러인지 모르겠어서 도움을 얻고자 글을 적어봅니다 

컴파일 하니 이런 에러가 뜨는데 무슨 뜻인가여 ㅠㅠㅠ ??

첨부 이미지

코드는
#include "Arduino.h"
#include

/* 모터드라이버 연결핀 */
#define DIR_PIN1 8 //스텝모터드라이버 DIR 연결핀-x0
#define CLK_PIN1 9 //스텝모터드라이버 CLK 연결핀-x0
#define DIR_PIN2 10 //스텝모터드라이버 DIR 연결핀-x1
#define CLK_PIN2 11 //스텝모터드라이버 CLK 연결핀-x1
#define DIR_PIN3 4 //스텝모터드라이버 DIR 연결핀-y2
#define CLK_PIN3 5 //스텝모터드라이버 CLK 연결핀-y2
#define DIR_PIN4 6 //스텝모터드라이버 DIR 연결핀-y3
#define CLK_PIN4 7 //스텝모터드라이버 CLK 연결핀-y3

/* 가변저항 연결핀 x축 */
#define POT_PINx A0
/* 가변저항 연결핀 Y축 */
#define POT_PINy A1

/* 스텝모터 구동 중간지점(데드존 영역) */
#define DEADZONE 20

/* 아날로그 입력값 0~1024 값으로 정역영역지정 */
#define POT_REV_MIN 0
#define POT_REV_MAX (512 - DEADZONE)
#define POT_FWD_MAX 1024
#define POT_FWD_MIN (512 + DEADZONE)

/* HCMotor 라이브러리 인스턴스 생성 */
HCMotor HCMotor;

void setup()
{

  /* 라이브러리 초기화 */
  HCMotor.Init();

  /* 모터0을 스텝모터로 설정하고 연결된 핀을 지정 */
  HCMotor.attach(0, STEPPER, CLK_PIN1, DIR_PIN1);  
  HCMotor.attach(1, STEPPER, CLK_PIN2, DIR_PIN2);
  HCMotor.attach(2, STEPPER, CLK_PIN3, DIR_PIN3);  
  HCMotor.attach(3, STEPPER, CLK_PIN4, DIR_PIN4);

  /* 모터를 연속동작모드로 설정*/
  HCMotor.Steps(0, CONTINUOUS);
  HCMotor.Steps(1, CONTINUOUS);  
  HCMotor.Steps(2, CONTINUOUS);
  HCMotor.Steps(3, CONTINUOUS);   
}


void loop()
{
  int Speed, Pot;

  /* 가변저항으로 부터 아날로그 값을 입력받음 */
{  Pot = analogRead(POT_PINx);

  /* 역방향? */
  if (Pot >= POT_REV_MIN && Pot <= POT_REV_MAX)
  {
    HCMotor.Direction(0, REVERSE);
    HCMotor.Direction(1, REVERSE);    
    Speed = map(Pot, POT_REV_MIN, POT_REV_MAX, 10, 1024);

    /* 정방향? */
  } else if (Pot >= POT_FWD_MIN && Pot <= POT_FWD_MAX)
  {
    HCMotor.Direction(0, FORWARD);    
    HCMotor.Direction(1, FORWARD);
    Speed = map(Pot, POT_FWD_MIN, POT_FWD_MAX, 1024, 10);

    /* 데드존(중간지점)? */
  } else
  {
    Speed = 0;
  }

  /* 속도설정 */
  HCMotor.DutyCycle(0, Speed);
  HCMotor.DutyCycle(1, Speed);  
}

  /* 가변저항으로 부터 아날로그 값을 입력받음 */
{  Pot = analogRead(POT_PINy);

  /* 역방향? */
  if (Pot >= POT_REV_MIN && Pot <= POT_REV_MAX)
  {
    HCMotor.Direction(2, REVERSE);
    HCMotor.Direction(3, REVERSE);    
    Speed = map(Pot, POT_REV_MIN, POT_REV_MAX, 10, 1024);

    /* 정방향? */
  } else if (Pot >= POT_FWD_MIN && Pot <= POT_FWD_MAX)
  {
    HCMotor.Direction(2, FORWARD);    
    HCMotor.Direction(3, FORWARD);
    Speed = map(Pot, POT_FWD_MIN, POT_FWD_MAX, 1024, 10);

    /* 데드존(중간지점)? */
  } else
  {
    Speed = 0;
  }

  /* 속도설정 */
  HCMotor.DutyCycle(2, Speed);
  HCMotor.DutyCycle(3, Speed);  
}
}






이렇게 되어있고 HCMOTER.h 라이브러리는

/* FILE:    HCMotor.cpp
   DATE:    09/07/15
   VERSION: 0.1
   AUTHOR:  Andrew Davies

11/03/15 version 0.1: Original version  
   
Library for driving DC and stepper motors.

You may copy, alter and reuse this code in any way you like, but please leave
reference to HobbyComponents.com in your comments if you redistribute this code.
This software may not be used directly for the purpose of selling products that
directly compete with Hobby Components Ltd's own range of products.

THIS SOFTWARE IS PROVIDED "AS IS". HOBBY COMPONENTS MAKES NO WARRANTIES, WHETHER
EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ACCURACY OR LACK OF NEGLIGENCE.
HOBBY COMPONENTS SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR ANY DAMAGES,
INCLUDING, BUT NOT LIMITED TO, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES FOR ANY
REASON WHATSOEVER.
*/


#include "HCMotor.h"
#include

MotorInfo Motor[MAXMOTORS];


/* Constructor to initialise the GPIO and library */
HCMotor::HCMotor(void)
{
/* Nothing to do ! */
}

/* Initialise the interrupt timer to generate the TDM/Clock signals in the 
   background. Set the timer an interrupt to trigger every 100uS. */
void HCMotor::Init(void)
{
HCMotor::_MotorTimer2Init(T2_CLK_DIV_32, 49);
}

/* Reconfigures the hardware timer 2 to trigger an interrupt */
void HCMotor::_MotorTimer2Init(byte prescaler, byte compare)
{
/* Turn off interrupts whilst we setup the timer */
cli();
/* Set timer mode to clear timer on compare match (mode 2)*/
TCCR2A = (1<

/* Set the prescaler */
TCCR2B = prescaler;

/* Clear timer 2 counter */
TCNT2 = 0;

/* Set the compare match register */
OCR2A = compare;

/* Enable timer 2 interrupt on compare match */
TIMSK2 = (1<

  /* Turn interrupts back on */
  sei();

}


/* Attaches a PWM output for a standard DC motor where:
MotorNum is a value used to reference which motor we wish to attach. Valid values are between 0 and MAXMOTORS.
MotorType is the type of motor being attached. Currently only one valid value (DCMOTOR)
Pin is the digital pin to attach it to (this can be any digital pin, not just the hardware PWM pins)
*/
void HCMotor::attach(byte MotorNum, byte MotorType, byte Pin)
{
if(MotorNum < MAXMOTORS)
{
/* Store the port number and mask for the required digital pin */
Motor[MotorNum].PortA = portOutputRegister(digitalPinToPort(Pin));
Motor[MotorNum].ActivePort = Motor[MotorNum].PortA;
Motor[MotorNum].MaskA = digitalPinToBitMask(Pin);
Motor[MotorNum].ActiveMask = Motor[MotorNum].MaskA;

/* Set all values used for generating the pulse to zero */
Motor[MotorNum].Counter = 0;
Motor[MotorNum].PulseHigh = 0;
Motor[MotorNum].PulseLength = 0;
/* If motor is already attached to pins then disable them before 
   attaching to new pins */
if (Motor[MotorNum].Attached)
{
pinMode(Motor[MotorNum].PinA, INPUT); 
}else
{
Motor[MotorNum].Attached = true;
}
/* Save the motor type and attached pin */
Motor[MotorNum].MotorType = MotorType;
Motor[MotorNum].PinA = Pin;
/* Set the digital pin to an output. */
pinMode(Pin, OUTPUT);
}
}

/* Attaches a PWM output for a standard DC motor with H-bridge driver or a stepper motor where:
MotorNum is a value used to reference which motor we wish to attach. Valid values are between 0 and MAXMOTORS.
MotorType is the type of motor being attached. Valid values are DCMOTOR_H_BRIDGE or STEPPER
PinA  PinB are the digital pins to attach it to. For a stepper motor PinA is the clock pin and PinB is the direction pin.
*/
void HCMotor::attach(byte MotorNum, byte MotorType, byte PinA, byte PinB)
{
if(MotorNum < MAXMOTORS)
{
/* Store the port number and mask for the required digital pins */
Motor[MotorNum].PortA = portOutputRegister(digitalPinToPort(PinA));
Motor[MotorNum].PortB = portOutputRegister(digitalPinToPort(PinB));
Motor[MotorNum].MaskA = digitalPinToBitMask(PinA);
Motor[MotorNum].MaskB = digitalPinToBitMask(PinB);
/* Set an active direction */
if(Motor[MotorNum].Direction == FORWARD || Motor[MotorNum].MotorType == STEPPER)
{
Motor[MotorNum].ActivePort = Motor[MotorNum].PortA;
Motor[MotorNum].ActiveMask = Motor[MotorNum].MaskA;
}else
{
Motor[MotorNum].ActivePort = Motor[MotorNum].PortB;
Motor[MotorNum].ActiveMask = Motor[MotorNum].MaskB;
}

/* Set all values used for generating the pulse to zero */
Motor[MotorNum].Counter = 0;
Motor[MotorNum].PulseHigh = 0;
Motor[MotorNum].PulseLength = 0;
/* If motor is already attached to pins then disable them before 
   attaching to new pins */
if (Motor[MotorNum].Attached)
{
pinMode(Motor[MotorNum].PinA, INPUT);
pinMode(Motor[MotorNum].PinB, INPUT);
}else
{
Motor[MotorNum].Attached = true;
}
/* Save the motor type and attached pins */
Motor[MotorNum].MotorType = MotorType;
Motor[MotorNum].PinA = PinA;
Motor[MotorNum].PinB = PinB;
/* Set the digital pins to an output. */
pinMode(PinA, OUTPUT);
pinMode(PinB, OUTPUT);
}
}


/* Removes an attached motor from the list and sets its pin(s) to inputs where:
   MotorNum is a value used to reference which motor we wish to detach. */
void HCMotor::detach(byte MotorNum)
{
if (Motor[MotorNum].Attached)
{
Motor[MotorNum].Counter = 0;
Motor[MotorNum].PulseHigh = 0;
Motor[MotorNum].PulseLength = 0;
pinMode(Motor[MotorNum].PinA, INPUT);
if(Motor[MotorNum].MotorType == DCMOTOR_H_BRIDGE || Motor[MotorNum].MotorType == STEPPER)
pinMode(Motor[MotorNum].PinB, INPUT);
Motor[MotorNum].Attached = false;
}
}


/* Sets the on part of the duty cycle for DC motors where:
   MotorNum is a value used to reference which motor we wish to alter.
   Time is the amount of the duty cycle the motor will be on for in 100uS increments. */
void HCMotor::OnTime(byte MotorNum, unsigned int Time)
{
if (Motor[MotorNum].Attached && Motor[MotorNum].MotorType != STEPPER)
{
if(Time <= Motor[MotorNum].PulseLength)
{
Motor[MotorNum].PulseHigh = Time;
}else
{
Motor[MotorNum].PulseHigh = Motor[MotorNum].PulseLength;
}
}
}

/* For DC motors sets the duty cycle length, for stepper motors the clock speed, where:
   MotorNum is a value used to reference which motor we wish to alter.
   Time is the duty cycle time in uS. For stepper motors this sets the clock speed. */
void HCMotor::DutyCycle(byte MotorNum, unsigned int Time)
{
if (Motor[MotorNum].Attached)
{
Motor[MotorNum].PulseLength = Time;
if(Motor[MotorNum].PulseHigh > Motor[MotorNum].PulseLength)
Motor[MotorNum].PulseHigh = Motor[MotorNum].PulseLength;
if(Motor[MotorNum].MotorType == STEPPER)
Motor[MotorNum].PulseHigh = Motor[MotorNum].PulseLength >> 1;

}
}

/* Sets the direction of the motor for H-Bridge and stepper motors where:
MotorNum is a value used to reference which motor we wish to alter.
Direction is the direction of the motor. Valid values are FORWARD & REVERSE
For H-Bridge motors this will switch the pin the PWM is output to and the sets the opposite pin low.
For stepper motors the will set the direction pin (PinB) high or low. */
void HCMotor::Direction(byte MotorNum, boolean Direction)
{
if(Motor[MotorNum].MotorType == DCMOTOR_H_BRIDGE)
{
/* If H-Bridge motor then swat the PWM pin */
if(Direction == FORWARD)
{
Motor[MotorNum].ActivePort = Motor[MotorNum].PortA;
Motor[MotorNum].ActiveMask = Motor[MotorNum].MaskA;
digitalWrite(Motor[MotorNum].PinB, LOW);
}else
{
Motor[MotorNum].ActivePort = Motor[MotorNum].PortB;
Motor[MotorNum].ActiveMask = Motor[MotorNum].MaskB;
digitalWrite(Motor[MotorNum].PinA, LOW);
}
/* If Stepper motor then change the direction pin */
}else if(Motor[MotorNum].MotorType == STEPPER)
{
digitalWrite(Motor[MotorNum].PinB, Direction);
}
Motor[MotorNum].Direction = Direction;
}

/* Sets the number of steps (pulses) to step a stepper motor where:
   MotorNum is a value used to reference which motor we wish to alter.
   Steps is the number of steps to step the motor.
   
   Note that for DC motors this function does nothing. */
void HCMotor::Steps(byte MotorNum, unsigned int Steps)
{
Motor[MotorNum].Steps = Steps;
}


/* Interrupt service routine for Timer 2 compare match */
ISR(TIMER2_COMPA_vect)
{
byte Index;
/* Step through each motor */
for (Index = 0; Index < MAXMOTORS; Index++)
{
/* Check if the motor is attached, duty cycle is not zero, and if it is
     a stepper motor number of steps is not zero */
if(Motor[Index].PulseLength && 
   Motor[Index].Attached && 
   (Motor[Index].MotorType != STEPPER || Motor[Index].Steps))
{
/* Tick up the counter time */
Motor[Index].Counter++;

/* If the counter time is still in the ON time then set the PWM/Clock pin high */
if (Motor[Index].Counter <= Motor[Index].PulseHigh)
{
*Motor[Index].ActivePort |= Motor[Index].ActiveMask;
/* Else set the pin low */
}else
{
*Motor[Index].ActivePort &= ~Motor[Index].ActiveMask;
}
  
/* If the counter time has reached the end of the duty cycle then reset it */
if (Motor[Index].Counter >= Motor[Index].PulseLength)
{
Motor[Index].Counter = 0;
/* If motor is a stepper motor then reduce the step counter by one */
if (Motor[Index].MotorType == STEPPER && Motor[Index].Steps && Motor[Index].Steps != CONTINUOUS)
Motor[Index].Steps--;
}
}
}
}

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

댓글 1

조회수 96

master님의 댓글

master 작성일

최근 컴퓨터 고장으로 인해서 아두이노가 깔려있지 않은 상태이며, 당분간 아두이노 설치는 하지 않을 것이므로 컴파일 해볼 수가 없습니다.
[오류메시지복사] 버튼을 클릭하면 클립보드에 복사되며, 메모장 등에 붙여넣기해서 오류 내용을 참고하세요

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

MCU, AVR, 아두이노 등 전자공학에 관련된 질문을 무료회원가입 후 작성해주시면 전문가가 답변해드립니다.
ATMEGA128PWMLED초음파
아두이노AVR블루투스LCD
UART모터적외선ATMEGA
전체 스위치 센서
질문게시판 목록
제목 작성자 작성일 조회
공지 MCU, AVR, 아두이노 등 전자공학에 관련된 질문은 질문게시판에서만 작성 가능합니다. 스태프 19-01-15 1417
공지 사이트 이용 안내댓글[11] master 17-10-29 10301
공지 [무료 공개] 소스코드 하이라이트 v2.0 beta [2013.02.07]댓글[1] 이미지첨부파일 master 18-01-23 3865
질문 스톱워치 코드를 어떻게 해야할까요? 새글 공부즁임다 20-03-29 6
답변 답변글 답변 : 스톱워치 코드를 어떻게 해야할까요? 새글 master 20-03-29 7
질문 아두이노 좀 도와주세요 ~ 영석 20-03-28 15
답변 답변글 답변 : 아두이노 좀 도와주세요 ~ master 20-03-28 24
질문 avr led제어하는것좀 도와주세요!!댓글[1] 스펙일등 20-03-26 40
질문 아두이노 서보모터 제어 ppap 20-03-26 33
답변 답변글 답변 : 아두이노 서보모터 제어댓글[7] master 20-03-26 50
질문 atmega128 시리얼통신 질문댓글[1] BLOO 20-03-23 62
질문 여러 개의 HC-06 값을 하나의 스마트폰으로 전송받는 코딩을 작성하려고 합니다댓글[3] 봄빛 20-03-21 63
질문 아두이노 PWM을 이용한 12V LED 제어댓글[4] namse12 20-03-16 92
답변 답변글 답변 : 아두이노 PWM을 이용한 12V LED 제어댓글[1] master 20-03-19 66
질문 아두이노 메가를 이용하여 lidar 거리 측정기 코딩 질문입니다. delay를 millis() 함수로 바꾸고… 첨부파일 gktt3 20-03-15 43
답변 답변글 답변 : 아두이노 메가를 이용하여 lidar 거리 측정기 코딩 질문입니다. delay를 millis() 함수… master 20-03-16 56
현재글 아두이노 esp32 컴파일 에러가 떠요. 아시는분 있다면 도와주세요..ㅜㅜ댓글[1] 동규 20-03-09 97
질문 BLDC MOTOR CONTROL 문의댓글[2] 인수거사 20-03-09 103
질문 i2c 멈춤현상댓글[3] 오박사 20-03-08 83
질문 atmega128 adc 사용하기댓글[4] Halo 20-03-07 114
답변 답변글 답변 : atmega128 adc 사용하기 master 20-03-07 57
질문 아두이노 졸음 운전 방지 코딩 질문 첨부파일 심플민 20-03-05 90
답변 답변글 답변 : 아두이노 졸음 운전 방지 코딩 질문 master 20-03-06 87
답변 답변글 답변 : 답변 : 아두이노 졸음 운전 방지 코딩 질문댓글[3] 심플민 20-03-25 31
질문 아두이노 초짜입니다 자꾸 막혀서 질문드려요댓글[1] 이칭이 20-03-05 83
질문 아두이노 초기화 질문 master 20-03-03 54
질문 아두이노 메가로 영상제어... 도와주세요 ㅠㅠ댓글[1] 뱅구 20-03-03 78
질문 보드가 고장인지 조도센서 인식이 안됩니다 ㅠ댓글[4] 쉘쉘김쉘쉘 20-03-01 123
질문 TFT LCD 버튼값 출력하기 2번째 질문입니다! 제발 도와주세요ㅠㅠ 쉘쉘김쉘쉘 20-03-01 76
답변 답변글 답변 : TFT LCD 버튼값 출력하기 2번째 질문입니다! 제발 도와주세요ㅠㅠ댓글[5] master 20-03-01 113
게시물 검색

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