Skip to content

Latest commit

 

History

History
133 lines (89 loc) · 5.19 KB

README.md

File metadata and controls

133 lines (89 loc) · 5.19 KB

Resource Forecasting in 6G Non-Terrestrial Networks (6G-NTN)

Table of Contents

📖Introduction

Welcome to 6G-NTN-resource-forecasting project! This project leverages Machine Learning techniques to forecast resource allocation in the context of 6G Non-Terrestrial Networks (6G-NTN). Our goal is to develop ML solutions for resource forecasting, thereby enabling dynamic orchestration of virtual resources in 6G-NTN environments. Read the article if you want to know more!

⚙Installation

Prerequisites:

  • Docker>=24.0.7

Setup

  1. Clone the repository:
git clone https://github.com/martel-innovate/6G-NTN-resource-forecasting
cd 6G-NTN-resource-forecasting
  1. Run Docker desktop

  2. Start docker compose

cd src
docker-compose --profile compose-project up -d --build

It can take around 10 minutes, so you might want to grab a coffee ☕

This will start the following Docker containers:

Note: The project requires environment variables to be specified. Please add a .env file in the src directory following the .env.example file.

  1. Build and run a prefect CLI
docker-compose run --build prefect-cli  

This will open a shell inside a Docker container. From here you can:

  1. Create the work pool
prefect work-pool create LSTM_forecasting

Select type "Prefect Agent". Go to http://localhost:4200/work-pools: you should see the new work pool created.

  1. Set MinIO storage
python scripts/set_block_storage.py
  1. Upload scripts to MinIO
python scripts/load_minio.py

Check on MinIO UI if files have been added.

  1. Deploy scripts
prefect deployment build scripts/load_postgres.py:get_input -n 'load_postgres' --pool 'LSTM_forecasting' -sb 'remote-file-system/minio' 
prefect deployment apply get_input-deployment.yaml  

prefect deployment build scripts/distributed_LSTM_univariate.py:ml_pipeline -n 'distributed_LSTM_univariate' --pool 'LSTM_forecasting' -sb 'remote-file-system/minio' 
prefect deployment apply ml_pipeline-deployment.yaml  

Go to http://localhost:4200/deployments and you should see the two deployments.

  1. Exit Prefect CLI
exit
  1. Start Prefect worker
docker-compose --profile prefect-worker up -d --build
  1. Run scripts

Go to http://localhost:4200/deployments and using the UI execute a Quick Run.

If when running the deployment there is a popup asking for environmental variable, uncheck the box and click on run.

🏛Architecture

The AI-Powered Network Forecasting platform is essential for executing Machine Learning (ML) pipelines, enabling the automated training and retraining of ML models. ML and Deep Learning (DL) experiments are initiated by Prefect, a Machine Learning Function Orchestrator that orchestrates workflows utilizing a cloud-native infrastructure. The execution environment of Prefect flows is managed by Docker containers.

In the picture below, you can see the system architecture of our platform.

Architecture of AI-Powered Network Forecasting

📉Sequence Diagram

Below is the sequence diagram illustrating the workflow of data collection, storage, and prediction in our project:

Sequence Diagram

🏗Prefect distributed architecture

Below is the architecture we used to interconnect Prefect components in a distributed environment. All components are deployed using Docker containers to ensure consistent and isolated execution environments. Prefect Architecture

📜License

This project is licensed under the GPL3.0 License. See the LICENSE file for more details.

📌Acknowledgement

This repository is part of the 6G-NTN project. 6G-NTN project has received funding from the Smart Networks and Services Joint Undertaking (SNS JU) under the European Union’s Horizon Europe research and innovation programme under Grant Agreement No 101096479. This work has received funding from the Swiss State Secretariat for Education, Research and Innovation (SERI). Views and opinions expressed are however those of the author(s) only and do not necessarily reflect those of the European Union. Neither the European Union nor the granting authority can be held responsible for them. For more details about the project, visit the 6G-NTN project website or the 6G-NTN LinkedIn page.

European Union 6G SNS funding SERI