Object oriented computing and distributed system

Catalogue des cours de Télécom SudParis

Code

IGSE CSC 7203

Niveau

MSc

Graduate

PostGraduate

Semestre

Spring

Domaine

Informatique

Programme

Master of Science

Langue

Anglais/English

Crédits ECTS

6

Heures programmées

60

Charge de travail

120

Coordonnateur(s)

Département

  • Informatique

Equipe pédagogique

Organisation

Cours/TD/TP/projet/examen : 30/0/30

Acquis d'apprentissage

This course is an introduction to advanced computing concepts encompassing the object-oriented paradigm, design patterns, data management and virtualization.

At the end of this course, the students will be able to :
• Design applications following the UML methodology;
• Understand design patterns ;
• Implement object-oriented applications using the Java language;
• Understand the principles of data management;
• Understand virtualization and the concepts underlying cloud computing.

Prérequis

Unix user commands, Algorithmics (CSC 7001)

Mots-clés

design, class, object, inheritance, Java, multi-core, cluster, grid, MPI, OpenMP

Contenu

The course is organised in sequences involving the following items:
• Lectures: Presentation of the concepts
• Labs: Application of the concepts learned

The course is divided into three main parts:

1) Object-oriented computing

• Presentation of the fundamental concepts of object orientation (OO);
• Introduction to the UML notation for modeling;
• Application of these concepts using the Java programming language;
• Introduction to the notion of virtual machine through the Java virtual machine (JVM)
• Introduction to design patterns; Comparison of different OO programming languages;
• Reuse and generics.



2) Principles of data management
• Introduction to data management and relational database design
• Presentation of the concepts of Entity-Relationship Diagram (ERD), comparison with UML
• Transforming ERDs into relational models
• Discovery and manipulation of the Structured Query Language (SQL)

3) From virtualization to cloud computing
• Introduction to virtualization technology: virtualizing resources, operating systems, networks of machines, software, data centers
• Definition of cloud computing
• Overview of some solutions for cloud computing from OVH, Amazon, Microsoft, Google and opensource solutions like OpenStack

Evaluation

Continuous control and realisation of a project.

The continuous control grade results from the presence and participation to the lectures, the elaboration of a document during the design phase of the project and also from graded labs.

A computing micro-project will be given at the beginning of the course. Some lab sessions will be dedicated to the project and it will be finished as homework. A final grade will be given to the project with separate evaluations of the final report, the source code and an oral presentation including a demonstration.

The project can be done in groups of at most 2 students, but the grading will be individual.