Difference between revisions of "Raspberry Pi CNC v2.51"

From Protoneer - Wiki
Jump to: navigation, search
(Installation and configuration)
m (F5dta moved page Raspberry Pi CNC to Raspberry Pi CNC v2.51 without leaving a redirect)
 
(17 intermediate revisions by one user not shown)
Line 14: Line 14:
 
</gallery>
 
</gallery>
  
==Availability and Update Notifications==
+
==Availability, Update Notifications and Forums==
 
: [http://stores.ebay.com/Protoneer Protoneer Shop]
 
: [http://stores.ebay.com/Protoneer Protoneer Shop]
 
: [http://eepurl.com/DIq-z Raspberry Pi CNC Board News-Letter]
 
: [http://eepurl.com/DIq-z Raspberry Pi CNC Board News-Letter]
 +
: [http://forum.protoneer.co.nz/viewforum.php?f=7 Raspberry Pi CNC board forum section]
  
 
==Installation and configuration==
 
==Installation and configuration==
Line 127: Line 128:
 
GRBL v0.9 setting $21 needs to be set to 1 to activate hard-limits. Setting $22 also activated the Homing functionality.
 
GRBL v0.9 setting $21 needs to be set to 1 to activate hard-limits. Setting $22 also activated the Homing functionality.
  
=== Clone Drive ===
+
'''V2.51''' Introduces End-stop and Probe line filters to prevent noise on the lines.
 +
 
 +
=== Clone Drive (Introduced with V2.51) ===
 
The 4th Stepper Driver Socket can be configured to clone any of the other Axes. Configuration is done with the two rows of jumper headers situated under the Nano board.
 
The 4th Stepper Driver Socket can be configured to clone any of the other Axes. Configuration is done with the two rows of jumper headers situated under the Nano board.
  
... Updated Diagrams to follow soon ...
 
  
Removing all the jumpers for the two rows of headers disables the 4th Stepper Driver Socket.
+
<gallery mode=packed style="text-align:left" perrow=4>
 +
File:Raspberry_Pi_CNC_Clone_X.png|4th Socket Cloning X Axis
 +
File:Raspberry_Pi_CNC_Clone_Y.png|4th Socket Cloning Y Axis
 +
File:Raspberry_Pi_CNC_Clone_Z.png|4th Socket Cloning Z Axis
 +
File:UnConnected.png|4th Socket Disconnected
 +
</gallery>
  
=== External Drivers and Buttons ===
+
In the images above the green sections indicates a jumper positions to configure the 4th Stepper Motor Socket.
. . .
+
  
==Software==
+
=== External Drivers===
In order for the GRBL to communicate with the Raspberry Pi, the hardware serial port on the Raspberry Pi needs to be enabled and working. HobbyTronics has a good tutorial on how to set it up and test it. [http://www.hobbytronics.co.uk/raspberry-pi-serial-port Raspberry Pi Serial Port setup]
+
Below are images of the pins(in red) needed to connect to an external stepper driver for each axis. External Drivers usually run at 3.3-5V logic with the Raspberry Pi CNC board using 5V. (Check the external driver details before connecting.)
  
===Firmware (GRBL + Micro-Controller)===
+
Needed pins are as follow:
GRBL is the magic that does the actual control of the CNC machines.
+
* Stepper Pin
 +
* Direction Pin
 +
* Enable Pin
 +
* Ground Pin
  
For more details : [https://github.com/grbl/grbl GRBL]
+
Special attention needs to be taken with the Enable pin. Pololu Drivers activate when the enable pin goes low/grounded. If the external drivers you are using needs active high you will not be able to use the enable pin but can instead just connect the external drivers enable pin to 5V to enable it.
  
The Raspberry CNC board comes pre-loaded with GRBL but can be updated as follows : [https://github.com/grbl/grbl/wiki/Flashing-Grbl-to-an-Arduino Flashing Grbl to an Arduino]
+
<gallery mode=packed style="text-align:left" perrow=4>
 +
File:ExternalDriver_Button_Pins.png|External Drivers and Control Button pins
 +
File:ExternalDrivers_X_Axis.png|X-Axis pins
 +
File:ExternalDrivers_Y_Axis.png|Y-Axis pins
 +
File:ExternalDrivers_Z_Axis.png|Z-Axis pins
 +
File:ExternalDrivers_Cloned_Axis.png|Cloned-Axis pins
 +
</gallery>
  
 +
=== Button Controls===
 +
The buttons : RESET,ABORT,HOLD,RESUME work with normally open buttons and gets activated when grounded. All buttons are pulled high.
  
----
+
===Coolant, Spindle Direction, Spindle Speed===
===User Interfaces (Raspberry Pi)===
+
'''GCode Commands''':
 +
* S0 - S1000 - This command set the spindle speed. (0-1000 with 1000 being 100% speed.)
 +
* M3 / M4 - Enables the spindle clockwise or anti-clockwise. The Spindle Direction pin is set accordingly(Anti-clockwise turns direction pin high). Sets the Spindle speed pin accordingly.
 +
* M5 - Disables and pulls spindle pin low.
  
 +
Examples:
 +
M3 S500 -> Enables spindle in clockwise direction at 50% speed.
  
----
+
Keep in mind that the direction pin does not reset when the M5 command is used.
====bCNC [Python][Recommended]====
+
bCNC is a GRBL CNC command sender, auto-leveller and g-code editor.
+
  
'''We have created a special Raspberry Pi Image with bCNC pre-installed. [[Raspberry Pi CNC User Interface SD Card Image]]'''
+
====Coolant====
 +
'''GCode Commands''':
 +
* M8 - Enables the coolant and pulls the pin high.
 +
* M9 - Disables and pulls the pin low.
  
[[File:BCNC.png|300px|thumb|left|alt bCNC]]
+
===Probe===
'''Features:'''
+
...
* G-code sender + Editor - Compatible with GRBL 0.9i
+
* Workspace configuration (dialog for G54..G59 commands)
+
* Auto leveling, Z-probing and auto leveling by altering the g-code during sending
+
* Basic CAM features (profiling, drilling)
+
* User configurable database of materials, endmills, stock
+
* Graphically moving and arranging objects
+
* Web pendant to be used via smart phones
+
* Graphical display of the g-code, and workspace
+
* Extra's : Finger joint box generator
+
  
 +
==Software==
 +
In order for the GRBL to communicate with the Raspberry Pi, the hardware serial port on the Raspberry Pi needs to be enabled and working. HobbyTronics has a good tutorial on how to set it up and test it. [http://www.hobbytronics.co.uk/raspberry-pi-serial-port Raspberry Pi Serial Port setup]
  
[https://github.com/vlachoudis/bCNC/wiki bCNC Wiki]
+
===Firmware (GRBL + Micro-Controller)===
 +
GRBL is the magic that does the actual control of the CNC machines.  
  
 +
For more details : [https://github.com/grbl/grbl GRBL]
  
Source code is available at [https://github.com/vlachoudis/bCNC]
+
The Raspberry CNC board comes pre-loaded with GRBL but can be updated as follows : [https://github.com/grbl/grbl/wiki/Flashing-Grbl-to-an-Arduino Flashing Grbl to an Arduino]
Install instructions - [https://github.com/vlachoudis/bCNC/wiki/OS]
+
  
  
 
----
 
----
 +
==Hardware==
 +
===Version 2.58===
 +
* Replaced the Arduino Nano with a embedded micro-controller(ATMEGA328 - Arduino UNO compatible)
 +
* Add reset circuitry to enable programming directly from the Raspberry Pi. ISP pins added and preloaded with the Opti-Boot bootloader. This opens the door for other firmwares like Firmata.
 +
* Replaced clone jumpers with solder-able jumpers.
 +
* Later batches might have dip-switches instead of Jumper headers.
 +
* First Protoneer board to be mode on our Pick and Place machine.
  
====Serial Interface====
+
<gallery mode=packed style="text-align:left" perrow=5>
The micro-controller is connected to the Rapsberry Pi via the GPIO serial pins. To connect to the onboard serial port of the Raspberry Pi you will need a serial terminal application like [http://www.hobbytronics.co.uk/raspberry-pi-serial-port minicom] or [http://blog.protoneer.co.nz/install-and-run-putty-on-your-raspberry-pi/ putty] to connect.
+
File:RPI-CNC-V258-Front.jpg
 +
File:RPI-CNC-V258-Front-MCU.jpg
 +
File:RPI-CNC-V258-Top.jpg
 +
File:RPI-CNC-V258-Back001.jpg
 +
File:RPI-CNC-V258-Clone.jpg
 +
File:RPI-CNC-V258-FrontSteppers001.jpg
 +
File:RPI-CNC-V258-FrontSteppers002.jpg
 +
File:RPI-CNC-V258-CAD-Front.jpg
 +
File:RPI-CNC-V258-CAD-Back.jpg
 +
</gallery>
  
;Serial port details (GRBL 0.9):
 
: Port : /dev/ttyAMA0
 
: Baud Rate : 115200
 
 
 
----
 
====G-Code streaming script for GRBL [Python] ====
 
This is a simple [https://www.python.org/ Python] script that allows you to send G-Code files to GRBL.
 
 
Download : [https://github.com/grbl/grbl/tree/master/doc/script Stream.py]
 
 
 
----
 
====Raspberry Pi CNC - Web interface====
 
[https://github.com/Protoneer/Raspberry-Pi-CNC Raspberry Pi CNC]
 
 
==Hardware==
 
 
===Version 2.51===
 
===Version 2.51===
 
* Extra Stepper Drivers Socket that can clone one of the other Axes.
 
* Extra Stepper Drivers Socket that can clone one of the other Axes.

Latest revision as of 22:30, 9 June 2016

Overview

Raspberry Pi CNC Board V215 Front2.JPG

The RPI CNC Board combines a real-time CNC controller(Micro-controller running GRBL) with a powerful credit card size computer(Raspberry Pi).

By combining the two systems we have created an eco-system where the Raspberry Pi provides benefits like: Processing power, connectivity(IOT) and a well supported community.

The board plugs directly into the Raspberry Pi General Purpose Input/Output pins, with the micro-controller and Raspberry Pi communicating via serial. (/dev/ttyAMA0)


Availability, Update Notifications and Forums

Protoneer Shop
Raspberry Pi CNC Board News-Letter
Raspberry Pi CNC board forum section

Installation and configuration

IMPORTANT: None of the components should be powered while installing or configuring.

Quick Start Guide

WARNING: Do not power up the board with stepper drivers installed if they are not connected to stepper motors. The stepper drivers are current limiting and will overheat if they are not connected.


Raspberry Pi CNC - Quick Start Guide




Wiring Diagram

Raspberry Pi CNC Wiring diagram.png ... Diagram Will Be Updated To The 4 Stepper Setup Soon ...


Micro Stepping Jumpers

In the tables below High indicates that a Jumper is inserted and Low indicates that no jumper is inserted.

Pololu A4988 Link
Jumper 1 Jumper 2 Jumper 3 Microstep Resolution
Low Low Low Full step
High Low Low 1/2 step
Low High Low 1/4 step
High High Low 1/8 step
High High High 1/16 step
Pololu DRV8825 Link
Jumper 1 Jumper 2 Jumper 3 Microstep Resolution
Low Low Low Full step
High Low Low 1/2 step
Low High Low 1/4 step
High High Low 1/8 step
Low Low High 1/16 step
High Low High 1/32 step
Low High High 1/32 step
High High High 1/32 step

End Stops

End Stops use normally-open push-button type switches. The End-stop socket shares a common ground that connects to each axis end-stop. The pins are pulled high by the micro controller's internal pull-ups and will activate the end-stop when the pin is connected to ground.

GRBL v0.9 setting $21 needs to be set to 1 to activate hard-limits. Setting $22 also activated the Homing functionality.

V2.51 Introduces End-stop and Probe line filters to prevent noise on the lines.

Clone Drive (Introduced with V2.51)

The 4th Stepper Driver Socket can be configured to clone any of the other Axes. Configuration is done with the two rows of jumper headers situated under the Nano board.


In the images above the green sections indicates a jumper positions to configure the 4th Stepper Motor Socket.

External Drivers

Below are images of the pins(in red) needed to connect to an external stepper driver for each axis. External Drivers usually run at 3.3-5V logic with the Raspberry Pi CNC board using 5V. (Check the external driver details before connecting.)

Needed pins are as follow:

  • Stepper Pin
  • Direction Pin
  • Enable Pin
  • Ground Pin

Special attention needs to be taken with the Enable pin. Pololu Drivers activate when the enable pin goes low/grounded. If the external drivers you are using needs active high you will not be able to use the enable pin but can instead just connect the external drivers enable pin to 5V to enable it.

Button Controls

The buttons : RESET,ABORT,HOLD,RESUME work with normally open buttons and gets activated when grounded. All buttons are pulled high.

Coolant, Spindle Direction, Spindle Speed

GCode Commands:

  • S0 - S1000 - This command set the spindle speed. (0-1000 with 1000 being 100% speed.)
  • M3 / M4 - Enables the spindle clockwise or anti-clockwise. The Spindle Direction pin is set accordingly(Anti-clockwise turns direction pin high). Sets the Spindle speed pin accordingly.
  • M5 - Disables and pulls spindle pin low.

Examples: M3 S500 -> Enables spindle in clockwise direction at 50% speed.

Keep in mind that the direction pin does not reset when the M5 command is used.

Coolant

GCode Commands:

  • M8 - Enables the coolant and pulls the pin high.
  • M9 - Disables and pulls the pin low.

Probe

...

Software

In order for the GRBL to communicate with the Raspberry Pi, the hardware serial port on the Raspberry Pi needs to be enabled and working. HobbyTronics has a good tutorial on how to set it up and test it. Raspberry Pi Serial Port setup

Firmware (GRBL + Micro-Controller)

GRBL is the magic that does the actual control of the CNC machines.

For more details : GRBL

The Raspberry CNC board comes pre-loaded with GRBL but can be updated as follows : Flashing Grbl to an Arduino



Hardware

Version 2.58

  • Replaced the Arduino Nano with a embedded micro-controller(ATMEGA328 - Arduino UNO compatible)
  • Add reset circuitry to enable programming directly from the Raspberry Pi. ISP pins added and preloaded with the Opti-Boot bootloader. This opens the door for other firmwares like Firmata.
  • Replaced clone jumpers with solder-able jumpers.
  • Later batches might have dip-switches instead of Jumper headers.
  • First Protoneer board to be mode on our Pick and Place machine.

Version 2.51

  • Extra Stepper Drivers Socket that can clone one of the other Axes.
  • End-stop + Probe line noise filters. Allows end stops to work with normal un-shielded cable.
  • Breakout pins allowing external Stepper drivers to be hooked up.

Version 2.11

  • Initial Version
  • 3-Axis (XYZ)
  • End Stop for each Axis (XYZ)
  • Variable Speed Spindle / Laser Intensity control (PWM Spindle pin and Direction pin)
  • Coolant control pin. (Extra output pin)