use atmega32 to control stepper motors

Signed-off-by: Stepan Usatyuk <usaatyuk@ustk.me>
This commit is contained in:
2019-05-16 14:36:40 +03:00
parent c7299e7916
commit a96a47f0f9
26 changed files with 513 additions and 200 deletions

View File

@@ -0,0 +1,153 @@
#include <Arduino.h>
#include <Servo.h>
#include <Wire.h>
#include "Globals.h"
#include "common/Commands.h"
int curRPM = DEF_RPM;
int adjustDelay = 10;
void adjustRPM() {
unsigned int stepsX = servoStepper.getRemainingSteps();
unsigned int stepsY = eggStepper.getRemainingSteps();
if (stepsX != 0 && stepsY != 0) {
if (stepsX > stepsY) {
float rpm = (float)curRPM * (float)stepsY / (float)stepsX;
eggStepperRPM = rpm;
} else if (stepsY > stepsX) {
float rpm = (float)curRPM * (float)stepsX / (float)stepsY;
servoStepperRPM = rpm;
} else {
eggStepperRPM = curRPM;
servoStepperRPM = curRPM;
}
recalculateDelays = true;
}
}
int curFloat = 0;
float command[4];
bool newCommand = false;
bool executing = false;
int curByte = 0;
byte rxBuffer[4];
void receiveEvent(int howMany) {
while (Wire.available() > 0) {
if (!newCommand) {
char c = Wire.read();
rxBuffer[curByte] = c;
curByte++;
if (curByte == 4) {
curByte = 0;
bytesToFloat(&command[curFloat], rxBuffer);
curFloat++;
}
if (curFloat == 4) {
curFloat = 0;
newCommand = true;
}
}
}
}
byte txBuffer[5 * sizeof(float)];
void requestEvent() {
if (command[0] == M99) {
floatToBytes(&txBuffer[0], servoStepper.getPos());
floatToBytes(&txBuffer[sizeof(float)], eggStepper.getPos());
floatToBytes(&txBuffer[sizeof(float) * 2], servoStepper.getPosMm());
floatToBytes(&txBuffer[sizeof(float) * 3], eggStepper.getPosMm());
floatToBytes(&txBuffer[sizeof(float) * 4], (float)pen.getEngaged());
Wire.write(txBuffer, 5 * sizeof(float));
} else if (executing || newCommand) {
Wire.write(WAIT);
} else {
Wire.write(NEXT);
}
}
float calculateDelay(float rpm, int stepsPerRevolution) {
return ((float)1000 * (float)60) / (rpm * (float)stepsPerRevolution);
}
Servo servo;
void execCommand(float *command) {
if (command[0] == G01 || command[0] == G00) {
if (command[0] == G01) {
needAdjust = true;
} else {
needAdjust = false;
}
if (command[X] != -1) {
servoStepper.moveTo(command[X]);
}
if (command[Y] != -1) {
eggStepper.moveTo(command[Y]);
}
if (command[Z] < 0) {
pen.engage();
}
if (command[Z] >= 0) {
pen.disengage();
}
adjustRPM();
return;
}
}
void setup() {
cli();
Serial.begin(115200);
Wire.begin(8);
Wire.onReceive(receiveEvent);
Wire.onRequest(requestEvent);
Serial.println("Hello!");
recalculateDelays = true;
eggStepperRPM = servoStepperRPM = 4;
OCR2 = 250;
TCCR2 |= (1 << WGM12) | (1 << CS22);
TIMSK |= (1 << OCIE2);
sei();
servoStepper.setPos(X_LIMIT);
pen.init();
}
ISR(TIMER2_COMP_vect) {
unsigned long ms = millis();
if (fmod(ms, eggStepperDelay) < 1) {
eggStepper.doStep();
}
if (fmod(ms, servoStepperDelay) < 1) {
servoStepper.doStep();
}
if (fmod(ms, adjustDelay) < 1) {
adjustRPM();
}
}
void loop() {
if (eggStepper.getRemainingSteps() == 0 &&
servoStepper.getRemainingSteps() == 0) {
executing = false;
}
if (newCommand) {
newCommand = false;
executing = true;
execCommand(command);
}
if (recalculateDelays) {
eggStepperDelay = calculateDelay(eggStepperRPM, STEPS_PER_REVOLUTION);
servoStepperDelay =
calculateDelay(servoStepperRPM, STEPS_PER_REVOLUTION);
recalculateDelays = false;
}
}