Enhanced project recommendation system with advanced niche discovery features
Project description
Project Chooser
A sophisticated, AI-enhanced recommendation engine designed for academic project allocation in higher education institutions. This system employs advanced algorithmic approaches including Bayesian inference and niche discovery to optimise student-project matching.
Features
- 🧠 Bayesian Inference Engine: Smart question selection to minimize cognitive load during preference elicitation
- 🔍 Niche Discovery Algorithm: Identifies uncommon yet potentially suitable projects through cross-domain analysis
- ⚡ Adaptive Questioning: Dynamically adjusts strategy based on user responses to maximize information gain
- 📊 Multi-dimensional Scoring: Combines preference matching, novelty detection, and practical constraints
- 📈 Statistical Analysis: Comprehensive analytical reports on project distribution and allocation patterns
- ⚙️ Configurable Parameters: Fine-tune scoring weights and algorithmic parameters for your institution
Quick Start
Installation
Install from PyPI using pip:
pip install project-chooser
Or using Poetry:
poetry add project-chooser
Basic Usage
-
Interactive Recommendation (recommended for new users):
project-chooser recommend --interactive
-
Batch Processing with a JSON file:
project-chooser recommend --input preferences.json --output recommendations.json
-
Data Validation:
project-chooser validate projects.json
-
Generate Analysis Report:
project-chooser analyse projects.json --output analysis_report.json
Project Data Format
Create a projects.json file with your project data:
{
"projects": [
{
"id": "PROJ001",
"title": "Machine Learning in Climate Modeling",
"description": "Apply ML techniques to climate data analysis",
"degree": "Computer Science",
"year": 4,
"supervisor": "Dr. Smith",
"topics": ["machine learning", "climate science", "data analysis"],
"skills_required": ["Python", "TensorFlow", "Statistics"],
"difficulty": "Hard",
"group_size": "Individual"
}
]
}
Algorithm Details
Bayesian Inference Engine
The system uses information-theoretic question selection to minimize the number of questions needed to understand user preferences, reducing cognitive load while maximizing information gain.
Niche Discovery
Advanced algorithms identify projects that may not be obvious matches but could be excellent fits based on:
- Cross-domain skill transfer potential
- Novelty scoring mechanisms
- Hidden preference pattern recognition
Scoring System
Multi-dimensional scoring considers:
- Direct preference matching
- Skill requirement alignment
- Supervisor preferences
- Workload and difficulty matching
- Diversity and exploration factors
Development Setup
For contributors and advanced users:
# Clone the repository
git clone https://github.com/unkokaeru/project-chooser.git
cd project-chooser
# Install with Poetry (recommended)
poetry install --with dev
poetry shell
# Or install with pip
pip install -e ".[dev]"
Configuration
The system can be configured through environment variables or config files:
export PROJECT_CHOOSER_DEBUG=true
export PROJECT_CHOOSER_MAX_QUESTIONS=10
Contributing
We welcome contributions! Please see our Contributing Guide for details.
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Make your changes
- Add tests for your changes
- Run the test suite (
poetry run pytest) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support
Changelog
See CHANGELOG.md for a detailed history of changes.
Made with ❤️ for academic institutions worldwide
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file project_chooser-1.0.0.tar.gz.
File metadata
- Download URL: project_chooser-1.0.0.tar.gz
- Upload date:
- Size: 42.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29627492803f984ea041f2d3f03786123fc3c23ac91fc44c50f9f1cf7bcdc160
|
|
| MD5 |
a61011c548a725a7dacc658895cad481
|
|
| BLAKE2b-256 |
253dd02a463d9336c5f1511c5eb6c2a3d3f841a900314c52f3a209867b2b9d2d
|
File details
Details for the file project_chooser-1.0.0-py3-none-any.whl.
File metadata
- Download URL: project_chooser-1.0.0-py3-none-any.whl
- Upload date:
- Size: 49.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f22c012291978035dd0cd78e1fbe7ec1d07f26362895faa9121d35075de8c1ed
|
|
| MD5 |
b37277f6530abd439a47dc7d06b716dd
|
|
| BLAKE2b-256 |
96b1f26a23d84456ff0c1784ffc21286ec419ce12c4244a00878e5f67ff9bc30
|