Start Guide
Windows
- Install WSL2 before proceeding. Install the default Ubuntu distribution to avoid compatibility issues.
- Access the WSL terminal by searching for and opening the Ubuntu application in the Windows start menu. Open a VSCode window from WSL by entering
code .
in the terminal. - Follow the general installation and setup instructions.
- Install Docker Desktop.
- Follow the instructions for Configuring WSL2 with Docker Desktop. In the VSCode terminal, add your user to the docker group by entering
sudo usermod -aG docker $USER
. Usenewgrp docker
to force the change to take effect. Ensure the correct docker context is in use withdocker context use default
. - In the VSCode terminal, enter
sudo apt-get update && sudo apt-get install libgl1
to resolve dependency issues with the libgl1 library on WSL2.
MacOS
- Follow the general installation and setup instructions.
- Install Docker Desktop.
- Note: The GEMINI App attempts to find an NVIDIA GPU to use with OpenDroneMap for orthomosaic generation. Due to the lack of a compatibile GPU on MacOS systems, the following error is expected:
docker: Error response from daemon: could not select device driver "" with capabilities: [[gpu]].
Linux
- The recommended distro for the GEMINI App is Ubuntu. Other distros may encounter compatibility issues that will require further debugging.
- Follow the general installation and setup instructions.
- Install Docker Desktop based on the instructions for your system.
- If your system has an NVIDIA GPU that should be used for orthophoto generation, install the NVIDIA Container Toolkit and follow the relevant setup instructions.
- In a terminal, enter
docker context use default
to use the Docker Engine instead of Docker Desktop for the GEMINI App Docker container. - If your system does not have a compatible NVIDIA GPU or the NVIDIA Container Toolkit is not installed and configured, the following error will be seen during orthophoto generation:
docker: Error response from daemon: could not select device driver "" with capabilities: [[gpu]].
- This error will lead to the CPU being used for orthophoto generation, which may result in longer generation time.
Install
- Access the GEMINI-App repository.
- Clone into an IDE such as VSCode (recommended) using HTTPS or SSH. If using HTTPS, ensure your git credentials are populated via the terminal. If using SSH, make sure an SSH key for your machine is available in your Github account.
- Input the commands for setup listed on the GEMINI-App README.md:
# Download git submodules
git submodule update --init --recursive
# Install conda virtual environment
cd GEMINI-Flask-Server
./install_flask_server.sh
cd ../
# Install Node Version Manager
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
source ~/.bashrc
# Install Node 18
nvm install 18
nvm use 18
# Install dependencies
cd gemini-app
npm install --legacy-peer-deps # Fix the upstream dependency conflict
Setup
- Create a directory
GEMINI-App-Data
in your home directory (mkdir ~/GEMINI-App-Data
).- If this directory is created anywhere else, the path listed in
GEMINI-App/gemini-app/package.json
must be modified:
- If this directory is created anywhere else, the path listed in
- This path must point to a
GEMINI-App-Data
directory for the app to function. - Create and add your Map Box Access Token to the
.env
file in thegemini-app
directory like below. This is necessary for map functionality.
REACT_APP_MAPBOX_TOKEN=example.yourMapBoxAccessToken.1234
Running the App
- Finish the system-specific setup instructions above before proceeding: Windows | MacOS | Linux
- Ensure Docker Desktop is running before running the GEMINI App (or Docker Engine if running ODM with GPU on Linux).
In GEMINI-App/gemini-app
:
# Run development server (front and server concurrently)
npm run gemini
# If you want to run front only
npm run front
# If you want to run flask server only
npm run server
Troubleshooting
- If the path in
package.json
is not properly populated, aFailed to upload file
error will appear. Make sure the path points to an existing and accessible directory. This error will also be seen if the Flask Server fails to start. - To ensure that the app is properly running in Docker, after the command
npm start gemini
, ensure that the terminal is NOT cleared (meaning you should be able to scroll up and see previous commands). If the terminal is cleared (you are unable to scroll up to view previous commands), the app is not running in Docker properly. Restart Docker and try again. - Certain errors during orthophoto generation can be solved by manual deletion of the
~/GEMINI-App-Data/temp
directory. If generation is repeatedly failing, deletetemp
before the next attempt.