From ee55d4483f6256e052800886fc71eae26b08666a Mon Sep 17 00:00:00 2001 From: jonny Date: Fri, 31 Jan 2025 10:19:46 +0100 Subject: [PATCH] Update Readme: Add RPI + Python usage instructions --- README.md | 199 ++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 154 insertions(+), 45 deletions(-) diff --git a/README.md b/README.md index 24031fc..38f229e 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# Raspberry Pi Extension board +# Raspberry Pi Extension Board A custom PLC-like system based on the Raspberry Pi. With a custom interface board, a Raspberry Pi is extended with protected I/O, bus systems, analog inputs, and Relay or PWM outputs. All components, including a display, are housed in a custom-designed enclosure. @@ -9,7 +9,7 @@ The project is intended for versatile use in prototyping and project development --- -### Photo of all hardware components +## Photo of All Hardware Components

All Components (Disassembled)

@@ -21,7 +21,7 @@ The project is intended for versatile use in prototyping and project development # Repository Content - **KiCad Projects**: 3 KiCad projects with schematics and PCB layouts for the custom PCBs created. - **Housing**: Custom enclosure design for PCBs and Raspberry Pi created in FreeCAD. -- **Software/Firmware**: Python scripts for operating and testing the PCB features (WIP). +- **Software/Firmware**: Python scripts run on the Raspberry Pi for operating and testing the PCB features and providing examples as base for future projects. --- @@ -42,7 +42,7 @@ Detailed features of each PCB are described in the respective sections below. # Designed PCBs -## 1. **Raspberry Pi Interface Board** +## 1. Raspberry Pi Interface Board This board connects to the Raspberry Pi via a 40-pin ribbon cable and provides protected GPIO extensions and versatile input/output features. ### Photo @@ -51,7 +51,7 @@ This board connects to the Raspberry Pi via a 40-pin ribbon cable and provides p ### Features **Inputs**: - **8x Digital Inputs**: - - Wide continuous voltage range (-1.7 V to 120 V), idea: compatible with 3 V and 24 V devices. + - Wide voltage range (-1.7 V to 120 V) → compatible with 3 V and 24 V devices. - TVS diodes for ESD and spike protection. - Reverse polarity protection. - Isolated with optocouplers. @@ -74,7 +74,7 @@ This board connects to the Raspberry Pi via a 40-pin ribbon cable and provides p - 8x digital outputs (via shift register): - Low-power (30 mA push-pull) and high-power (500 mA open-drain) outputs. - Buzzer and relays connected to channels 6-8, with enable/disable switches. - - Note: Outputs are **not short-circuit proof**. + - **Note**: Outputs are **not short-circuit proof**. **General**: - WAGO spring-loaded terminals for easy wiring. @@ -85,7 +85,7 @@ This board connects to the Raspberry Pi via a 40-pin ribbon cable and provides p - UART (unprotected). - I2C (TVS diodes, 2.2 kΩ pull-ups). - SPI (unprotected). -Note: Either RS485 or UART can be used at the same time (select with jumpers). + - **Note**: RS485 and UART cannot be used simultaneously (select via jumpers). ### Schematic and Layout

@@ -160,70 +160,179 @@ Small PCBs with LEDs, resistors, and mounting holes for housing indicators.

+
+ --- +
-# Software/Firmware -Python code for operating the extension PCBs (e.g., GPIO pins, shift registers, ADC, and bus communication). This section is a work in progress (WIP), and example scripts will be added as development continues. +# Raspberry Pi Usage -# ======== WIP ======== -# Python scripting - -The pin assignment to the actual terminals are defined / mapped in -`rpi-scripts\interface_board_pins.py` so it should be included in any custom script created to easily reference the terminal numbers printed onto the project housing in the code. See examples in `rpi-scripts\examples` -TODO: make those files link to file but with text still the file path - -# Usage Raspberry-PI ## Connectivity +The Raspberry Pi can operate **standalone** with a connected keyboard, mouse, and HDMI monitor, or by using the integrated display in the housing. -### Establish LAN Connection (ethernet) -configure in command.txt in boot partition? -### Establish WIFI Connection +However, for **development**, it is recommended to connect it to a network via **WiFi or LAN**, allowing easy remote access from a laptop. A direct **Ethernet connection** between the Raspberry Pi and a laptop is often the simplest method. + +### LAN Connection (Ethernet) +- **Connection**: Connect cable directly between raspberry and PC +- **Configure the PC interface**: Set a static ip address e.g. `192.168.1.1/24` + Note: Optionally also enable network sharing to enable the RPI to use the internet connection the PC currently has. +- **Configure the Raspberry Interface**: Set a static ip address e.g. `192.168.1.100/24` + The Raspberry Pi can be configured for **Ethernet access** using different methods: + - **Boot Partition Configuration:** Modify `cmdline.txt` on the SD card. + - **GUI Setup:** Use the built-in network manager if a monitor is connected. + - **Command Line (`nmcli`)**: Configure networking via the terminal. + +To check the assigned IP run: ```bash -s nmcli device wifi connect password -# replace and with actual wifi +ip a ``` -### Connect via ssh -```powershell +### WiFi Connection +Probably the **fastest and easiest** way to set up communication between the Raspberry Pi and a PC - while even maintaining internet access - is to **use a mobile phone as a WiFi hotspot**. +Simply **connect both the Raspberry Pi and the laptop** to the same hotspot. + +To connect to a WiFi network, use: +```bash +nmcli device wifi connect password +``` +Replace `` and `` with the actual credentials. +The Raspberry Pi will **automatically reconnect** after a reboot. + +Once connected, you can check the assigned IP on the Raspberry Pi using: + ``` + ip a + ``` + +### SSH Access +For remote terminal access, connect via SSH from a laptop: +```bash ssh pi@192.168.1.100 ``` +Replace the IP with the actual address of the Raspberry Pi. -### Connect via rdp -Open mstsc from windows start menu, and enter ip, user root and password. -Or use powershell: +### Remote Desktop (RDP) +To control the Raspberry Pi’s **GUI remotely**, RDP is pre-configured. + +#### Connect via Windows Remote Desktop: +- Open **Remote Desktop Connection (mstsc)**. +- Enter the Raspberry Pi’s IP address. +- **Login:** + - **User:** `root` + - **Password:** (configured during setup) + - **Note:** Logging in as `pi` may result in a black screen. + +#### Alternatively, use PowerShell: ```powershell mstsc /v:192.168.1.100:3389 ``` -Note: currently only user `root` works (using user pi results in blackscreen) -### Mount filesystem in windows -You can mount /home/pi folder in windows natively using samba -Run in powershell to mount it as network device X (replace ip with the current ip of rpi) -Find out ip with running `ip a` on the raspberry -```powershell -net use X: \\192.168.1.100\pi /user:pi -``` +### Mount Raspberry Pi Filesystem in Windows (SAMBA) +For convenient file access and editing (e.g., with **VS Code**), the Raspberry Pi’s `/home/pi` directory can be **mounted as a network drive** using Samba. -## Scripts +#### Steps: +1. Determine the Raspberry Pi’s IP address: + ```bash + ip a + ``` +2. Mount the `/home/pi` directory in Windows: + ```powershell + net use X: \\192.168.1.100\pi /user:pi + ``` + Replace `192.168.1.100` with the actual IP address. -### Autostart GUI +**Note:** +Currently, only `/home/pi` is available for mounting. To share additional directories, edit the Samba configuration file: ```bash -git/rpi-interface-board/rpi-scripts/gui% s cp gui-start.service /etc/systemd/system/ +# add a new `[share]` section with the desired folder path and permissions. +sudo nano /etc/samba/smb.conf +# then restart samba +sudo systemctl restart smbd ``` -# ======== END WIP ======== + + +
--- +
+ + +# Python Scripting +All **terminal-to-pin assignments** are mapped in [`interface_board_pins.py`](rpi-scripts/interface_board_pins.py), allowing easy reference to terminal numbers labeled on the housing. + +Example scripts demonstrating I/O control can be found in [`rpi-scripts/examples`](rpi-scripts/examples). + +--- + +## Scripts & Development + +### Running Python Examples +Pre-written **Python scripts** to control I/O terminals are located in: +``` +rpi-scripts/examples +``` +To run an example, execute: +```bash +cd /home/pi/git/rpi-interface-board/rpi-scripts/examples/ +python read_digital_inputs.py +``` + +### Starting a New Python Project with I/O Access +To create a custom Python project using the **interface board**, follow these steps: + +1. **Copy the entire `rpi-scripts/` folder** to your new project directory. +2. **Remove unnecessary files**, keeping at least: + - `rpi-scripts/interface_board_libs/` → contains custom drivers. + - `rpi-scripts/interface_board_pins.py` → maps terminal numbers to GPIO/ADC channels. +3. **Start coding** by modifying an existing example in `examples/`. + +--- + +## GUI Interface +A **Python GUI** is available for **real-time monitoring** and **control** of all I/O terminals for quick testing. + +### Run the GUI +```bash +cd rpi-scripts/gui +python main.py +``` + +### Enable GUI Autostart on Boot +The GUI is configured to start automatically on boot in **fullscreen mode**. To modify this behavior: + +#### Enable autostart: +```bash +sudo cp rpi-scripts/gui/gui-start.service /etc/systemd/system/ +sudo systemctl enable gui-start.service +``` + +#### Disable autostart: +```bash +sudo systemctl disable gui-start.service +``` + +### GUI Screenshots +

+ + +

+ + +
+ +--- + +
+ # Housing Custom-designed enclosure includes: -- Ports for Raspberry Pi. -- Banana sockets for power outputs. -- Exposed screw terminals. -- Openings for buttons and LEDs. -- Mounts for all PCBs and wiring. - +- Cutouts for all Ports for Raspberry Pi. +- Mounting screws for all pcbs and Raspberry +- Fan mount + venting slots +- Cutouts for all external pcb terminals +- Cutout + mounting arms (M2.5) for Display 3D Model