Spaces:
Sleeping
Sleeping
title: Sentiment Analysis App | |
emoji: 🚀 | |
colorFrom: green | |
colorTo: purple | |
sdk: streamlit | |
sdk_version: 1.17.0 | |
app_file: app.py | |
pinned: false | |
# AI Project: Finetuning Language Models - Toxic Tweets | |
Hello! This is a project for CS-UY 4613: Artificial Intelligence. I'm providing a step-by-step instruction on finetuning language models for detecting toxic tweets. | |
# Milestone 1 | |
This milestone includes setting up docker and creating a development environment on Windows 11. | |
## 1. Enable WSL2 feature | |
The Windows Subsystem for Linux (WSL) lets developers install a Linux distribution on Windows. | |
``` | |
wsl --install | |
``` | |
Ubuntu is the default distribution installed and WSL2 is the default version. | |
After creating linux username and password, Ubuntu can be seen in Windows Terminal now. | |
Details can be found [here](https://learn.microsoft.com/en-us/windows/wsl/install). | |
data:image/s3,"s3://crabby-images/669f4/669f4cd4ef34b40d6fefc2c0fb93bcf53179d3d3" alt="" | |
## 2. Download and install the Linux kernel update package | |
The package needs to be downloaded before installing Docker Desktop. | |
However, this error might occur: | |
`Error: wsl_update_x64.msi unable to run because "This update only applies to machines with the Windows Subsystem for Linux"` | |
Solution: Opened Windows features and enabled "Windows Subsystem for Linux". | |
Successfully ran update [package](https://docs.microsoft.com/windows/wsl/wsl2-kernel). | |
data:image/s3,"s3://crabby-images/9b3f3/9b3f320cfe5d2ba51d29173c10e90417aa5cdce4" alt="" | |
## 3. Download Docker Desktop | |
After downloading the [Docker App](https://www.docker.com/products/docker-desktop/), WSL2 based engine is automatically enabled. | |
If not, follow [this link](https://docs.docker.com/desktop/windows/wsl/) for steps to turn on WSL2 backend. | |
Open the app and input `docker version` in Terminal to check server running. | |
data:image/s3,"s3://crabby-images/07c5e/07c5e734c668a61c7d4ecc6f8ac33c5dc65c612d" alt="" | |
Docker is ready to go. | |
## 4. Create project container and image | |
First we download the Ubuntu image from Docker’s library with: | |
``` | |
docker pull ubuntu | |
``` | |
We can check the available images with: | |
``` | |
docker image ls | |
``` | |
We can create a container named *AI_project* based on Ubuntu image with: | |
``` | |
docker run -it --name=AI_project ubuntu | |
``` | |
The `–it` options instruct the container to launch in interactive mode and enable a Terminal typing interface. | |
After this, a shell is generated and we are directed to Linux Terminal within the container. | |
`root` represents the currently logged-in user with highest privileges, and `249cf37645b4` is the container ID. | |
data:image/s3,"s3://crabby-images/2cb2f/2cb2f9dae1f493f2fb671a33a8c85aa76abf0e30" alt="" | |
## 5. Hello World! | |
Now we can mess with the container by downloading python and pip needed for the project. | |
First we update and upgrade packages by: (`apt` is Advanced Packaging Tool) | |
``` | |
apt update && apt upgrade | |
``` | |
Then we download python and pip with: | |
``` | |
apt install python3 pip | |
``` | |
We can confirm successful installation by checking the current version of python and pip. | |
Then create a script file of *hello_world.py* under `root` directory, and run the script. | |
You will see the following in VSCode and Terminal. | |
data:image/s3,"s3://crabby-images/55a70/55a7069db03935839ff68e5747595f7cc6b6d69b" alt="" | |
data:image/s3,"s3://crabby-images/df122/df1228372a7e3d777c5655b34dc73e46fad52924" alt="" | |
## 6. Commit changes to a new image specifically for the project | |
After setting up the container we can commit changes to a specific project image with a tag of *milestone1* with: | |
``` | |
docker commit [CONTAINER] [NEW_IMAGE]:[TAG] | |
``` | |
Now if we check the available images there should be a new image for the project. If we list all containers we should be able to identify the one we were working on through container ID. | |
data:image/s3,"s3://crabby-images/f1898/f1898e51575afb1194e4d2d0ed8e203a501e5f87" alt="" | |
The Docker Desktop app should match the image list we see on Terminal. | |
data:image/s3,"s3://crabby-images/f31c2/f31c2d9cd276460d2f6093ca6c74f09f720de252" alt="" | |