La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

Architecture d’application L’apprentissage automatique appliqué à l’architecture 3-tiers.

Présentations similaires


Présentation au sujet: "Architecture d’application L’apprentissage automatique appliqué à l’architecture 3-tiers."— Transcription de la présentation:

1

2 Architecture d’application L’apprentissage automatique appliqué à l’architecture 3-tiers

3 Plan de présentation  Introduction  L’architecture 3-tiers  L’apprentissage automatique  L’algorithme du perceptron  Application

4 Introduction  L’objectif de ce cours est de vous montrer l’architecture 3-tiers.  Comme vous êtes des passionnés, nous allons utiliser un algorithme d’IA pour appliquer à l’architecture 3- tiers.(Algorithme du perceptron).

5 Le modèle 3-tiers  Son nom provient de l'anglais tier signifiant étage ou niveau. Il s'agit d'un modèle logique d'architecture applicative qui vise à modéliser une application comme un empilement de trois couches logicielles (étages, niveaux, tiers ou strates) dont le rôle est clairement défini :anglaisapplicationlogicielles  la présentation des données(GUI, Graphic User Interface ) : correspondant à l'affichage, la restitution sur le poste de travail, le dialogue avec l'utilisateur ;  le traitement métier des données ( La couche métier ( BLL, Business Logic Layer)): correspondant à la mise en œuvre de l'ensemble des règles de gestion et de la logique applicative ;  et enfin l' accès aux données persistantes ( La couche d’accès aux données (DAL, Data Access Layer ) ) : correspondant aux données qui sont destinées à être conservées sur la durée, voire de manière définitive.persistantes BD Utilisateur Couche GUI Couche Métier(BLL) Couche Accès données (DAL)

6 La couche présentation(GUI) BD Utilisateur Couche GUI Couche Métier(BLL) Couche Accès données (DAL)

7 La couche présentation(GUI)  Elle correspond à la partie de l'application visible et interactive avec les utilisateurs. On parle d'interface homme machine.applicationinterface homme machine  La couche présentation relaie les requêtes de l'utilisateur à destination de la couche métier, et en retour lui présente les informations renvoyées par les traitements de cette couche. Il s'agit donc ici d'un assemblage de services métiers et applicatifs offerts par la couche inférieure.  La couche présentation n'effectue aucun traitement, elle se contente d'afficher les résultats des traitements effectués.

8 Couche métier(BLL) BD Utilisateur Couche GUI Couche Métier(BLL) Couche Accès données (DAL)

9 Couche métier(BLL)  Elle correspond à la partie fonctionnelle de l'application, c’est elle qui implémente la « logique », et qui décrit les opérations que l'application opère sur les données en fonction des requêtes des utilisateurs, effectuées au travers de la couche présentation.application  Les différentes règles de gestion et de contrôle du système sont mises en œuvre dans cette couche.  La couche métier offre des services applicatifs et métier à la couche présentation. Pour fournir ces services, elle s'appuie, le cas échéant, sur les données du système, accessibles au travers des services de la couche inférieure. En retour, elle renvoie à la couche présentation les résultats qu'elle a calculés.

10 Couche accès aux données(DLL) BD Utilisateur Couche GUI Couche Métier(BLL) Couche Accès données (DAL)

11 Couche accès aux données(DLL)  Cette couche est responsable de la gestion et de l'accès aux données du système. Ces données peuvent être propres au système, ou gérées par un autre système. La couche métier n'a pas à s'adapter à ces deux cas, ils sont transparents pour elle, et elle accède aux données de manière uniforme.  Cette couche assure la gestion des données et garantit leur intégrité. Dans le cas typique d'une base de données, c'est le modèle qui la gère. Cette couche offre généralement des méthodes pour mettre à jour ces données (insertion, suppression, changement de valeur). Il offre aussi des méthodes pour récupérer ces données.

12 Communication entre les couches  Dans cette approche, les couches communiquent entre elles au travers d'un « modèle d'échange », et chacune d'entre elles propose un ensemble de services rendus.  Les services d'une couche sont mis à disposition de la couche supérieure. On s'interdit par conséquent qu'une couche invoque les services d'une couche plus basse que la couche immédiatement inférieure ou plus haute que la couche immédiatement supérieure (chaque couche ne communique qu'avec ses voisins immédiats). BD Utilisateur Couche GUI Couche Métier(BLL) Couche Accès données (DAL)

13 En résumé  En résumé, lorsqu'un client envoie une requête à l'application : 1. la requête envoyée depuis la couche présentation est analysée par la couche métier (par exemple un clic de souris pour lancer un traitement de données), 2. la couche métier fait le traitement et demande à la couche d’accès aux données de faire les modifications voulues dans la base de données, 3. La couche d’accès aux données retourne la mise à jour à la couche métier, qui à son tour, la remettra à la couche présentation.

14 Avantages  Un avantage apporté par ce modèle est la clarté de l'architecture qu'il impose. Cela simplifie la tâche du développeur qui tenterait d'effectuer une maintenance ou une amélioration sur le projet. En effet, la modification des traitements ne change en rien la vue.  Par exemple on peut passer d'une base de données de type SQL à XML en changeant simplement les traitements d'interaction avec la base, et les vues ne s'en trouvent pas affectées.SQLXML

15 Exemple  Aller chercher les documents d’exercice sur le site Internet du cours.  L’interface graphique ( GUI, Graphic User Interface) :  Demander le nom d’un fichier.  Ajouter un bouton pour activer la lecture du fichier  Ajouter un RichTextBox pour afficher les résultats  La couche métier ( BLL, Business Logic Layer)  Vide pour le moment  La couche d’accès aux données ( DAL, Data Access Layer)  Nous allons remplir une structure de données pour les données et une pour les résultats.  Résultat:  Afficher les données dans le RichTextBox.

16 Architecture d’application L’apprentissage automatique appliqué à l’architecture 3-tiersSuite…

17

18

19 Apprentissage automatique: Les réseaux de neurones  Attention aux coeurs sensibles s’abstenir!!  La poubelle se trouve près de la porte…

20 Mais qu’est-ce que l’IA et où on va dans ce cours?  L’intelligence artificielle tente de reproduire le comportement humain à l’aide d’un ordinateur.  Mais qu’est-ce qu’on cherche à reproduire:  La représentation des connaissances  L’apprentissage (voir le film à 40 minutes)  Le raisonnement(inférence)  L’intelligence émotionnelle  La personnalité  Etc.

21 Comparaison avec l’humain  Le cerveau utilise un réseau très complexe ayant un grand nombre de cellules de base interconnectées. Il y a ∼ 100 milliards de neurones et10 15 connexions.  Aujourd’hui, nous essaierons de stimuler un neurone pour le faire apprendre.

22 Comment apprendre? Dans la vrai vie  L’apprentissage se fait grâce à l’interaction entre les données et la conception de l’apprenant.  L’apprennant essait de trouver un modèle(pattern) à travers les données pour en déduire une conclusion.  Si l’apprenant fait une erreur, il ajuste sa conception en fonction du résultat.

23 Apprentissage automatique  Certain scientifiques affirme que le hasard n’existe pas et que tout phénomène peut être calculé à l’avance si on a suffisamment de données.

24 Apprentissage automatique  Toute question peut être reformulée sous la forme d’une question booléenne.  L’objectif sera de conditionner un neurone pour détermine les règles qui régissent une réponse à une question booléenne.

25 Le perceptron  Dans ce cours, nous allons utiliser un classificateur de type perceptron.  Le perceptron a été inventé en 1957 par Frank Rosenblatt au Cornell Aeronautical Laboratory.1957Frank RosenblattCornell Aeronautical Laboratory  L’objectif de l’algorithme est de construire une “bonne” fonction h(x) à partir de l’observation d’un échantillon d’exemples S. Idéalement, nous aurions h(x) =y pour tout exemple (x i ; y)non observé par l’algorithme. i.e., h(x) est une “bonne” fonction ssi elle prédit bien la valeur de sortie des exemples à venir.

26 Apprentissage automatique sur un échantillon d’apprentissage  Un algorithme d’apprentissage est un algorithme qui a pour fonction d’apprendre à répondre à une question à partir d’un ensemble S de données contenant un nombre fini m d’ exemples de la tâche à apprendre.  Cet ensemble S se nomme l’ échantillon d’apprentissage (“training set”)  Chaque exemple est constitué d’un “objet” d’entrée x i et d’une valeur de sortie y

27 L’idée  Modéliser un ensemble de données dans un plan cartésien.  Essayer de tracer une droite qui séparera correctement les éléments.  Voir le document Excel  La question est de savoir si une personne est riche?

28 Limite du perceptronperceptron Le perceptron est incapable de distinguer les patterns non séparables linéairement input P0101 input Q1001 ET0001 XOR1100

29 Comment s’opère la magie maintenant? https://www.youtube.com/watch?v=SGZ6BttHMPw&index=1&list=PL6Xpj9I5qXYEcOhn7TqghAJ6NAPrNmUBH

30 Algorithme d’apprentissage

31

32 Descente en gradien http://www.iro.umontreal.ca/~bengioy/ift6266/H12/html/gradient_fr.html

33 Algorithme d’apprentissage Principales étapes : 1. Initialiser aléatoirement les poids synaptiques 2. Faire passer les observations unes à unes  Calculer l’erreur de prédiction pour l’observation  Mettre à jour les poids synaptiques si nécessaire 3. Jusqu’à convergence du processus

34 Algorithme d’apprentissage

35 3- Descente en gradien 1- Valeur des poids 2- Équation http://www.iro.umontreal.ca/~bengioy/ift6266/H12/html/gradient_fr.html

36 Algorithme d’apprentissage Ancienne frontière :

37

38

39 Algorithme d’apprentissage Entrée :un échantillon S Pour i = 0... n initialiser aléatoirement les poids w i Faire Pour chacun des exemples dans S Prendre un exemple(x, y vrai ) dans S Calculer la sortie y estimé pour l'entrée x Si y vrai != y estimé Alors Pour i= 0... n w i ←w i + ConstanteApprentissage × (y vrai −y estimé )× x i Fin Pour Fin Répéter Jusqu’à obtention de la convergence Sortie :Un perceptron P défini par(w 0, w 1,..., w n )

40 La tolérance à l’erreur Il peut être avantageux d’être tolérant à l’erreur plutôt que de ne pas trouver de solution… à vous de trouver la bonne méthode de convergence. Selon vous quels sont les possibilités de critère de convergence?

41 Conclusion  L’architecture 3-tiers est un modèle étoffé qui permet aisément la modification et l’extension d’une application.  Le but de l’apprentissage automatique est de définir un vecteur de valeur qui permet de définir si oui ou non un vecteur d’entré appartient à un groupe ou non. https://www.youtube.com/watch?v=GROvIr2GGcc&list=PL6Xpj9I5qXYFD_rc1tttugXLfE2TcKyiO

42 Période de questions  Vous avez des questions?


Télécharger ppt "Architecture d’application L’apprentissage automatique appliqué à l’architecture 3-tiers."

Présentations similaires


Annonces Google