Skip to main content

this is a Python libary to drive a stepper motor with a Trinamic TMC2209 stepper driver and a Raspberry Pi

Project description

TMC_2209_Raspberry_Pi

PyPI python version TMC-2209-Raspberry-Pi PyPI version TMC-2209-Raspberry-Pi PyPI downloads TMC-2209-Raspberry-Pi



This is a library to drive a stepper motor with a TMC2209 stepper driver and a Raspberry Pi.

This code is still experimental, so use it on your own risk.

This library is programmed in pure Python. The performance of Python is not good enough to drive the motor with high speed. So if you move the motor with high speed and this library the motor will lose steps.

My TMC2209 is a Bigtreetech TMC 2209 V1.2

It has a rSense of 110 mOhm and it uses one Pin (PDN_UART) for UART RX and TX. So the PD_UART-Pin needs to be connected to the Raspberrry Pis RX-Pin directly and to the TX-Pin with an 1kOhm resistor. You can read more about this in the datasheet from Trinamic.

Because the TMC2209 uses one shared pin for transmit and receive in the UART communication line, the Raspberry Pi also receives what it sends. Well, the Pi receives 4 bytes from itself and 8 bytes from the driver. So the Pi receives a total of 12 bytes and only the last 8 are the reply, of which only 4 are data bytes.

the Documentation of the TMC2209 can be found here:
TMC2209 - Datsheet

The code is also available on PyPI.

Installation

Installation with PIP

pip3 install TMC-2209-Raspberry-Pi

Installation with GIT

  • clone this repo to your Raspberry Pi using
git clone https://github.com/Chr157i4n/TMC2209_Raspberry_Pi
  • install the python module bitstring with
pip3 install bitstring
  • enable the serial port in
sudo raspi-config

Wiring

Pin TMC2209 connect to Function
TX or PDN_UART with 1kOhm TX of Raspberry Pi send data to TMC via UART
RX or PDN_UART directly RX of Raspberry Pi receive data from TMC via UART
VM 12V or 24V of power supply power for the motor
GND GND of power supply power for the motor
VDD 3,3V of Raspberry Pi optional, for more stable logic voltage
GND2 GND of Raspberry Pi GND for VDD and Signals
EN GPIO21 of Raspberry Pi enable the motor output
STEP GPIO16 of Raspberry Pi moves the motor one step per pulse
DIR GPIO20 of Raspberry Pi set the direction of the motor
DIAG GPIO26 of Raspberry Pi optional, for StallGuard

wiring diagram

The GPIO pins can be specific when initiating the class. If you test this on a breadboard, make sure to cut off the bottomside of the pins (Vref and DIAG) next to the EN pin, so that they are not shorted trough the breadboard.

Tests

You can run the test files from the main directory with

python3 -m tests.test_script_01_uart_connection

test_script_01_uart_connection.py

This only communicates with the TMC driver over UART. It should set some settings in the driver and then outputs the settings. When it outputs TMC2209: UART Communication Error, you need to check the UART-connection.

test_script_02_pin_connection.py

This script enables the raspberry GPIO output for the dir, en and step pin and then checks the TMC driver register, whether the driver sees them as HIGH or LOW. Because the enabled pin is activated for a short time, the motor current ouput will be also activated in this script for a short time. This script should output: Pin DIR: OK Pin STEP: OK Pin EN: OK if not, check the connection of the pin.

test_script_03_basic_movement.py

This script should move the motor 6 times, one revolution back and forth.

test_script_04_stallguard.py

In this script the stallguard feature of the TMC2209 is beeing setup. A funtion will be called, if the driver detects a stall. The function stops the current movement. The motor will be moved 10 revolutions. If the movement is finished unhindered, the script outputs Movement finished successfully. If you block the motor with pliers or something similar, the the motor will stop and the script outputs StallGuard! and Movement was not completed

test_script_05_vactual.py

VACTUAL allows moving the motor by UART control. It gives the motor velocity in +-(2^23)-1 [μsteps / t]

test_script_06_multiple_drivers.py

Multiple drivers can be addressed via UART by setting different addresses with the MS1 and MS2 pins. Simultaneous movement of multiple motors can be done with threaded movement.

test_script_07_threads.py

In this script, the movement of a stepper with threads is shown. This can be used to do other task while moving a motor, or to move several motors simultaneous.



For me these baudrates worked fine: 19200, 38400, 57600, 115200, 230400, 460800, 576000.

If the TMC2209 driver is connected to the Vmotor, the internal voltage regulator will create the Vio for the chip. So you don't need to connect anything to the Vio pin of the driver.

Usage

from TMC_2209.TMC_2209_StepperDriver import *
tmc = TMC_2209(21, 16, 20)

tmc.set_direction_reg(False)
tmc.set_current(300)
tmc.set_interpolation(True)
tmc.set_spreadcycle(False)
tmc.set_microstepping_resolution(2)
tmc.set_internal_rsense(False)

tmc.set_acceleration(2000)
tmc.set_max_speed(500)

tmc.set_motor_enabled(True)

tmc.run_to_position_steps(400)
tmc.run_to_position_steps(0)

tmc.set_motor_enabled(False)

Troubleshoot

If you have questions please check out the Wiki and the other issues.

If you encounter any problems, feel free to open an issue (ENG/GER). Please don't send any E-Mails to me. Pls use Github, so that i don't need to answer the same question multiple times. I reserve the right not to answer E-Mails.

Problem Solution
FileNotFoundError: [Errno 2]
No such file or directory: '/dev/serial0'
depending on your Raspberry Pi version, you need to enable the Serial Port
run sudo raspi-config in your terminal.
there go to '3 Interface Options' -> 'P3 Serial Port'
Would you like a login shell to be accessible over serial? No
Would you like the serial port hardware to be enabled? Yes
Finish and then reboot
PermissionError: [Errno 13]
Permission denied: '/dev/serial0'
you need to give the permission to acces the Serial Port to your current user
You may need to add your user (pi) to the dialout group with sudo usermod -a -G dialout pi
"TMC2209: UART Communication Error" You can use the 'debug_script_01_uart_connection' script to get a better reading on the received bytes and troubleshoot your problem
"TMC2209: UART Communication Error: 0 data bytes | 4 total bytes" only 4 total bytes received indicates, that the Raspberry Pi receives its own data, but nothing from the TMC driver. This happens if RX and TX are connected properly, but the TMC driver has no power
"TMC2209: UART Communication Error: 0 data bytes | 0 total bytes" 0 total bytes received indicates, a problem with your wiring or your Raspberry Pi. This happens if TX is not connected
"TMC2209: UART Communication Error: 4 data bytes | 12 total bytes" this indicates, the Raspberry Pi received only zeroes. This happens if only RX is connected and TX not
"the Raspberry Pi received only the sended bits" or
inconsistent received bits
Make sure the UART ist properly connected to the TMC driver and the driver is powered and working.
Make sure login shell (console) over serial is disabled.

wiring photo

Acknowledgements

The code to run the stepper motor is based on the code of the AccelStepper Library from Mike McCauley.

The code for the UART communication is based on this code from troxel.

My goal is to make a library, that can run a stepper motor with a TMC2209 stepper driver and can write the setting in the register of the TMC2209, entirely in Python. The main focus for this are Test setups, as Python is not fast enough for high motor speeds.

Feedback/Contributing

If you encounter any problem, feel free to open an issue on the Github issue page. Feedback will keep this project growing and I encourage all suggestions. Feel free to submit a pull request on the dev branch.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

TMC_2209_Raspberry_Pi-0.3.3.tar.gz (36.5 kB view details)

Uploaded Source

Built Distribution

TMC_2209_Raspberry_Pi-0.3.3-py3-none-any.whl (31.6 kB view details)

Uploaded Python 3

File details

Details for the file TMC_2209_Raspberry_Pi-0.3.3.tar.gz.

File metadata

  • Download URL: TMC_2209_Raspberry_Pi-0.3.3.tar.gz
  • Upload date:
  • Size: 36.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for TMC_2209_Raspberry_Pi-0.3.3.tar.gz
Algorithm Hash digest
SHA256 47411b369c9b0ed663846364464684411502194d1bcdf20f5d240c7a03b3bab7
MD5 81facef3dbeb7e5314bbb18297ff4362
BLAKE2b-256 013224df881929eb563e78c173c87fd0f4988cd6c51fb11faf6fb5057301882a

See more details on using hashes here.

Provenance

File details

Details for the file TMC_2209_Raspberry_Pi-0.3.3-py3-none-any.whl.

File metadata

File hashes

Hashes for TMC_2209_Raspberry_Pi-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5a01df99c03835df9232b45a0da19d794279ac02acfce4fb8c13f6b3da96606b
MD5 0ea1910a2cc8d5507a02f83b97d4ff35
BLAKE2b-256 f03451c63b95e41e2b171a1e9a28a7f3bf21f944a5d3b3d26c727116da80601f

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page