planktoscope/README.md

220 lines
5.7 KiB
Markdown
Raw Normal View History

# PlanktonScope Installation
2019-12-17 04:08:11 +01:00
## Install and setup Raspbian on your Raspberry Pi
2020-04-15 22:17:18 +02:00
### Download the image
2020-04-15 22:17:18 +02:00
Download the .zip file of Raspbian Buster with desktop from the Raspberry Pi website Downloads page.
Writing an image to the SD card
Download the latest version of balenaEtcher and install it.
Connect an SD card reader with the micro SD card inside.
Open balenaEtcher and select from your hard drive the Raspberry Pi .zip file you wish to write to the SD card.
Select the SD card you wish to write your image to.
Review your selections and click 'Flash!' to begin writing data to the SD card.
### Prepare your Raspberry Pi
[Getting Started with your Raspberry Pi](https://projects.raspberrypi.org/en/projects/raspberry-pi-getting-started/)
2020-04-15 22:17:18 +02:00
Plug the SD Card in your Raspberry Pi
Connect your Pi to a screen, mouse, keyboard and power
2020-04-15 22:17:18 +02:00
Finish the setup
Make sure you have access to internet and update/upgrade your fresh raspbian
Update your Pi first
```
sudo apt-get update -y
sudo apt-get upgrade -y
```
2020-04-15 22:17:18 +02:00
Reboot your Pi safely
```
sudo reboot now
```
2020-04-15 22:17:18 +02:00
### Raspberry Pi configurations
2020-04-15 22:17:18 +02:00
Enable Camera/SSH/I2C in raspi-config
Open up the configuration page and select Interfacing Options by typing this command:
```
sudo raspi-config
```
2020-04-15 22:17:18 +02:00
Select `Serial`
2020-04-15 22:17:18 +02:00
Select `NO`
2020-04-15 22:17:18 +02:00
Keep the `Serial Port Hardware enabled`
2020-04-15 22:17:18 +02:00
Reboot your Pi safely
```
sudo reboot now
```
2020-04-15 22:17:18 +02:00
## Install the needed libraries for the PlanktonScope
2020-04-15 22:17:18 +02:00
### Install CircuitPython
[Installing CircuitPython on Raspberry Pi](https://learn.adafruit.com/circuitpython-on-raspberrypi-linux/installing-circuitpython-on-raspberry-pi)
2020-04-15 22:17:18 +02:00
Run the following command to install adafruit_blinka
```
pip3 install adafruit-blinka
sudo pip3 install adafruit-circuitpython-motorkit
```
2020-04-15 22:17:18 +02:00
### Install RPi Cam Web Interface
2020-04-15 22:17:18 +02:00
[RPi Cam Web Interface](https://elinux.org/RPi-Cam-Web-Interface)
2020-04-15 22:17:18 +02:00
Clone the code from github and enable and run the install script with the following commands
```
git clone https://github.com/silvanmelchior/RPi_Cam_Web_Interface.git
cd RPi_Cam_Web_Interface
./install.sh
```
2020-04-15 22:17:18 +02:00
Press Enter to allow default setting of the installation
Press Enter to start RPi Cam Web Interface now
Found what is the IP of your Raspberry Pi
```
sudo ip addr show | grep 'inet 1'
```
2020-04-15 22:17:18 +02:00
Reach the url on a local browser : http://127.0.0.1/html/
### Install Ultimate GPS HAT
[Installing Adafruit GPS HAT](https://learn.adafruit.com/adafruit-ultimate-gps-hat-for-raspberry-pi/pi-setup)
[Use Python Thread with GPS HAT](http://www.danmandle.com/blog/getting-gpsd-to-work-with-python/)
2020-04-15 22:17:18 +02:00
```
sudo apt-get install python gpsd gpsd-clients
```
### Install RGB Cooling HAT
[Installing RGB Cooling HAT](https://www.yahboom.net/study/RGB_Cooling_HAT)
2020-04-15 22:17:18 +02:00
Type these command to install:
```
git clone https://github.com/WiringPi/WiringPi.git
cd WiringPi
sudo ./build
sudo apt-get install gcc
```
### Install Node-RED
[Installing Node-RED on Raspberry Pi](https://nodered.org/docs/getting-started/raspberrypi)
#### Prerequisites
Ensure npm is able to build any binary modules it needs to install.
```
sudo apt-get install build-essential
```
#### Download and installation
To install Node.js, npm and Node-RED onto a Raspberry Pi, run the following command will that download and install them:
```
bash <(curl -sL https://raw.githubusercontent.com/node-red/linux-installers/master/deb/update-nodejs-and-nodered)
```
2020-04-15 22:17:18 +02:00
Due to the limited memory of the Raspberry Pi, you will need to start Node-RED with an additional argument to tell the underlying Node.js process to free up unused memory sooner than it would otherwise.
```
node-red-pi --max-old-space-size=256
```
2020-04-15 22:17:18 +02:00
#### Autostart on boot
2020-04-15 22:17:18 +02:00
Run Node-RED when the Pi is turned on, or re-booted, enable the service to autostart by running the command:
```
sudo systemctl enable nodered.service
```
2020-04-15 22:17:18 +02:00
#### Check the installation
Make sure NodeRed is correctly installed by reaching the following page from the broswer of your pi : http://localhost:1880.
2020-04-15 22:17:18 +02:00
#### Install few nodes
2020-04-15 22:17:18 +02:00
These nodes will be used in Node-RED:
```
cd .node-red/
npm install node-red-dashboard
npm install node-red-contrib-python3-function
npm install node-red-contrib-camerapi
npm install node-red-contrib-gpsd
npm install node-red-contrib-web-worldmap
```
2020-04-15 22:17:18 +02:00
#### Import the last GUI
2020-04-15 22:17:18 +02:00
Import the lastest version of the GUI from https://raw.githubusercontent.com/tpollina/PlanktonScope/master/scripts/flows_planktonscope.json>
2020-04-15 22:17:18 +02:00
### Install Mosquitto MQTT
2020-04-15 22:17:18 +02:00
In order to send and receive from Node-RED:
```
sudo apt-get install mosquitto mosquitto-clients
```
2020-04-15 22:17:18 +02:00
### Install mqtt-paho
2020-04-15 22:17:18 +02:00
In order to send and receive from python:
```
pip3 install paho-mqtt
```
### Install OpenCV
2020-04-15 22:17:18 +02:00
Use the quick version without virtual env
https://www.pyimagesearch.com/2019/09/16/install-opencv-4-on-raspberry-pi-4-and-raspbian-buster/
### Install MorphoCut
2020-04-15 22:17:18 +02:00
_Installing MorphoCut <https://morphocut.readthedocs.io/en/stable/installation.html>`_
2020-04-15 22:17:18 +02:00
MorphoCut is packaged on PyPI and can be installed with pip:
```
sudo apt-get install python3-scipy
pip3 install -U git+https://github.com/morphocut/morphocut.git@pyrocystis
```
2020-04-15 22:17:18 +02:00
## Finishing the install
2020-04-15 22:17:18 +02:00
Make sure to update your Pi
```
sudo apt-get update -y
sudo apt-get full-upgrade -y
```
2020-04-15 22:17:18 +02:00
Reboot your Pi safely
```
sudo reboot now
2020-04-15 22:17:18 +02:00
```
2020-04-15 22:17:18 +02:00
## Useful later maybe
2020-04-15 22:17:18 +02:00
### Download the GitHub repo
2020-04-15 22:17:18 +02:00
At this link : https://github.com/tpollina/PlanktonScope/archive/master.zip
Unzip to a specific location:
```
unzip /home/pi/Downloads/PlanktonScope-master.zip -d /home/pi/
mv /home/pi/PlanktonScope-master /home/pi/PlanktonScope
```
2020-04-15 22:17:18 +02:00
### Update node-RED interface
2020-04-15 22:17:18 +02:00
To update the interface, you can just download the lastest .json file:
```
wget -P $HOME/.node-red https://raw.githubusercontent.com/tpollina/PlanktonScope/master/scripts/flows_planktonscope.json
```
2020-04-15 22:17:18 +02:00
### Share WiFi via Ethernet
2020-04-15 22:17:18 +02:00
At this link : https://www.instructables.com/id/Share-WiFi-With-Ethernet-Port-on-a-Raspberry-Pi/