diff --git a/CMakeLists.txt b/CMakeLists.txt index ade78e0..066f4d7 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -6,4 +6,4 @@ cmake_minimum_required(VERSION 3.5) #set(EXTRA_COMPONENT_DIRS ../esp-idf-lib/components) include($ENV{IDF_PATH}/tools/cmake/project.cmake) -project(cable-length-cutting) +project(cable-length-cutter) diff --git a/README.md b/README.md index 4a565fa..afd43d2 100644 --- a/README.md +++ b/README.md @@ -1,18 +1,92 @@ -# Hardware -## connection plan -See [connection-plan.pdf](connection-plan.pdf) +# Overview +Firmware and documentation of a custom built machine that winds and cuts cable to certain lengths. +Extensive details about this project can be found on the website: [pfusch.zone/cable-length-cutter](https://pfusch.zone/cable-length-cutter) + + + +Photo of the built machine + +## Current Features +- Measure length using rotary encoder +- Wind to set length while start-button is pressed +- Automatic wire cutter +- Control interface: + - 2x 7-Segment display showing lengths and notifications + - Buzzer for acoustic notifications + - 4 Buttons and Potentiometer for setting the target length + - Reset and Cut Button +- Stepper motor controlling a linear axis guiding the cable while winding +- Store last axis position at shutdown + + +# Usage + + + +# Electrical Details +For detailed documentation of all electrical aspects, see [connection-plan.pdf](connection-plan.pdf). + + +# Printed Parts +All designed and 3D-printed parts can be found in the [cad/](cad/) folder. These parts were designed using FreeCAD. # Components -## rotary encoder LPD3806-600BM-G5-24C - - Pulses: 600 p/r (Single-phase 600 pulses /R,Two phase 4 frequency doubling to 2400 pulses) - - Power source: DC5-24V - - Shaft: 6*13mm/0.23*0.51" - - Size: 38*35.5mm/1.49*1.39" - - Output :AB 2phase output rectangular orthogonal pulse circuit, the output for the NPN open collector output type - - Maximum mechanical speed: 5000 R / min - - Response frequency: 0-20KHz - - Cable length: 1.5 meter - - size: http://domoticx.com/wp-content/uploads/2020/05/LPD3806-afmetingen.jpg - - Wires: Green = A phase, white = B phase, red = Vcc power +, black = V0 +### Custom pcb with ESP-32 microcontroller +See [connection-plan.pdf](connection-plan.pdf) +### Rotary encoder LPD3806-600BM-G5-24C +``` +- Pulses: 600 p/r (Single-phase 600 pulses /R,Two phase 4 frequency doubling to 2400 pulses) +- Power source: DC5-24V +- Shaft: 6*13mm/0.23*0.51" +- Size: 38*35.5mm/1.49*1.39" +- Output :AB 2phase output rectangular orthogonal pulse circuit, the output for the NPN open collector output type +- Maximum mechanical speed: 5000 R / min +- Response frequency: 0-20KHz +- Cable length: 1.5 meter +- size: http://domoticx.com/wp-content/uploads/2020/05/LPD3806-afmetingen.jpg +- Wires: Green = A phase, white = B phase, red = Vcc power +, black = V0 +``` +### Variable Frequency Drive T13-400W-12-H +See [docs/vfd/](docs/vfd/) + +### Stepper-driver TB6600 +See [docs/stepper-driver_TB6600-Manual.pdf](docs/stepper-driver_TB6600-Manual.pdf) + +### Linear Axis with Nema-12 28HB40 Stepper +See [connection-plan.pdf](connection-plan.pdf) + + + + +# Installation +For this project **ESP-IDF v4.4.4** is required (with other versions it might not compile) +```bash +#download esp-idf +yay -S esp-idf #alternatively clone the esp-idf repository from github +#run installation script in installed folder +/opt/esp-idf/install.sh +``` + +# Build +### Set up environment +```bash +source /opt/esp-idf/export.sh +``` +(run once per terminal) + +### Compile +```bash +cd board_single +idf.py build +``` + +# Flash +- connect FTDI programmer to board (VCC to VCC; TX to RX; RX to TX) +- press REST and BOOT button +- release RESET button (keep pressing boot) +- run flash command: +```bash +idf.py flash +``` \ No newline at end of file diff --git a/function-diagram.drawio b/function-diagram.drawio index 2612b8a..3b41108 100644 --- a/function-diagram.drawio +++ b/function-diagram.drawio @@ -1,6 +1,6 @@ - + - + @@ -13,7 +13,7 @@ - + @@ -25,7 +25,7 @@ - + @@ -205,7 +205,7 @@ - + @@ -230,11 +230,11 @@ - - + + - - + + @@ -348,13 +348,13 @@ - + - + - - + + @@ -362,24 +362,6 @@ - - - - - - - - - - - - - - - - - - @@ -417,15 +399,15 @@ - + - - + + - + @@ -501,8 +483,8 @@ - - + + @@ -516,14 +498,8 @@ - - - - - - - - + + @@ -534,14 +510,62 @@ - + - - + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -787,9 +811,10 @@ - + + @@ -801,7 +826,7 @@ - + diff --git a/function-diagram.drawio.pdf b/function-diagram.drawio.pdf index 99a8825..b2df6aa 100644 Binary files a/function-diagram.drawio.pdf and b/function-diagram.drawio.pdf differ diff --git a/img/cable-length-cutter.jpg b/img/cable-length-cutter.jpg new file mode 100644 index 0000000..022c9fa Binary files /dev/null and b/img/cable-length-cutter.jpg differ diff --git a/img/panel-layout.svg b/img/panel-layout.svg new file mode 100644 index 0000000..d75bb4b --- /dev/null +++ b/img/panel-layout.svg @@ -0,0 +1,3 @@ + + +Control panel layout FreeCAD SVG Export Drawing page: Page exported from FreeCAD document: box_v1_0 7 Segmen Display: show CURRENT length7 Segmen Display: show TARGET lengthRESETCUTAUTOCUT5m10m20mSELSETLEDMotor activePotentiometer: select custom target length 0 - 50 mwhile SET-Button is pressedSET-Button:apply selected length (Poti)Toggle switchAUTO:enable automatic cut after target reachedledCUT-Button:Trigger one cutRESET-Button:reset current length to 0,move guide to start position3x PRESET-Button:set predefined target lengthLED on if automatic cut enabled \ No newline at end of file