Tested and developed using Python 3.11.5!
The LLM-based Autoscheduler is a project developed by the Data Science Club at CSUS, aiming to provide an automated scheduling system for students. 📅 The project comprises three main components:
- Scraper 🕵️♂️
- LLM API Connection 🤖
- User Interface Application 💻
The scraper is a Python-based module that retrieves class schedule data from the CSUS webpage. It utilizes Selenium and BeautifulSoup to navigate the website, render dynamic content, and parse the HTML structure.
The scraper performs the following tasks:
- Retrieves the rendered HTML content of the class schedule page.
- Parses the HTML structure using BeautifulSoup to extract relevant data.
- Stores the extracted data in a structured format (JSON) for further processing.
The LLM (Large Language Model) API Connection module establishes a connection with a language model API, in this case OpenAI GPT-3.5. This module is responsible for sending prompts to the LLM and receiving the generated responses.
The LLM API Connection module performs the following tasks:
- Authenticates with the LLM API service using provided credentials.
- Formats and sends prompts to the LLM API, including the extracted class schedule data.
- Receives and processes the generated responses from the LLM.
- Applies any necessary post-processing or formatting to the LLM responses.
The User Interface Application provides a graphical interface for users to interact with the LLM-based Autoscheduler. It acts as a bridge between the user and the underlying scraper and LLM API Connection components. It's build using the fantastic library streamlit.io, which provides a clean-looking UI on top of Python apps.
The User Interface Application offers the following features:
- A user-friendly interface for inputting preferences and constraints for scheduling (e.g., desired courses, time preferences, workload limitations).
- Integration with the scraper module to retrieve the latest class schedule data from the scraped JSON files.
- Integration with the LLM API Connection module to send prompts and receive generated schedules from the LLM.
- Display of the generated schedules in a clear and organized manner.
To see the LLM-based Autoscheduler project in action, follow these steps:
- Clone the repository:
git clone https://github.com/yourusername/llm-based-autoscheduler.git
- Install the required dependencies.
pip install -r dependencies.txt
- Configure the necessary API keys and credentials for the OpenAI API. (Tutorial)
- Select the term in the the
scraper/scraper.py
code. - Run the scraper
python3 scraper.py
to generate the fileschedules/{term}.json/
. - Go into the folder containing the streamlit app
cd streamlit
. - Run the app with
streamlit run app.py
. - Access the app at
http://localhost:8501
.
Contributions to the LLM-based Autoscheduler project are welcome! If you'd like to contribute, please follow these steps:
- Fork the repository
- Create a new branch:
git checkout -b my-new-feature
- Make your changes and commit them:
git commit -am 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request
This project is licensed under the MIT License. 📜