Plonge dans le monde intrigant du modèle de la chute d'eau, un processus de conception séquentielle souvent utilisé dans le développement de logiciels. C'est un modèle ancré dans les annales de l'histoire de l'informatique, mais qui continue à trouver des applications pertinentes dans divers aspects de l'ingénierie logicielle. En approfondissant son cycle de vie, il est possible d'explorer les étapes clés qui constituent son cadre et de voir comment l'approche itérative y trouve sa place. L'évaluation des caractéristiques du modèle n'est pas complète si l'on n'en pèse pas les avantages et les inconvénients pour obtenir un point de vue équilibré. En outre, tu juxtaposeras la méthodologie Agile au modèle Waterfall, ce qui te permettra de mieux comprendre leurs caractéristiques distinctives et de savoir quand choisir l'une plutôt que l'autre dans le domaine de l'informatique. Enfin, tu élargiras ton répertoire de techniques de résolution de problèmes en comprenant comment le modèle de la chute d'eau peut offrir une approche structurée, en affinant ces connaissances à l'aide d'exemples d'études de cas réels. Ce voyage promet d'être une plongée profonde dans les mécanismes, les applications et les implications du modèle de la chute d'eau, améliorant ainsi ta compréhension de ce jalon important de l'informatique.
Dans le monde de l'informatique, tu entendras parler de diverses méthodologies et de divers modèles employés pour assurer un développement harmonieux et systématique des logiciels. Parmi eux, le modèle de la chute d'eau occupe une place importante.
Origines et aperçu du modèle de la chute d'eau en informatique
Initialement présenté par Winston Royce en 1970, le modèle de la chute d'eau est l'une des premières approches en matière de développement de logiciels. Son nom provient de sa nature séquentielle. Lorsqu'on le visualise, ce modèle ressemble à une chute d'eau qui s'écoule de haut en bas, d'où le terme "modèle de la chute d'eau".
Le modèle de la cascade fait référence à un modèle de cycle de vie linéaire-séquentiel, où le progrès est perçu comme s'écoulant régulièrement vers le bas (comme une chute d'eau) à travers des phases définies telles que les exigences, la conception, la mise en œuvre, la vérification et la maintenance. Chacune de ces phases est conçue pour être exécutée une fois au cours du cycle de vie d'un projet de développement logiciel.
Supposons que tu développes une application de quiz. Tout d'abord, tu recueilleras toutes les exigences et tu les noteras. Ensuite, en fonction de ces exigences, tu concevras le design de l'application. Vient ensuite la phase de mise en œuvre, au cours de laquelle le codage réel est effectué pour donner vie à la conception. Le logiciel est ensuite vérifié par des tests et des contrôles de qualité. La dernière phase est celle de la maintenance, au cours de laquelle tu t'efforces de veiller à ce que le logiciel continue à fonctionner correctement, en corrigeant les bogues et en le mettant à jour si nécessaire.
Ce modèle est surtout utilisé pour les petits projets dont les exigences sont très claires, car il nécessite une approche disciplinée et méthodique dans le développement.
Application du modèle de la chute d'eau au génie logiciel
L'application du modèle Waterfall dans le génie logiciel suit une approche systématique et séquentielle où chaque phase dépend des produits livrables de la phase précédente. Voici un aperçu plus approfondi des étapes séquentielles que tu dois suivre lorsque tu utilises le modèle de la chute d'eau :
Il est essentiel de noter que dans le modèle Waterfall, une fois qu'une phase a été achevée, il est difficile de revenir à une étape précédente pour apporter des changements. En effet, chaque phase s'appuie fortement sur les informations et les produits livrables de la phase précédente. Il est donc essentiel que les exigences soient claires et bien documentées dès le départ.
Tu trouveras ci-dessous un tableau simple pour illustrer les différentes phases du modèle de la chute d'eau :
Phase
Description de la phase
Analyse des besoins
À ce stade, des détails complexes sur les exigences du système sont recueillis.
Conception du système
La phase de conception du système consiste à détailler les exigences en matière de matériel et de système et à concevoir l'architecture du système.
Mise en oeuvre
Une fois que la conception du système est prête, le travail est divisé en unités ou en modules et le codage commence.
Une fois la phase de codage terminée, la voie est tracée pour la phase de test. Au cours de cette phase, le système sera testé pour détecter d'éventuelles erreurs, bogues ou incohérences.
Déploiement
Une fois les tests réussis, le système est déployé chez le client pour qu'il puisse l'utiliser.
Maintenance
Après le déploiement, le système fait l'objet d'une maintenance. Ceci est fait pour fournir ces services au client qui a fourni ce logiciel fonctionnel mais acceptable après l'inspection du client.
Enfin, il est essentiel que tu comprennes les avantages et les limites du modèle de la chute d'eau lorsque tu l'envisages pour tes projets de développement de logiciels. Malgré son approche simple et directe, il peut ne pas convenir aux projets dont les exigences ne sont pas claires ou aux projets qui sont vastes et complexes. Il est donc conseillé d'analyser en profondeur la nature et les exigences du projet avant d'opter pour ce modèle.
Le cycle de vie du modèle en cascade
Il est essentiel de comprendre le cycle de vie du modèle de la chute d'eau pour pouvoir l'appliquer efficacement. Il se caractérise par une séquence d'étapes où chaque étape englobe entièrement et exclusivement un ensemble de tâches. Au fur et à mesure que tu progresses dans ces étapes, garde à l'esprit que les allers-retours sont souvent limités, ce qui renforce la nécessité d'une planification minutieuse et d'une documentation approfondie.
Principales étapes du modèle de cycle de vie en cascade
Détaillons les étapes fondamentales du modèle de cycle de vie en cascade :
Exigences :
Conception :
Mise en œuvre :
Vérification :
Maintenance :
La phase des exigences s 'apparente à la pose des fondations d'un bâtiment. Tu rassembles tous les éléments nécessaires, tels que les exigences du client, les exigences du système et les besoins de l'utilisateur, pour te donner une image complète de ce qui doit être fait. C'est l'occasion de prévoir et de traiter les complexités et les ambiguïtés potentielles avant de passer à la phase de conception. Ensuite, la phase de conception est celle où les étapes de conception du système et du logiciel sont traitées. La conception du système permet de spécifier les exigences du matériel et du système et de définir l'architecture globale du système. La conception architecturale, la conception au niveau des composants et les aspects relatifs à la structure des données sont précisés à ce stade. C'est à ce stade que tu dois prendre tes exigences approfondies et les transformer en une conception réalisable. La phase de mise en œuvre est la phase pratique et concrète du codage. Le système est développé en petits programmes appelés unités, qui sont intégrés dans la phase suivante. Chaque unité est développée et sa fonctionnalité est testée, ce que l'on appelle le test d'unité. Lavérification est la phase qui valide le produit en vue d'une étude détaillée et d'une rectification des bogues découverts. Le système est testé pour s'assurer qu'il fonctionne comme prévu et qu'il répond aux exigences prédéfinies de l'utilisateur recueillies lors de la première phase. Les tests peuvent être effectués au niveau de l'unité, de l'intégration et du système pour garantir la robustesse et l'état de préparation. La dernière étape concerne la maintenance. Cette phase est initiée après le déploiement du produit dans l'environnement du client et consiste à mettre en œuvre des changements pour améliorer les performances ou modifier les fonctionnalités.
Mise en œuvre du modèle itératif en cascade dans le cycle de vie
Il arrive que le modèle de la chute d'eau directe ne corresponde pas aux besoins de développement d'un projet. C'est là qu'intervient le modèle itératif de la chute d'eau. Contrairement au modèle de la chute d'eau, cette approche permet un développement itératif et un perfectionnement par étapes.
Le modèle itératif de la chute d'eau consiste à répéter la séquence linéaire du modèle de la chute d'eau de façon itérative, en ajoutant plus de caractéristiques à des niveaux de détail croissants à chaque répétition.
Le processus de base d'un modèle itératif en cascade ressemblerait à ceci :
Initialiser les exigences, concevoir et mettre en œuvre une maquette ou un prototype, puis vérifier à l'aide de tests.
En fonction des réactions et des résultats des tests, affiner les exigences, la conception et la mise en œuvre.
Recommence à partir de l'étape 1 jusqu'à ce que le produit soit entièrement développé et prêt à être déployé.
Dans un modèle itératif en cascade, le projet est divisé en parties plus petites appelées itérations. Chaque itération implique une séquence de tâches qui sont similaires à celles utilisées dans un modèle de chute d'eau traditionnel. À la fin d'une itération, une version du logiciel est publiée.
Par exemple, disons que tu es en train de développer un marché en ligne. Tu peux publier la première itération avec des fonctions de base comme la liste des produits, la fonctionnalité du panier d'achat et la fonctionnalité de placement des commandes. Les itérations suivantes pourraient ajouter des fonctions plus avancées comme des listes de souhaits, des évaluations de produits, des modules pour les vendeurs, etc.
Plutôt que d'essayer de réussir chaque phase du premier coup, comme dans le modèle classique de la chute d'eau, le modèle itératif de la chute d'eau te permet d'affiner et de développer progressivement ton projet, ce qui crée un processus de développement plus souple et plus efficace. Cependant, cette flexibilité se fait au détriment de la complexité, et la gestion de tels projets peut nécessiter des compétences importantes en matière de planification et d'organisation.
Avantages et inconvénients du modèle de la cascade
Comme toute autre approche, le modèle de la chute d'eau a ses avantages et ses inconvénients potentiels, qui peuvent grandement influencer ta décision d'utiliser ou non ce modèle dans ton processus de développement de logiciels. Peser soigneusement ces avantages et ces inconvénients peut t'aider à déterminer le modèle de développement le plus approprié pour ton projet.
Évaluer les avantages et les inconvénients du modèle Waterfall
Comprendre les avantages et les inconvénients du modèle de la chute d'eau est une étape essentielle pour décider s'il s'agit de la bonne méthodologie pour tes besoins en matière de développement de logiciels. Les avantages du modèle de la chute d'eau sont les suivants :
Simple et facile à comprendre : La nature directe et linéaire du modèle de la chute d'eau le rend simple à comprendre et à utiliser. Il fournit des étapes claires et définies avec des objectifs précis, ce qui peut être particulièrement bénéfique pour les nouvelles équipes inexpérimentées ou les projets relativement simples.
Documentation : Chaque phase comporte des livrables spécifiques et un processus de révision, ce qui favorise intrinsèquement une documentation complète. Cette documentation peut ensuite faire partie des produits livrables, ce qui facilite la compréhension et la maintenance future du système.
Détection précoce des erreurs de conception : Comme ce modèle met l'accent sur la planification, il permet la détection précoce des défis potentiels, des problèmes ou des faiblesses dans la conception ou le cadre de ton logiciel.
Malgré ces avantages, le modèle de la chute d'eau présente également plusieurs inconvénients notables :
Difficulté des changements : Ce modèle ne tolère pas les changements. Une fois que tu as quitté une phase, il est difficile d'y revenir et d'y apporter des changements. Cette rigidité signifie que le modèle a du mal dans les scénarios où les exigences du projet ne sont pas claires ou sont appelées à évoluer au cours de la vie du projet.
Test retardé : Les tests sont retardés jusqu'à ce qu'une version fonctionnelle du logiciel soit disponible. Ce retour d'information retardé peut signifier que les problèmes sont découverts tardivement au cours du développement, et que leur résolution peut être coûteuse en temps et en argent.
Ne convient pas aux grands projets : Pour les projets complexes et à grande échelle où les exigences technologiques et commerciales peuvent changer au cours du développement, ce modèle peut devenir un obstacle en raison de son manque de flexibilité inhérent.
Une compréhension équilibrée de ces avantages et inconvénients éclairera ta décision d'employer le modèle de la chute d'eau.
Implications pratiques du modèle de distribution en cascade
L'application pratique du modèle de distribution en cascade va au-delà de la compréhension théorique. Examinons les implications pratiques de l'utilisation du modèle de la chute d'eau. Les avantages pratiques du modèle de la chute d'eau sont largement tirés de son approche systématique et de ses phases bien structurées. Ces points forts sont particulièrement mis en évidence dans les domaines suivants :
Gestion des délais : Avec des objectifs clairs pour chaque phase, il est facile de planifier, d'organiser et de gérer les tâches, ce qui constitue un excellent outil de gestion des délais.
Assurance qualité : Grâce à une responsabilisation et une documentation claires, les processus peuvent être vérifiés et validés à la fin de chaque phase. Il est ainsi impossible d'ignorer ou de négliger les problèmes, ce qui garantit des résultats de meilleure qualité.
Contrôle : Ce modèle s'intègre naturellement dans des plans de distribution et de déploiement contrôlés, ce qui permet de livrer le produit final en douceur.
Cependant, l'application pratique implique que tu dois également prévoir les inconvénients potentiels.
Risque de dépassement : Tout changement ou révision nécessaire après le passage à la phase suivante peut entraîner des dépassements de coûts et de délais, ce qui pourrait nuire non seulement au produit, mais aussi à tes relations avec les clients, les parties prenantes ou les utilisateurs.
Temps d'attente des clients : cette approche séquentielle peut signifier un délai important avant qu'un modèle fonctionnel du logiciel soit prêt, ce qui entraîne une attente plus longue pour les clients ou les utilisateurs avant qu'ils ne puissent voir des progrès tangibles.
Comprendre ces implications pratiques te permet de décider en toute connaissance de cause si le modèle de la chute d'eau convient à ton processus de développement de logiciels. Même s'il ne convient pas parfaitement à tous les projets, ce modèle peut apporter des avantages substantiels lorsqu'il est utilisé dans des circonstances appropriées.
Comparaison des méthodologies Agile et Waterfall
Lorsqu'il s'agit de méthodologies de développement de logiciels, deux des cadres les plus couramment utilisés sont les méthodologies Agile et Waterfall. Chacune possède ses propres mérites et limites et s'applique dans des circonstances différentes. Comprendre les principales différences entre ces deux méthodologies peut aider à choisir le cadre le plus approprié pour un projet de développement logiciel donné.
Différence entre les méthodologies Agile et Waterfall
Bien que les méthodologies Agile et Waterfall soient toutes deux destinées à rationaliser le processus de développement de logiciels, elles diffèrent considérablement dans leurs stratégies et leurs philosophies. Le modèle Waterfall est connu pour son approche linéaire où chaque phase du projet se déroule dans l'ordre. En revanche, la méthodologie Agile est itérative, ce qui signifie que le projet est divisé en petites unités gérables et que les membres de l'équipe travaillent sur ces unités de manière collaborative et simultanée. Le tableau suivant présente une comparaison complète des deux méthodologies :
Sujet
Agile
Chute d'eau
Conception
Conception adaptative et flexible sujette à des changements même à des stades avancés du projet.
Met l'accent sur une documentation abondante et exige une conception stable et définie dès le départ.
Structure du projet
Approche itérative et incrémentale qui met l'accent sur la participation et la collaboration des utilisateurs.
Approche séquentielle et linéaire avec des étapes clairement définies.
Codage
Le codage commence tôt et se poursuit tout au long du projet.
Le codage commence une fois que toutes les exigences et les conceptions sont terminées.
Engagement des clients
Implication continue des clients avec des commentaires et des changements réguliers.
Le client est surtout impliqué au début et à la fin du projet.
Test
En même temps que le développement ; tests itératifs tout au long du projet.
Programmés vers la fin du projet.
Alors que le modèle Agile encourage la flexibilité et la collaboration avec le client, le modèle Waterfall s'efforce d'assurer des progrès et des transitions fluides, attendus et bien documentés. Le modèle Waterfall est loué pour sa simplicité et sa prévisibilité, minimisant les incertitudes et fournissant une structure claire, mais il a tendance à avoir des difficultés lorsqu'il s'agit de faire face à l'ambiguïté et aux changements dans les exigences du projet. En revanche, l'adaptabilité du modèle Agile et son approche centrée sur l'utilisateur le rendent populaire pour les projets dont les exigences évoluent ou qui font appel à des technologies émergentes.
Choisir entre le modèle Agile et le modèle Waterfall en informatique
Lorsque tu dois choisir entre les modèles Agile et Waterfall, il est essentiel de prendre en compte les exigences du projet, la composition de l'équipe et les attentes des parties prenantes. Voici des facteurs clés qui peuvent guider ton choix :
La taille et la complexité du projet : Pour les petits projets avec des objectifs clairs et constants, le modèle Waterfall pourrait être plus adapté en raison de sa simplicité et de sa discipline. Le modèle Agile, en revanche, est idéal pour les projets vastes et complexes qui évoluent fréquemment, car il permet des ajustements et des innovations à n'importe quelle étape du développement.
Participation des clients : Si le projet nécessite une participation considérable des clients et des modifications fréquentes, Agile permet une certaine flexibilité et s'adapte plus efficacement à ces changements. À l'inverse, pour les projets où la participation du client est minime ou les exigences sont bien définies et peu susceptibles de changer, Waterfall peut être plus souhaitable.
Calendrier et budget : Si tu as un calendrier et un budget serrés, le modèle Waterfall permet de minimiser les incertitudes et de maintenir le projet dans les temps, car chaque étape est planifiée à l'avance. Le modèle Agile peut mener à l'achèvement du projet plus rapidement en raison de la nature itérative et des processus simultanés, mais il nécessite une gestion plus prudente des ressources.
Que tu optes pour Agile ou Waterfall, tu dois te rappeler que ce ne sont que des outils pour t'aider à atteindre tes objectifs de développement de logiciels. Aucune méthodologie ne remplacera une équipe compétente, une communication efficace et des objectifs bien définis. Cela vaut la peine de se familiariser avec les deux méthodologies afin de pouvoir sélectionner intelligemment le modèle adapté à ton projet et de maximiser tes chances de réussite.
Application du modèle de la chute d'eau aux techniques de résolution de problèmes
Dans le contexte des techniques de résolution de problèmes, l'application du modèle de la chute d'eau peut être très avantageuse. Son approche systématique et séquentielle offre une manière structurée d'aborder les tâches complexes de résolution de problèmes, en veillant à ce que chaque aspect du problème soit pris en compte et traité de manière ordonnée et complète.
Résolution de problèmes avec le modèle de la chute d'eau
Lorsque tu résous des problèmes en utilisant l'approche du modèle de la chute d'eau, chaque étape du modèle peut être utilisée pour aborder un aspect différent du problème. Voici comment tu peux le décomposer :
Collecte des besoins : La première étape de la résolution des problèmes consiste à comprendre le problème en profondeur. Cela comprend l'identification de la portée du problème, des contraintes et des exigences. Une définition claire et précise du problème constitue la base d'une résolution efficace du problème.
Conception du système : Vient ensuite la phase de conception du problème, au cours de laquelle tu exposes une stratégie ou un plan pour résoudre le problème. Il peut s'agir de formuler des algorithmes, d'identifier des ressources ou de planifier des étapes d'action.
Mise en œuvre : Dans cette phase, tu exécutes le plan élaboré dans la phase de conception. Il peut s'agir d'expérimenter, de construire des modèles ou d'effectuer des simulations.
Vérification : Après avoir mis en œuvre les solutions, tu passes à la phase de vérification, en testant les solutions proposées pour t'assurer qu'elles résolvent le problème comme prévu. Cette étape consiste à tester, examiner et valider les résultats.
Maintenance : Dans la phase finale, tu surveilles et affines la solution si nécessaire. Cette étape peut consister à réévaluer le problème, à s'assurer que la solution est durable et à suivre les changements qui pourraient affecter la solution à l'avenir.
En suivant ces étapes, tu peux appliquer le modèle de la chute d'eau pour obtenir une feuille de route claire qui te permettra de naviguer d'un problème à sa solution, en t'assurant que tu abordes chaque aspect du problème et que tu appliques une approche approfondie et cohérente pour le résoudre.
Le modèle de la chute d'eau dans la résolution de problèmes est une approche séquentielle où chaque étape du processus de résolution de problèmes est minutieusement menée avant de passer à la suivante, ce qui garantit une progression systématique vers la solution.
Les gens préfèrent généralement utiliser l'approche du modèle de la chute d'eau dans la résolution de problèmes lorsque le problème est bien défini, que les exigences sont claires et qu'il est peu probable que des changements se produisent au cours du processus de résolution de problèmes.
Exemples d'études de cas du modèle de la chute d'eau en action
Pour mieux comprendre et apprécier l'utilité du modèle de la chute d'eau, examinons quelques exemples d'études de cas où le modèle de la chute d'eau est utilisé efficacement pour résoudre des problèmes dans différents contextes.
Prenons le cas d'une petite entreprise de développement de logiciels qui souhaite créer une solution logicielle personnalisée pour une entreprise locale. Les exigences sont clairement définies, les technologies à utiliser sont bien établies et il y a peu de possibilités de changement une fois que le développement a commencé. Dans un tel scénario, l'utilisation du modèle de la chute d'eau peut mener à l'achèvement du projet, car il permet un développement ordonné et discipliné où chaque étape est clairement définie, correctement documentée et passe logiquement de l'une à l'autre. Le processus de résolution des problèmes comprendrait une collecte approfondie des besoins, une phase de conception méticuleuse, une mise en œuvre strictement conforme à la conception, une vérification rigoureuse et une maintenance robuste.
Dans un contexte éducatif, le modèle de la chute d'eau pourrait être utilisé pour structurer un projet de recherche de longue durée. Au départ, les exigences telles que le sujet, la portée et les objectifs sont clairement définies. La phase de conception consiste à élaborer un plan de recherche, y compris les méthodes de collecte des données, les ressources nécessaires et un calendrier pour le projet. Ensuite, la phase de mise en œuvre comprend la réalisation de la recherche, la collecte et l'analyse des données, tandis que l'étape de vérification permet de s'assurer que les résultats de la recherche répondent de manière adéquate aux objectifs initiaux de la recherche. Enfin, la phase de maintenance comprend la présentation des résultats de la recherche, la prise en compte des commentaires et les révisions nécessaires.
Ces exemples illustrent des applications réelles du modèle de la cascade, soulignant son utilité en tant qu'outil systématique et structuré de résolution de problèmes, particulièrement utile dans les contextes où les exigences sont claires et les changements au cours du processus sont minimes. Cependant, comme nous l'avons déjà souligné, il est essentiel de reconnaître que le modèle de la chute d'eau n'est pas un outil universel, mais que son efficacité et son applicabilité dépendent en grande partie de la nature et des exigences spécifiques du problème à résoudre.
Modèle de la chute d'eau - Principaux enseignements
Le modèle de la chute d'eau est un modèle de cycle de vie linéaire-séquentiel employé dans le développement de logiciels, où la progression se fait vers le bas à travers des étapes telles que les exigences, la conception, la mise en œuvre, la vérification et la maintenance.
Ce modèle, présenté par Winston Royce en 1970, est idéal pour les petits projets avec des exigences claires en raison de son approche disciplinée et méthodique.
Les étapes systématiques du modèle en cascade comprennent l'analyse des besoins, la conception du système, la mise en œuvre, le test du système, le déploiement et la maintenance.
Le modèle itératif en cascade permet un développement et un perfectionnement itératifs par étapes, ce qui permet d'ajouter davantage de fonctionnalités à des niveaux de détail croissants à chaque cycle répété.
Le modèle en cascade est connu pour sa structure simple et permet de détecter rapidement les erreurs de conception, mais il ne pardonne pas les changements effectués après avoir quitté une phase du projet.
Apprends plus vite avec les 15 fiches sur Modèle en cascade
Inscris-toi gratuitement pour accéder à toutes nos fiches.
Questions fréquemment posées en Modèle en cascade
Qu'est-ce que le modèle en cascade?
Le modèle en cascade est une méthodologie séquentielle en génie logiciel, où chaque phase doit être terminée avant de passer à la suivante.
Quelles sont les phases du modèle en cascade?
Les phases incluent l'analyse des exigences, la conception, l'implémentation, les tests, le déploiement et la maintenance.
Quels sont les avantages du modèle en cascade?
Ses avantages comprennent une structure claire, une documentation détaillée et une planification facile des étapes du projet.
Quels sont les inconvénients du modèle en cascade?
Les inconvénients incluent un manque de flexibilité, des difficultés à gérer les changements et des risques élevés si les exigences ne sont pas bien définies dès le début.
How we ensure our content is accurate and trustworthy?
At StudySmarter, we have created a learning platform that serves millions of students. Meet
the people who work hard to deliver fact based content as well as making sure it is verified.
Content Creation Process:
Lily Hulatt
Digital Content Specialist
Lily Hulatt is a Digital Content Specialist with over three years of experience in content strategy and curriculum design. She gained her PhD in English Literature from Durham University in 2022, taught in Durham University’s English Studies Department, and has contributed to a number of publications. Lily specialises in English Literature, English Language, History, and Philosophy.
Gabriel Freitas is an AI Engineer with a solid experience in software development, machine learning algorithms, and generative AI, including large language models’ (LLMs) applications. Graduated in Electrical Engineering at the University of São Paulo, he is currently pursuing an MSc in Computer Engineering at the University of Campinas, specializing in machine learning topics. Gabriel has a strong background in software engineering and has worked on projects involving computer vision, embedded AI, and LLM applications.