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

Spellmotion

Spellmotion

J'ai entrepris ce projet en solo avec la volonté d'explorer le domaine de la vision par ordinateur à travers une application concrète. Passionné par le développement, j'ai eu l'idée de fusionner cette technologie avec la création de jeux vidéo pour concevoir une expérience immersive où les commandes physiques traditionnelles sont remplacées par des interactions naturelles. L'objectif était de transformer des concepts théoriques de traitement d'image en un outil de contrôle intuitif et réactif pour un environnement virtuel.

juillet 2025

Progression - Visualisation

Progression - Visualisation

Lors de ma dernière session au Cégep de Rosemont, j'ai eu l'opportunité de contribuer à Progression, une plateforme d'apprentissage de la programmation de type "LeetCode" développée par le département. Au sein d'une équipe de sept développeurs, notre mandat était d'enrichir l'expérience pédagogique en ajoutant une dimension visuelle à la résolution de problèmes. L'objectif était de permettre aux étudiants de ne plus seulement voir du code, mais de comprendre la dynamique de leurs algorithmes en temps réel.

février 2025

Shopnest

Shopnest

J'ai réalisé ce projet dans le cadre de mon premier cours de développement d'applications web. L'objectif était de concevoir une plateforme e-commerce complète permettant l'achat et la vente de produits de manière fluide. Ce projet a été fondateur pour moi, car il m'a permis de comprendre l'importance d'une structure solide, de la planification initiale jusqu'à la mise en ligne d'un site fonctionnel et sécurisé.

décembre 2023

View All Projects