Logo
Accueil
Projets
Blog

Prêt à créer
quelque chose d'incroyable ?

Company logo

Ali Benkarrouch

Étudiant en génie logiciel à l'ETS

Get upTélécharger mon CV
LinkedInGithubEmail

Contactez-moi

© 2026 Ali Benkarrouch. Tous droits réservés.
0%
Tous les projets
Genie Optiroll
mars 2026

Genie Optiroll

En tant que pianiste, je trouve souvent la lecture de partitions traditionnelles chronophage et je préfère de loin les représentations visuelles de type "piano roll". Comme toutes les chansons ne disposent pas de ce genre de tutoriel en ligne, j'ai voulu créer un outil capable de convertir instantanément n'importe quelle partition en un piano roll interactif. L'intégration de contrôles de vitesse me permet de ralentir les passages complexes, ce qui facilite grandement l'apprentissage de nouveaux morceaux directement à mon piano. Par ailleurs, cela faisait un moment que je voulais reprendre mon projet "Genies" de 2024 pour en créer une "v2". J'ai donc décidé de lancer une nouvelle série de projets indépendants sous l'appellation "Genie", qui regroupera toutes mes applications liées à l'IA et à la vision par ordinateur. C'est la raison pour laquelle le nom du projet commence par "Genie:", tandis que "Optiroll" est la contraction de "Optique" (pour la reconnaissance optique de musique) et "Roll" (pour le piano roll).

Ma contribution

J'ai décidé de réaliser ce projet entièrement seul. En tant qu'unique développeur, j'ai géré l'intégralité du cycle de développement, de la conception de l'interface utilisateur et du codage du frontend React, jusqu'à la création du backend FastAPI et l'intégration du pipeline de vision par ordinateur.

Project Gallery

Visual Overview

Genie Optiroll screenshot 1

Approche

M'appuyant sur mes expériences passées en vision par ordinateur, j'avais initialement prévu de créer un algorithme de détection de notes à partir de zéro en utilisant OpenCV. J'ai cependant vite réalisé l'immense complexité, les cas particuliers et les règles strictes liés à la notation musicale standard. J'ai donc revu ma stratégie et fait des recherches sur la reconnaissance optique de musique (OMR), pour finalement opter pour oemer, un modèle pré-entraîné performant. J'ai configuré un backend FastAPI qui exécute oemer sur les images téléchargées pour générer un fichier MusicXML, puis utilise muspy pour extraire les événements MIDI précis (hauteur, temps, durée). Côté frontend, j'ai développé un visualiseur sur mesure avec HTML Canvas pour afficher les barres défilantes et intégré la bibliothèque Web Audio smplr pour offrir un rendu sonore réaliste et contrôlable directement dans le navigateur.

Fonctionnalités

  • Téléchargement de partitions
  • Rouleau piano interactif
  • Vitesse de lecture
  • Plusieurs instruments audio
  • Transposition de hauteur
  • Superposition d'instruments
  • Thèmes visuels personnalisés
  • Bibliothèque de partitions

Technos

GSAPGSAPOpenCVOpenCVViteViteSQLiteSQLiteReactReactTailwindTailwindFastAPIFastAPImuspymuspyPythonPythonOemer (OMR)smplr

Sources

Github
Github

More Projects

Explore Other Work

Devil fruit Encyclopedia

Devil fruit Encyclopedia

Grand fan de l'univers de One Piece, j'ai créé ce projet pour concevoir une encyclopédie interactive dédiée aux Fruits du Démon. L'idée était de construire une ressource centralisée et structurée permettant de répertorier chaque fruit, son type et ses capacités. Ce projet m'a permis de mettre en pratique le développement d'une architecture moderne séparant totalement la gestion des données (API) de l'expérience utilisateur (Client).

novembre 2024

Portail DTI

Portail DTI

Lors de mon dernier cours d’application Web au cégep, on devait choisir un projet dans une liste proposée par notre enseignant. Avec mon équipe, on a décidé de se lancer dans quelque chose d’assez ambitieux : le portail du département d’informatique. L’idée derrière ce projet était de concevoir un espace numérique pour les étudiants du programme. Un lieu pensé pour favoriser l’entraide, le tutorat, le partage d’événements, la mise en valeur de projets, mais aussi la création et la consultation de tutoriels. En bref, un vrai portail collaboratif qui rassemble la communauté étudiante autour du développement et du partage de connaissances.

décembre 2024

Netpulse

Netpulse

J'ai développé Netpulse avec la volonté d'approfondir mes connaissances théoriques sur le fonctionnement des réseaux informatiques. Je voulais comprendre concrètement comment les données circulent, comment les paquets sont structurés et comment les protocoles interagissent entre eux. En créant mon propre analyseur, j'ai pu passer de la théorie des couches réseau à une observation réelle et détaillée du trafic de données.

août 2024

View All Projects