-
-
Notifications
You must be signed in to change notification settings - Fork 61
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Local installation instruction and formulations in UI, especially "label". #211
Closed
Closed
Changes from all commits
Commits
Show all changes
3 commits
Select commit
Hold shift + click to select a range
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,206 @@ | ||
Docker Compose is used to create a full installation of fAIr (with redis, worker, postgis database, api and frontend), all in one Docker container. This setup is suitable for development. For production it is not recommended. ***TODO*** What is production? Is it the version that executes on the web site? | ||
|
||
## Installation of fAIr using Docker | ||
|
||
In the following, four directories are created: ```fair, ramp-code, ramp``` and ```training```, for the fAIr code, the model code, the model variables, and temporary data used during fine-tunining training of the (RAMP) model. It is a good idea to create these directories in the same, new, directory, created for this installation of fAIr and its companions. | ||
|
||
1. Check your graphics card | ||
|
||
It is highly recommended to use a graphics card to run fAIr. It might not work with CPU only. (You can set up and test from bottom of this document). ***TODO*** What does this mean? NVIDIA graphics cards are tested. The bottom of this document is about a tile server, whatever that is. But it is not a GPU test?! ***TODO*** Does this mean that it works for NVIDIA cards but not for cards from other brands? | ||
|
||
For the local fAIr installation to work the necessary drivers for the graphics card need to be installed. | ||
|
||
By the following command you can see your graphics card and the graphics driver details and the NVIDIA container toolkit that is installed. There is more information on the [NVIDIA site](https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/install-guide.html). | ||
|
||
``` | ||
nvidia-smi | ||
``` | ||
|
||
You need to see your graphics card details here. ***TODO*** Does this mean that if this command shows details about my GPU, then it is OK for fAIr? | ||
|
||
2. Install Docker Compose | ||
|
||
If Docker is not installed, Install it from the [Docker site](https://docs.docker.com/engine/install/). | ||
|
||
To check whether Docker is installed, type | ||
|
||
``` | ||
docker compose version | ||
``` | ||
|
||
3. Clone the repository for fAIr. | ||
|
||
In a Windows Command Prompt window, type | ||
|
||
``` | ||
git clone https://github.com/hotosm/fAIr.git | ||
``` | ||
|
||
This creates directory ```./fAIr```. | ||
|
||
4. Clone the Base Model and create environment variable RAMP_HOME | ||
|
||
- Clone the RAMP code. | ||
|
||
``` | ||
git clone https://github.com/kshitijrajsharma/ramp-code-fAIr.git | ||
``` | ||
|
||
This creates directory ```./ramp-code-fAIr```. | ||
|
||
- Create environment variable RAMP_HOME | ||
|
||
Set RAMP_HOME to be the file path to the directory ```ramp-code-fAIr```. | ||
|
||
``` | ||
set RAMP_HOME=C:\Users\kshitij\fAIr_install\ramp-code-fAIr | ||
``` | ||
|
||
- Download pre-trained variable values for the RAMP model from [here](https://drive.google.com/file/d/1YQsY61S_rGfJ_f6kLQq4ouYE2l3iRe1k/view). | ||
|
||
If that doesn't work, you can alternatively use the variables in the original RAMP model, [RAMP Baseline](https://github.com/radiantearth/model_ramp_baseline/tree/main/data/input/checkpoint.tf) | ||
|
||
- Create a new folder called ```ramp-variables```. | ||
|
||
``` | ||
mkdir ramp-variables | ||
``` | ||
|
||
- Unzip the downloaded base model variables in subdirectory ```ramp-variables```. | ||
|
||
Move the compressed file to directory ```ramp-variables```. Right-click on it in File Explorer and choose "Extract All...". | ||
|
||
- Create environment variable TRAINING_WORKSPACE | ||
|
||
Training workspace is the directory where fAIr will store its training files | ||
for example. ***TODO*** Is this about a new checkpoint after fine-tuning? The name implies that this is for temporary files. | ||
|
||
``` | ||
mkdir trainings | ||
set TRAINING_WORKSPACE=C:\Users\kshitij\fAIr_install\trainings | ||
``` | ||
|
||
5. Register your Local setup to OSM ***TODO*** Settings in OSM? "your Local setup" = my local fAIr installation? | ||
|
||
- Go to [OpenStreetMap](https://www.openstreetmap.org/), Log in (If needed: Create an account first.). | ||
- Click on your Profile and Hit ```My Settings``` | ||
- Navigate to ```Oauth2 Applications``` | ||
- Register a new application | ||
- Check permissions for ```Read user preferences``` and set Redirect URI to be ```http://127.0.0.1:3000/authenticate/```. Give it the name ```fAIr Dev Local``` | ||
- You will get ```OSM_CLIENT_ID``` and ```OSM_CLIENT_SECRET```. Copy them. | ||
|
||
6. Create environment files | ||
|
||
- Create a file ```.env``` in directory backend with a copy of the content in [docker_sample_env](../backend/docker_sample_env). | ||
|
||
``` | ||
cd backend | ||
copy docker_sample_env .env | ||
``` | ||
|
||
- Fill in the details of ```OSM_CLIENT_ID``` and ```OSM_CLIENT_SECRET``` in the .env file and generate a unique key and paste it to ```OSM_SECRET_KEY``` (It can be any value in a setup for development). | ||
|
||
Leave the other items as they are, unless you have a specific, well-defined need. | ||
|
||
- Create ```.env``` in directory frontend | ||
|
||
``` | ||
cd frontend | ||
copy .env_sample .env | ||
``` | ||
|
||
There is no need to modify this file in a setup for development. | ||
|
||
7. Build and Run containers | ||
|
||
In directory fAIr, run the following commands: | ||
|
||
``` | ||
docker compose build | ||
docker compose up | ||
``` | ||
|
||
8. Run Migrations | ||
|
||
***TODO*** What does "migration" mean in this context? | ||
|
||
Grab API container and Open Bash: In another command window, go to directory fAIr and execute: | ||
|
||
``` | ||
docker exec -it api bash | ||
``` | ||
|
||
Once bash is promoted run the following commands, one at a time: ***TODO*** How do we know when bash is promoted? What does "promoted" mean in this context? | ||
|
||
python manage.py makemigrations | ||
python manage.py makemigrations login | ||
python manage.py makemigrations core | ||
python manage.py migrate | ||
|
||
9. Play | ||
|
||
Restart containers | ||
|
||
``` | ||
docker compose restart | ||
``` | ||
|
||
Frontend will be available on port 5000, Backend on 8000, and Flower on 5500. | ||
|
||
To use your local fAIr installation, go to [Local fAIr](http://127.0.0.1:3000) with your web browser. | ||
***TODO*** There is a list of port numbers, but it doesn't include 3000, which seems to be the most important one. Is this a bug or a feature? | ||
|
||
Extra: Do you want to run your local tiles from local .geotiff without uploading to OAM? | ||
|
||
You can use [TiTiler](https://github.com/developmentseed/titiler), [gdals2tiles](https://gdal.org/programs/gdal2tiles.html) or nginx to run your own TMS server and add the following to docker compose in order to access your localhost through docker containers. Add this to API and Worker. Also update the .env variable accordingly | ||
|
||
``` | ||
network_mode: "host" | ||
``` | ||
|
||
Example docker compose : | ||
|
||
``` | ||
backend-api: | ||
build: | ||
context: ./backend | ||
dockerfile: Dockerfile_CPU | ||
container_name: api | ||
command: python manage.py runserver 0.0.0.0:8000 | ||
|
||
ports: | ||
- 8000:8000 | ||
volumes: | ||
- ./backend:/app | ||
- ${RAMP_HOME}:/RAMP_HOME | ||
- ${TRAINING_WORKSPACE}:/TRAINING_WORKSPACE | ||
depends_on: | ||
- redis | ||
- postgres | ||
network_mode: "host" | ||
|
||
backend-worker: | ||
build: | ||
context: ./backend | ||
dockerfile: Dockerfile_CPU | ||
container_name: worker | ||
command: celery -A aiproject worker --loglevel=INFO --concurrency=1 | ||
|
||
volumes: | ||
- ./backend:/app | ||
- ${RAMP_HOME}:/RAMP_HOME | ||
- ${TRAINING_WORKSPACE}:/TRAINING_WORKSPACE | ||
depends_on: | ||
- backend-api | ||
- redis | ||
- postgres | ||
network_mode: "host" | ||
``` | ||
|
||
Example .env after this host change : | ||
|
||
``` | ||
DATABASE_URL=postgis://postgres:admin@localhost:5434/ai | ||
CELERY_BROKER_URL="redis://localhost:6379/0" | ||
CELERY_RESULT_BACKEND="redis://localhost:6379/0" | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -114,9 +114,9 @@ const AOI = (props) => { | |
return ( | ||
<> | ||
<Grid item md={12} className="card" marginBottom={1}> | ||
<Tooltip title="For each AOI, we need to make sure labels inside it are alighed and complete to acheive best model accuracy"> | ||
<Tooltip title="For each AOI, we need to ensure that all buildings are mapped and correctly aligned."> | ||
<Typography sx={{ mt: 4, mb: 2 }} variant="h6" component="div"> | ||
List of Area of Interests{` (${props.mapLayers.length})`} | ||
List of Areas of Interest{` (${props.mapLayers.length})`} | ||
</Typography> | ||
</Tooltip> | ||
<Demo> | ||
|
@@ -151,9 +151,9 @@ const AOI = (props) => { | |
<span style={{ color: "red" }}> | ||
{parseInt(layer.area) < 5000 ? ( | ||
<> | ||
Area seems to be very small for an AOI | ||
The area is too small. | ||
<br /> | ||
Please delete it and create a bigger AOI | ||
Delete it and create a larger AOI. | ||
</> | ||
) : ( | ||
"" | ||
|
@@ -170,7 +170,7 @@ const AOI = (props) => { | |
{/* <IconButton aria-label="comments"> | ||
<DeleteIcon /> | ||
</IconButton> */} | ||
{/* <Tooltip title="Create Labels on RapID Editor"> | ||
{/* <Tooltip title="Create map feature in RapID Editor"> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. map features sound good |
||
<IconButton | ||
aria-label="comments" | ||
sx={{ width: 24, height: 24 }} | ||
|
@@ -199,7 +199,7 @@ const AOI = (props) => { | |
/> | ||
</IconButton> | ||
</Tooltip> */} | ||
<Tooltip title="Create Labels on JOSM Editor"> | ||
<Tooltip title="Create map features in JOSM Editor"> | ||
<IconButton | ||
aria-label="comments" | ||
sx={{ width: 24, height: 24 }} | ||
|
@@ -298,7 +298,7 @@ const AOI = (props) => { | |
className="margin1" | ||
onClick={(e) => { | ||
mutateFetch(layer.aoiId); | ||
console.log("call raw data API to fetch OSM labels"); | ||
console.log("call raw data API to fetch OSM data"); | ||
}} | ||
> | ||
<MapTwoTone fontSize="small" /> | ||
|
@@ -310,11 +310,11 @@ const AOI = (props) => { | |
disabled | ||
onClick={(e)=> { | ||
|
||
console.log("Remove labels ") | ||
console.log("Remove OSM data ") | ||
}}> | ||
<PlaylistRemoveIcon /> | ||
</IconButton> */} | ||
<Tooltip title="Zoom to layer"> | ||
<Tooltip title="Zoom to AOI"> | ||
<IconButton | ||
sx={{ width: 24, height: 24 }} | ||
className="margin1" | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Currently its building but label might not represent only buildings later stage , I wonder how we can communicate this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is surprisingly difficult. We cannot say "all map features" because we cannot handle all kinds of map features. Saying "all map features that fAIr can handle" is too complex and subtle. Can we stay with "buildings" and hope it is updated when needed? I think that even if roads and water flows are added, "buildings" is more useful than "labels".