This ia a basic demo application that visualizes data in the UK Offshore wind farms example dataset. Scroll around the map to see the locations of the wind farms and click on a marker to see details about that wind farm's performance. Zoom in to see the boundaries of each wind farm as a polygon - click on that to display a pop up with additional data. Finally, scroll in some more to see the locations of individual turbines.
Other resources that use this dataset include:
- A conference talk from the AI and Big Data Expo, Amsterdam 2024. Watch it on YouTube.
- A Jupyter notebook that lets you explore the queries shown in the conference talk. Run it on Google Colab.
- The raw data for this dataset, as JSON files. Clone the GitHub repository.
Backend servers implementations for this project are available for C# and Python.
To run this project you'll need to install the following software:
- (C# version) .NET SDK (download) - we've tested this project with version 9.0 on macOS Sequoia.
- (Python version) Python 3 (download) - we've tested this project with Python 3.12 on macOS Sequoia.
- Git command line tools (download).
- Your favorite code editor, to edit configuration files and browse/edit the code if you wish. Visual Studio Code is great for this.
- Access to a cloud or local CrateDB cluster (see below for details).
Next you'll need to get a copy of the code from GitHub by cloning the repository. Open up your terminal and change directory to wherever you store coding projects, then enter the following commands:
git clone https://github.com/crate/devrel-offshore-wind-farms-demo.git
cd devrel-offshore-wind-farms-demo
You'll need a CrateDB database to store the project's data in. Choose between a free hosted instance in the cloud, or run the database locally. Either option is fine.
Create a database in the cloud by first pointing your browser at console.cratedb.cloud
.
Login or create an account, then follow the prompts to create a "CRFREE" database on shared infrastructure in the cloud of your choice (choose from Amazon AWS, Microsoft Azure and Google Cloud). Pick a region close to where you live to minimize latency between your machine running the code and the database that stores the data.
Once you've created your cluster, you'll see a "Download" button. This downloads a text file containing a copy of your database hostname, port, username and password. Make sure to download these as you'll need them later and won't see them again. Your credentials will look something like this example (exact values will vary based on your choice of AWS/Google Cloud/Azure etc):
Host: some-host-name.gke1.us-central1.gcp.cratedb.net
Port (PostgreSQL): 5432
Port (HTTPS): 4200
Database: crate
Username: admin
Password: the-password-will-be-here
Wait until the cluster status shows a green status icon and "Healthy" status before continuing. Note that it may take a few moments to provision your database.
The best way to run CrateDB locally is by using Docker. We've provided a Docker Compose file for you. Once you've installed Docker Desktop, you can start the database like this:
docker compose up
Once the database is up and running, you can access the console by pointing your browser at:
http://localhost:4200
Note that if you have something else running on port 4200 (CrateDB admin UI) or port 5432 (Postgres protocol port) you'll need to stop those other services first, or edit the Docker compose file to expose these ports at different numbers on your local machine.
Now you have a database, you'll need to create the tables that this project uses. Copy and paste the following SQL command into the database console, then execute it to create a table named windfarms
. (If your database is in the Cloud, you can find the console in the menu to the left when logged in at console.cratedb.cloud
. If you are running the database locally then go to localhost:4200
and select the console icon from the left hand menu):
CREATE TABLE windfarms (
id TEXT PRIMARY KEY,
name TEXT,
description TEXT INDEX USING fulltext WITH (analyzer='english'),
description_vec FLOAT_VECTOR(2048),
location GEO_POINT,
territory TEXT,
boundaries GEO_SHAPE INDEX USING geohash WITH (PRECISION='1m', DISTANCE_ERROR_PCT=0.025),
turbines OBJECT(STRICT) AS (
brand TEXT,
model TEXT,
locations ARRAY(GEO_POINT),
howmany SMALLINT
),
capacity DOUBLE PRECISION,
url TEXT
);
Then copy and paste this statement into the console, and execute it to create a table named windfarm_output
:
CREATE TABLE windfarm_output (
windfarmid TEXT,
ts TIMESTAMP WITHOUT TIME ZONE,
month GENERATED ALWAYS AS date_trunc('month', ts),
day TIMESTAMP WITH TIME ZONE GENERATED ALWAYS AS date_trunc('day', ts),
output DOUBLE PRECISION,
outputpercentage DOUBLE PRECISION
) PARTITIONED BY (day);
Right now your database tables are empty. Let's add some sample data! Copy and paste the following SQL statement into the console then execute it to insert records for each windfarm into the windfarms
table:
COPY windfarms
FROM 'https://cdn.crate.io/downloads/datasets/cratedb-datasets/devrel/uk-offshore-wind-farm-data/wind_farms.json'
RETURN SUMMARY;
Examine the output of this command once it's completed. You should see that 45 records were loaded with 0 errors.
Next, let's load the sample power generation data into the windfarm_output
table. Copy and paste this SQL statement into the console, then execute it:
COPY windfarm_output
FROM 'https://cdn.crate.io/downloads/datasets/cratedb-datasets/devrel/uk-offshore-wind-farm-data/wind_farm_output.json.gz'
WITH (compression='gzip')
RETURN SUMMARY;
Examine the output of this command once it's completed. You should expect 75,825 records to have loaded with 0 errors.
The backend server for this project has two different implementations, each with their own instructions.
The server is written in C# and is contained in one file: Program.cs
. This contains a minmal web application that runs code to access CrateDB when called on various endpoints, and also serves static files from the wwwroot
folder.
Database access is handled through Npgsql.
The server is written in Python as a Flask framework application. The code is contained in one file: app.py
. This contains a minimal web application that runs code to access CrateDB when called on various endpoints, and also serves static files from the static
folder.
Database access is handled through crate-python.
The front end is the same for both the C# and Python versions of the project. It uses the Leaflet map framework with OpenStreetMap standard tiles. Font Awesome is also included in the project (for rendering icons). The Bulma CSS framework is used for styling and layout.
The JavaScript code for the front end is contained in one file. For the C# project, this is wwwroot/js/app.js
and for the Python project it is static/js/app.js
. It uses the JavaScript Fetch API to interact with the C# server.
Want to learn more about CrateDB? Take our free online "CrateDB Fundamentals" course, available now at the CrateDB Academy.