Logo ÉTS
Session
Cours
Responsable(s) Ali Ouni

Se connecter
 

Sauvegarde réussie
Echec de sauvegarde
Avertissement
École de technologie supérieure

Responsable(s) de cours : Ali Ouni


PLAN DE COURS

Hiver 2024
LOG530 : Réingénierie du logiciel (3 crédits)





Préalables
Programme(s) : 7065,7070,7365,7610
             
  Profils(s) : Tous profils  
             
    LOG210    
             
Unités d'agrément
Total d'unités d'agrément : 58,8 25,0 % 75,0 %




Qualités de l'ingénieur

Qn
Qualité visée dans ce cours  
Qn
  Qualité visée dans un autre cours  
  Indicateur enseigné
  Indicateur évalué
  Indicateur enseigné et évalué



Descriptif du cours
Ce cours vise l’acquisition des principes de la réingénierie du logiciel. Différentes techniques à différents niveaux d’un logiciel seront étudiées de manière théorique ou pratique.

Au terme de ce cours, l'étudiante ou l'étudiant sera en mesure de proposer des solutions concrètes pour la réingénierie dans le milieu professionnel. Nous y verrons les concepts suivants :
• maintenance du logiciel;
• exigences des systèmes modernes et les techniques de transformations des systèmes patrimoniaux;
• définition des systèmes patrimoniaux;
• stratégies de transformation des systèmes patrimoniaux;
• approches centrées sur les règles d’affaires;
• réusinage de code;
• patrons en réingénierie;
• réingénierie de bases de données;
• rétro-ingénierie et ses outils.



Objectifs du cours

À la fin de ce cours, l’étudiant(e) sera en mesure de:

  • Proposer et appliquer des solutions concrètes pour la réingénierie d’un logiciel existant,
  • Effectuer une analyse de qualité de logiciel pour identifier des opportunités de réusinage,
  • Appliquer des techniques de réusinage et de rétro-ingénierie,
  • Comprendre et distinguer les bonnes et mauvaises pratiques d’implémentation/conception.



Stratégies pédagogiques
  • Un cours magistral de trois (3) heures par semaine portant sur les principes et les pratiques de la réingénierie logicielle. Ces principes seront accompagnés d’exemples concrets, de quiz et d’exercices pratiques.
  • Deux (2) heures de laboratoire par semaine qui permettront à l’étudiant d’appliquer les concepts théoriques vus en classe et d’utiliser les outils de réingénierie.



Utilisation d’appareils électroniques

Utilisation de votre ordinateur personnel pour les travaux pratiques et les présentations.

Vous devez avoir un ordinateur portable (laptop) pour effectuer les examens en classe. Si vous n'avez pas d'ordinateur portable vous ne pouvez pas suivre ce cours.

Il est interdit de capter le cours ou des portions du cours (enregistrement vidéo, enregistrement audio, photographie) pendant les séances du cours ou des laboratoires à moins d’avoir obtenu au préalable la permission de l'enseignant.




Horaire
Groupe Jour Heure Activité
01 Mercredi 13:30 - 17:00 Activité de cours
Jeudi 13:30 - 15:30 Laboratoire (Groupe A)
Jeudi 15:30 - 17:30 Laboratoire (Groupe B)



Coordonnées de l’enseignant
Groupe Nom Activité Courriel Local Disponibilité
01 Ali Ouni Activité de cours Ali.Ouni@etsmtl.ca A-4483
01 Narjes Bessghaier Laboratoire (Groupe B) narjes.bessghaier.1@ens.etsmtl.ca



Cours

Contenu[1]

  • Introduction (3 heures)
  • Maintenance, évolution et réingénierie de logiciels (3 heures)
  • Les systèmes légataires (1.5 heures)
  • Réusinage (Refactoring) de logiciels (4.5 heures)
  • Métriques de qualité pour la réingénierie de logiciels (3 heures)
  • Patrons de réingénierie (6 heures)
  • Compréhension de logiciel (1.5 heures)
  • Retro-ingénierie: visualisation du logiciel (3 heures)
  • Les changements et analyse de l’impact (3 heures)
  • Architecture et reconstruction d’architecture (3 heures)
  • Études empiriques pour la réingénierie (3 heures)
  • Présentation et discussion des projets (3 heures)
  • Révision (1 heure)

[1]   La matière ne sera pas nécessairement présentée dans cet ordre. Tous les sujets proposés seront traités, mais la durée individuelle d’enseignement est approximative et peut varier pour chaque sujet.




Laboratoires et travaux pratiques

Il y a 5 travaux prévus pour les laboratoires et un projet: 

Laboratoires :

  • Laboratoire #1 : Duplication de code
  • Laboratoire #2 : Assistants de refactoring
  • Laboratoire #3 : Exploration des répértoires de code
  • Laboratoire #4 : Analyse dynamique et tests

Projet :

Le but du projet est d'explorer les différentes techniques de réingénierie et analyser leurs impact sur la qualité et l'évolution d'un systéme existant. Le projet sera réalisé en équipes de 3 étudiants.

Un membre de l'équipe qui ne participe pas avec une contribution significative avec ses co-équipiers dans un travail reçoit une note de "0" pour le travail.




Utilisation d'outils d'ingénierie

L’étudiant se familiarise avec des outils et environnements de développement supportant la rétro-ingénierie, la détection des défauts de conception/implémentation, la visualisation logicielle, et la transformation et le réusinage de code, etc.




Évaluation
Examen intra : 20%
Laboratoires : 25%
Projet de réingénierie : 20%
Examen final : 35%

L'étudiant(e) doit avoir une moyenne d'au moins 50% aux examens à évaluation individuelle (Intra et Final) afin de réussir le cours.  Cette condition est nécessaire mais non suffisante.




Double seuil
Note minimale : 50



Dates des examens intra
Groupe(s) Date
1 28 février 2024



Date de l'examen final
Votre examen final aura lieu pendant la période des examens finaux, veuillez consulter l'horaire à l'adresse suivante : http://etsmtl.ca/Etudiants-actuels/Baccalaureat/Examens-finaux


Politique de retard des travaux
Tout travail (devoir pratique, rapport de laboratoire, rapport de projet, etc.) remis en retard sans motif valable, c’est-à-dire autre que ceux mentionnés dans le Règlement des études (1er cycle, article 7.2.7 b / cycles supérieurs, article 6.5.4 b) se verra attribuer la note zéro, à moins que d’autres dispositions ne soient communiquées par écrit par l’enseignant dans les consignes de chaque travail à remettre ou dans le plan de cours pour l’ensemble des travaux.

Dispositions additionnelles

Les dates de remises doivent impérativement être respectées. Une pénalité de 20 % par jour de retard sera appliquée pour tous les travaux remis après la date limite selon le tableau suivant :

Retard Pénalité
0h01 et 24h00 - 25%
24h01 et 48h00 - 50%
> 48h -100%



Absence à un examen
Dans les cinq (5) jours ouvrables suivants, la tenue de son examen, l’étudiant devra justifier son absence d’un examen durant le trimestre auprès de la coordonnatrice – Affaires départementales qui en référera au directeur du département ou du SEG. Pour un examen final, l’étudiant devra justifier son absence auprès du Bureau du registraire. Dans tous les cas, l’étudiant doit effectuer sa demande en complétant le formulaire prévu à cet effet qui se trouve dans son portail Mon ÉTS/Formulaires. Toute absence non justifiée par un motif majeur (maladie certifiée par un billet de médecin, décès d’un parent immédiat, Activité compétitive d’un étudiant appartenant à un club scientifique ou un club sportif d’élite de l’ÉTS ou au programme « Alliance sport étude » ou autre) à un examen entraînera l’attribution de la note zéro (0).



Infractions de nature académique
À l’ÉTS, le respect de la propriété intellectuelle est une valeur essentielle et les étudiants sont invités à consulter la page "Citer, pas plagier !" (https://www.etsmtl.ca/Etudes/citer-pas-plagier). Les clauses du règlement sur les infractions de nature académique de l’ÉTS (« Règlement ») s’appliquent dans ce cours ainsi que dans tous les cours du département. Les étudiants doivent consulter le règlement sur les infractions de nature académique (https://www.etsmtl.ca/docs/ETS/Gouvernance/Secretariat-general/Cadre-reglementaire/Documents/Infractions-nature-academique) pour identifier les actes qui constituent des infractions de nature académique au sens du Règlement ainsi que prendre connaissance des sanctions prévues à cet effet.

Systèmes d’intelligence artificielle générative (SIAG)
L’utilisation des systèmes d’intelligence artificielle générative (SIAG) dans les activités d’évaluation constitue une infraction de nature académique au sens du Règlement sur les infractions de nature académique, sauf si elle est explicitement autorisée par l’enseignant(e) du cours.

Dispositions additionnelles

L'utilisation des grand modéles de languages (LLM) telque ChaGPT est permise, à condition que l'étudiant:

  1. indique le prompt utilisé + la réponse du LLM dans le rapport du laboratoire ou projet ou autre activité, ainsi que dans le fichier Google Form qui est disponible sur Moodle
  2. indique la tâche/excercice où il/elle a utilisé le LLM (exemple: Exercice 3 du TP1, refactoring de la classe xyz.java dans l’excercice 2)

L'absence de déclaration de l’utilisation d’un LLM peut représenter une infraction de nature académique.




Documentation obligatoire

Disponibles gratuitement pendant cette période d'enseignement à distance (sur Moodle):

S. Demeyer, S. Ducasse, O. Nierstrasz, Object-oriented reengineering patterns. Amsterdam, Boston: Morgan Kaufmann Publishers, 2003.




Ouvrages de références

Fowler, Martin, Refactoring: improving the design of existing code. Boston: Addison-Wesley, 2eme édition, 2019.

Feathers, Michael. Working effectively with legacy code. Prentice Hall Professional, 2004.

Steven C. McConnell, Code complete, 2e édition. Redmond, Wash., Microsoft Press.

Robert C. Martin, Clean code: a handbook of agile software craftsmanship. Pearson Education, 2009.

April, Alain et Abran, Alain, Améliorer la maintenance du logiciel. Loze-Dion, 337 pp., 2006.

Mens, Tom, & Demeyer, Serge, Software Evolution. Springer Berlin Heidelberg, XVIII, 347 pp., 2008. 




Adresse internet du site de cours et autres liens utiles

Moodle: https://ena.etsmtl.ca




Autres informations

Le matériel du cours (Powerpoint de présentation, laboratoires, excerices, projets, etc.) sont pour votre propre usage dans le cadre du cours LOG530, et il est strictement interdit de les partager sur internet.