Welcome to the repository of the 2024/2025 [AE4353] Artificial Intelligence for Aerospace Control and Operations course! π
This repository contains all the resources for the weekly exercises and competitions associated with the course. Each week, exercises and their solutions will be published here.
To ensure a consistent and easy-to-setup coding environment for everyone, we will be using VSCode Devcontainers. This will be the official environment throughout the course, including for the final digital exam.
To get started, please refer to this README file for detailed instructions and guidance on setting up your environment correctly. Once your environment is configured, you can begin exploring the code and working on the exercises. If you have any questions or need assistance, feel free to reach out. Happy coding and learning! π
Welcome to the setup guide! This section will cover the prerequisites, including setting up GitHub Copilot, and provide step-by-step instructions for configuring your development environment on Windows, Linux (Ubuntu), or MacOS. Follow the guidelines for your operating system to ensure you have all the necessary tools and configurations. Once your setup is complete, proceed to the Usage section to begin working with the project.
GitHub Copilot is an AI-powered assistant that helps you write code faster and more efficiently. It provides intelligent code suggestions and completions based on your context, enhancing your coding experience and boosting productivity.
β οΈ We encourage you to use tools like this to aid in learning concepts and practicing coding. However, itβs important not to rely solely on these tools β ensure you put in the effort to understand and practice the material yourself! Please note that such tools will NOT be permitted during the final exam.
If you do not have it yet, please sign up for the Student Developer Pack on GitHub using this link. Once you have signed up, wait for GitHub to authenticate your request. Once authenticated, you will have access to GitHub Copilot.
If you already have access to GitHub Copilot, it comes pre-installed when you open the devcontainer. Simply log in with your GitHub account and you can start using GitHub Copilot in Visual Studio Code.
To get started with this project on Windows, follow the steps below:
-
Ensure that Visual Studio Code is equipped with the necessary extensions. Install the following extensions in Visual Studio Code: Dev Containers, Docker, and WSL.
-
Install Windows Subsystem for Linux (WSL2) with the Ubuntu 20.04 distribution. This will set up an Ubuntu terminal environment, which is necessary for the following steps.
-
Install Docker Engine in WSL2 by following these steps:
a. Open the WSL2 terminal by typing
Ubuntu
in the Windows search bar and selecting the Ubuntu app. From this step onwards, input every subsequent command in this terminal.b. Set up Docker's
apt
repository:# Add Docker's official GPG key: sudo apt-get update sudo apt-get install ca-certificates curl sudo install -m 0755 -d /etc/apt/keyrings sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc sudo chmod a+r /etc/apt/keyrings/docker.asc # Add the repository to Apt sources: echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \ $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null sudo apt-get update
c. Install the Docker packages:
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
d. Verify that Docker Engine is installed successfully:
docker --version
e. Check if Docker is running:
sudo service docker status
f. Start the service (if not running):
sudo service docker start
g. Verify that everything is installed and running correctly by running the
hello-world
image:sudo docker run hello-world
This downloads a test image and runs it in a container. You should see a confirmation message. If you see this, you have successfully installed and started Docker Engine.
-
Follow the post-installation steps for Docker Engine to set the necessary permissions for running Docker on Visual Studio Code.
-
If this is your first time using WSL2, follow these steps to install Git and set up SSH:
a. Install Git:
- Follow these instructions in the "Installing on Linux" section to install Git on Ubuntu.
- Verify the installation by running the following command:
git --version
b. Generate a new SSH key by following these instructions.
c. Add the SSH key to your GitHub account using these instructions.
Well done! Your setup on Windows is complete, and you are ready to start working on the project. Next, proceed to the Usage section to learn how to run the code.
To get started with this project on Linux (Ubuntu), follow the steps below:
-
Ensure that Visual Studio Code is equipped with the necessary extensions. Install the following extensions in Visual Studio Code: Dev Containers and Docker.
-
Install Docker Engine by following these steps:
a. Open the terminal.
b. Set up Docker's
apt
repository:# Add Docker's official GPG key: sudo apt-get update sudo apt-get install ca-certificates curl sudo install -m 0755 -d /etc/apt/keyrings sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc sudo chmod a+r /etc/apt/keyrings/docker.asc # Add the repository to Apt sources: echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \ $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null sudo apt-get update
β οΈ If the above code block execution failed, try to execute the commands one line at a time.c. Install the Docker packages:
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
d. Verify that Docker Engine is installed successfully:
docker --version
e. Check if Docker is running:
sudo service docker status
f. Start the service (if not running):
sudo service docker start
g. Verify that everything is installed and running correctly by running the
hello-world
image:sudo docker run hello-world
This downloads a test image and runs it in a container. You should see a confirmation message. If you see this, you have successfully installed and started Docker Engine.
-
Follow the post-installation steps for Docker Engine to set the necessary permissions for running Docker on Visual Studio Code.
-
If Git is not installed on your machine or you have not set up an SSH key, please refer to step 5 in the Windows section for instructions on how to do so.
Well done! Your setup on Linux (Ubuntu) is complete, and you are ready to start working on the project. Next, proceed to the Usage section to learn how to run the code.
To get started with this project on MacOS, follow the steps below:
-
Ensure that Visual Studio Code is equipped with the necessary extensions. Install the following extensions in Visual Studio Code: Dev Containers.
-
Install Docker Desktop.
-
If Git is not installed on your machine or you have not set up an SSH key, please refer to step 5 in the Windows section for instructions on how to do so. For guidance on MacOS, please refer to the instructions specific to MacOS provided in the links.
Well done! Your setup on MacOS is complete, and you are ready to start working on the project. Next, proceed to the Usage section to learn how to run the code.
To use this project, follow the steps below:
π‘ Windows users should do the steps 0-2 in WSL2.
-
If you do not have a ssh key under
$HOME/.git
, follow the steps to create a key pair and upload to Github. -
Ensure your Git credentials are available in DevContainers by configuring them according to the guidelines provided here. This will allow seamless access to repositories without repeated authentication prompts while working inside DevContainers.
-
Clone the repository and create a private mirror by following the steps outlined here. This will help you set up a secure, private copy of the repository for your use.
-
Set up a dataset folder by following these steps:
-
cd
into a directory to host the dataset folder.On Linux/MacOS we recommend the
Downloads
folder:cd ~/Downloads
β οΈ For MacOS users, avoid putting the dataset folder inDesktop
orDocuments
if you have iCloud Drive 'Sync this Mac' on.On WSL, we recommend the home folder:
cd ~
-
Create a dataset folder at the directory:
mkdir ae4353_dataset
-
Navigate to the
ae4353_dataset
directory and copy the output of the pwd command into your clipboard:cd ae4353_dataset pwd
The
pwd
command will print the absolute path to the terminal. Copy this path. -
Go back to the directory of the repository, and start visual studio code:
cd ~/AE4353-Y24 code .
You will see the files in the repository.
-
Modify the
.devcontainer/devcontainer.json
file:- Open the
.devcontainer/devcontainer.json
file. - Locate the "mounts" section.
- Uncomment the line under the "mounts" section.
- Replace
<your-external-data-directory>
with the absolute path you copied from thepwd
command.
π‘ Make sure there is at least 10GB of free space available to host the datasets.
π‘ For WSL2 users, if you create the dataset folder within WSL2, you can access your WSL2 files through File Explorer in Windows and enter
\\wsl$
in the address bar. Navigate toUbuntu-<version>\home\<your-username>
(replace<version>
with your WSL2 distribution version and<your-username>
with your Linux username).π‘ For WSL2 users, if you want to create the dataset directory outside WSL2 and in your Windows file space, you can access it under the path
/mnt/<disk>/
within WSL2. An example of<your-external-data-directory>
could be/mnt/c/Users/Downloads/Dataset_Folder
. - Open the
-
Close Visual Studio Code.
-
If your machine has a CUDA-enabled GPU, you can follow the steps in CUDA Guide in order to use GPUs in the devcontainer.
-
Download the required dataset(s) for the exercise/competition from SurfDrive and move the file(s) to the above dataset folder.
π‘ Keep the file in its original format (e.g.
.npz
) without unzipping or extracting any contents unless being instructed explicitly. -
Open Visual Studio Code, click "File -> Open Folder," and select the repository folder. For WSL2 users, first connect to the WSL2 backend by pressing
F1
and selectingWSL: Connect to WSL
. -
Set up the development environment:
-
Ensure you have the Dev Containers extension installed.
-
When you open the folder in Visual Studio Code, a prompt will appear in the bottom-right corner asking if you want to
Reopen in Container
. Click this prompt to build the Docker container, which will open a new Visual Studio Code window inside the container. This container provides a pre-configured environment with all the necessary packages to run the scripts. -
Alternatively, open the Command Palette in Visual Studio Code (
β§βP
on macOS orCtrl+Shift+P
on Windows/Linux) and selectReopen in Container
.π‘ Container build may take up to 10 minutes and require up to 10GB of storage.
π‘ During the build process of the container, click the bottom-right corner of the window to view detailed progress logs.
π‘ Once the installation is complete and the container is open, if you encounter an "Invalid Python Interpreter" error, open the Command Palette (
β§βP
on MacOS orCtrl+Shift+P
on Windows/Linux) and selectDeveloper: Reload Window
. Ensure that the Jupyter notebook kernel starts with the prefixAE4353
to confirm everything is functioning correctly.
Good job! You can now start working on the project using the pre-configured environment.
This project is licensed under the MIT License. See the LICENSE file for more details.
For any questions or inquiries, please contact us at:
- Yilun Wu: [email protected]
- Kevin Malkow: [email protected]
We will be happy to answer your questions and assist you! π