Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/engineermichael/arduino-research-project-engineering-publication-

Pending Revisions, NDA Final Version
https://github.com/engineermichael/arduino-research-project-engineering-publication-

arduino documentation embedded-c home-automation ieee publication-repository

Last synced: 17 days ago
JSON representation

Pending Revisions, NDA Final Version

Awesome Lists containing this project

README

        

# Arduino-Research-Project-Engineering-Publication-

Creating a system using an Arduino Mega for 3D printing constructions of buildings and houses requires combining multiple aspects: controlling stepper motors for movement, coordinating with extruders for material deposition, and ensuring precise control over the entire printing process.
The following steps and code outline how to develop a basic 3D printer control system for construction purposes using the Arduino Mega.
Components Required:
1. Arduino Mega 2560 (primary controller)
2. Stepper Motors (typically 3 or 4 for X, Y, Z axes and Extruder)
3. Motor Drivers (e.g., A4988 or DRV8825)
4. Hotend Extruder (for material deposition)
5. Heated Bed (optional but recommended for better adhesion)
6. Endstops (for positioning and homing the printer)
7. Power Supply (sufficient for motors and heated components)
8. Temperature Sensor (e.g., Thermistor) (for controlling the extruder and heated bed temperature)
9. SD Card Module (to store and load G-code files)
10. 3D Printing Material (e.g., PLA, concrete, or other construction-grade materials)
Wiring Overview:
1. Stepper Motors: Connect the stepper motors to the motor driver boards, and then connect the motor driver to the Arduino Mega pins.
2. Heated Bed/Hotend: Connect the temperature sensors (e.g., thermistors) to analog pins and the heating elements to a MOSFET or a similar control circuit.
3. Endstops: Connect endstops to digital input pins (for X, Y, Z axes).
4. SD Card Module: Connect an SD card module to the Mega using SPI pins (MOSI, MISO, SCK, and SS).
Step 1: Install Libraries
First, you’ll need to install the necessary libraries for controlling the 3D printer. The most widely used libraries for 3D printers include AccelStepper for motor control and U8g2 (or similar) for graphical displays if you’re planning on adding an LCD.
1. AccelStepper Library (for controlling stepper motors)
2. SD Library (for reading G-code files)
3. Thermistor or OneWire for temperature sensor management
Install these libraries via Arduino IDE:
• Go to Sketch > Include Library > Manage Libraries
• Search for the required libraries and click “Install”.
Step 2: Arduino Mega Pin Mapping
Here is an example of pin mapping for a 3D printer:
Component PinX-Axis Stepper 2Y-Axis Stepper 3Z-Axis Stepper 4Extruder Stepper 5Endstop X 6Endstop Y 7Endstop Z 8Hotend Thermistor A0Heated Bed Thermistor A1Extruder Heater Digital Pin 9Heated Bed Digital Pin 10SD Card (MOSI) 11SD Card (MISO) 12SD Card (SCK) 13SD Card (CS) 53
Step 3: Basic Embedded C Code for 3D Printer
Below is an example of Arduino code for controlling a basic 3D printer. This code integrates motor control, temperature management, and SD card handling to load and process G-code commands.
#include

#include

// Pin definitions

#define X_STEP_PIN 2

#define X_DIR_PIN 5

#define Y_STEP_PIN 3

#define Y_DIR_PIN 6

#define Z_STEP_PIN 4

#define Z_DIR_PIN 7

#define EXTRUDER_STEP_PIN 8

#define EXTRUDER_DIR_PIN 9

#define HEATER_PIN 10

#define BED_HEATER_PIN 11

// Define the stepper motors

AccelStepper stepperX(AccelStepper::DRIVER, X_STEP_PIN, X_DIR_PIN);

AccelStepper stepperY(AccelStepper::DRIVER, Y_STEP_PIN, Y_DIR_PIN);

AccelStepper stepperZ(AccelStepper::DRIVER, Z_STEP_PIN, Z_DIR_PIN);

AccelStepper extruder(AccelStepper::DRIVER, EXTRUDER_STEP_PIN, EXTRUDER_DIR_PIN);
// Thermistor Pin

#define TEMP_PIN A0 // Thermistor for the extruder

#define BED_TEMP_PIN A1 // Thermistor for heated bed

// Constants for G-code commands

const float extruderSpeed = 100.0; // Speed for extruder movement

const float moveSpeed = 200.0; // Speed for X, Y, Z axis movement

const float extruderHeatThreshold = 200.0; // Temperature threshold for extruder

// Variables for storing G-code commands and parsing

char receivedCommand[50];

int index = 0;

File gCodeFile;

void setup() {

Serial.begin(115200);

pinMode(HEATER_PIN, OUTPUT);

pinMode(BED_HEATER_PIN, OUTPUT);

// Initialize SD card

if (!SD.begin(53)) {

Serial.println("SD Card initialization failed!");

return;

}

// Load the G-code file

gCodeFile = SD.open("print.gcode");

if (!gCodeFile) {

Serial.println("Failed to open G-code file!");

return;

}

// Set up stepper motors

stepperX.setMaxSpeed(2000);

stepperY.setMaxSpeed(2000);

stepperZ.setMaxSpeed(1000);

extruder.setMaxSpeed(500);

// Preheat extruder and bed

preheat();

}

void loop() {

if (gCodeFile.available()) {

// Read one line of G-code

char c = gCodeFile.read();

if (c == '\n' || c == '\r') {

// Process command

processGCode(receivedCommand);

index = 0;

} else {

receivedCommand[index++] = c;

}

} else {

// If the G-code file is finished, stop the process

Serial.println("Printing complete.");

while (true);

}

}

void processGCode(char *command) { 
// Example G-code parsing: G1 commands for movement and extrusion 
if (strncmp(command, "G1", 2) == 0) {   
// Move command    float x = extractGCodeValue(command, 'X');   
float y = extractGCodeValue(command, 'Y');   
float z = extractGCodeValue(command, 'Z');   
float e = extractGCodeValue(command, 'E'); // Extruder movement

if (x != -1) stepperX.moveTo(x);

if (y != -1) stepperY.moveTo(y);

if (z != -1) stepperZ.moveTo(z);

if (e != -1) extruder.moveTo(e);

stepperX.run();

stepperY.run();

stepperZ.run();

extruder.run();

} else if (strncmp(command, "M104", 4) == 0) {

// M104: Set extruder temperature

float temp = extractGCodeValue(command, 'S');

setExtruderTemperature(temp);

} else if (strncmp(command, "M140", 4) == 0) {

// M140: Set bed temperature

float temp = extractGCodeValue(command, 'S');

setBedTemperature(temp);

}

}
float extractGCodeValue(char *command, char axis) {

char *ptr = strchr(command, axis);

if (ptr != NULL) {

return atof(ptr + 1);

}

return -1;

}

void setExtruderTemperature(float targetTemp) {

while (getTemperature(TEMP_PIN) < targetTemp) {

analogWrite(HEATER_PIN, map(targetTemp, 0, 300, 0, 255));

}

}

void setBedTemperature(float targetTemp) {

while (getTemperature(BED_TEMP_PIN) < targetTemp) {

analogWrite(BED_HEATER_PIN, map(targetTemp, 0, 100, 0, 255));

}

}
float getTemperature(int pin) {

// Simple temperature sensor reading (for thermistor or other sensors)

int sensorValue = analogRead(pin);

return sensorValue * (5.0 / 1023.0) * 100.0; // Basic conversion for simplicity

}

void preheat() {

// Preheat extruder and bed

setExtruderTemperature(200.0);

setBedTemperature(60.0);

}

Step 4: Explanation of the Code:
1. Stepper Motor Control:
• We use the AccelStepper library to control the stepper motors (for X, Y, Z axes, and the extruder). The motors move according to the G-code commands parsed from the file.
2. Temperature Control:
3. • The M104 and M140 G-code commands set the temperatures of the extruder and the heated bed, respectively. The code uses analog output to control MOSFET
GNU General Public License v3.0