mirror of
https://github.com/sinseman44/PyCNC.git
synced 2026-04-20 18:48:11 +00:00
better documentation
This commit is contained in:
58
README.md
58
README.md
@@ -1,4 +1,4 @@
|
||||
This project bring CNC control for ARM based Linux boards like Raspberry Pi.
|
||||
This project bring CNC control for Raspberry Pi or any ARM based Linux boards.
|
||||
Typically there is no way to control stepper motors from Linux runtime
|
||||
environment due to the lack of real time GPIO control. Even kernel based
|
||||
modules can not guarantee precise control of pulses for steppers. There is
|
||||
@@ -17,25 +17,47 @@ Video demo - [YouTube video](https://youtu.be/vcedo59raS4)
|
||||
|
||||
# Current command support
|
||||
G0, G1, G4, G20, G21, G28, G90, G91, G92, M2, M3, M5, M30
|
||||
Commands can be easily added, see [gmachine.py](./gmachine.py) file.
|
||||
Commands can be easily added, see [gmachine.py](./cnc/gmachine.py) file.
|
||||
|
||||
# Config
|
||||
All config is stored in [config.py](./config.py) and contains hardware properties, limitations
|
||||
and pin names for hardware control.
|
||||
All config is stored in [config.py](./cnc/config.py) and contains hardware
|
||||
properties, limitations and pin names for hardware control.
|
||||
Raspberry Pi implementation should be connected to A4988, DRV8825 or any other
|
||||
stepper motor controllers with DIR and STEP pin inputs.
|
||||
Default config is created for Raspberry Pi 2-3 and this wiring diagram:
|
||||

|
||||
So having Raspberry Pi connected this was, there is no need to configure
|
||||
pin map for project.
|
||||
_Note: spindle control is not implemented yet_
|
||||
|
||||
# Hardware
|
||||
Currently, this project supports Raspberry Pi 1-3. But there is a way to add new boards.
|
||||
See [hal.py](./hal.py) file.
|
||||
Currently, this project supports Raspberry Pi 1-3. Tested with RPI2. But there
|
||||
is a way to add new boards. See [hal.py](./cnc/hal.py) file.
|
||||
|
||||
# Usage
|
||||
Just clone this repo and run `./pycnc` from repo root. It will start in
|
||||
interactive terminal mode where gcode commands can be entered manually.
|
||||
To run file with gcode commands, just run `./pycnc filename`.
|
||||
Optionally, `pycnc` can be installed. Run
|
||||
```bash
|
||||
sudo pip install .
|
||||
```
|
||||
in repo root directory to install it. After than, `pycnc` command will be added
|
||||
to system path. To remove installation, just run:
|
||||
```bash
|
||||
sudo pip remove pycnc
|
||||
```
|
||||
|
||||
# Performance notice
|
||||
Pure Python interpreter wouldn't provide great performance for high speed machines.
|
||||
Overspeeding setting causes motors mispulses and probably lose of trajectory. According
|
||||
to my tests, Raspberry Pi 2 can handle axises with 400 pulses on mm with top velocity ~800 mm
|
||||
per min. There is always way out! :) Use JIT Python implementation like PyPy. RPi2 can handle
|
||||
up to 18000 mm per minute on the machine with 80 steps per millimeter motors with PyPy.
|
||||
_Note: Raspbian has outdated PyPy version in repositories(v4.0). Moreover v4.0 has issue with
|
||||
`mmap` module implementation. Use PyPy v5.0+, download it for your OS from
|
||||
[here](https://pypy.org/download.html)._
|
||||
Pure Python interpreter wouldn't provide great performance for high speed
|
||||
machines. Overspeeding setting causes motors mispulses and probably lose of
|
||||
trajectory. According to my tests, Raspberry Pi 2 can handle axises with 400
|
||||
pulses on mm with top velocity ~800 mm per min. There is always way out! :)
|
||||
Use JIT Python implementation like PyPy. RPi2 can handle up to 18000 mm per
|
||||
minute on the machine with 80 steps per millimeter motors with PyPy.
|
||||
_Note: Raspbian has outdated PyPy version in repositories(v4.0). Moreover v4.0
|
||||
has issue with `mmap` module implementation. Use PyPy v5.0+, download it for
|
||||
your OS from [here](https://pypy.org/download.html)._
|
||||
PyPy installation:
|
||||
```bash
|
||||
wget wget https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.7.1-linux-armhf-raspbian.tar.bz2
|
||||
@@ -44,12 +66,16 @@ sudo tar xvf pypy2-v5.7.1-linux-armhf-raspbian.tar.bz2 --directory /opt/pypy/ --
|
||||
sudo ln -s /opt/pypy/bin/pypy /usr/local/bin/pypy
|
||||
```
|
||||
|
||||
# Project architecture
|
||||

|
||||
|
||||
# Dependencies
|
||||
Nothing. Just pure Python code.
|
||||
|
||||
# GCode simulation
|
||||
Just a link to a nice web software for gcode files emulation (very helpful for manual creating of
|
||||
gcode files): [https://nraynaud.github.io/webgcode/](https://nraynaud.github.io/webgcode/)
|
||||
Just a link, mostly for myself :), to a nice web software for gcode files
|
||||
emulation (very helpful for manual creating of gcode files):
|
||||
[https://nraynaud.github.io/webgcode/](https://nraynaud.github.io/webgcode/)
|
||||
|
||||
# License
|
||||
see [LICENSE](./LICENSE) file.
|
||||
|
||||
Reference in New Issue
Block a user