CLUSTERING DE FLUX DE DONNÉES



Documents pareils
Introduction aux algorithmes MapReduce. Mathieu Dumoulin (GRAAL), 14 Février 2014

Apprentissage actif pour le clustering semi-supervisé

Application de K-means à la définition du nombre de VM optimal dans un cloud

Fouille de données massives avec Hadoop

TRS: Sélection des sous-graphes représentants par l intermédiaire des attributs topologiques et K-medoïdes

Cartographie des solutions BigData

Big Data et Graphes : Quelques pistes de recherche

Résumé hybride de flux de données par échantillonnage et classification automatique

Big Data et Graphes : Quelques pistes de recherche

Programmation parallèle et distribuée

Parallélisation de l algorithme des k-médoïdes. Application au clustering de courbes.

Labs Hadoop Février 2013

BIG Data et R: opportunités et perspectives

Implémentation parallèle de certains algorithmes de fouille de données avec le framework MapReduce

Change the game with smart innovation

Introduction à MapReduce/Hadoop et Spark

L écosystème Hadoop Nicolas Thiébaud Tuesday, July 2, 13

Panorama des solutions analytiques existantes

Les participants repartiront de cette formation en ayant une vision claire de la stratégie et de l éventuelle mise en œuvre d un Big Data.

Techniques du Data Mining pour la prédiction de faillite des entreprises et la gestion du risque de crédit

Développements algorithmiques au LIAMA et àamap en vue de l'analyse d'une scène forestière


Echantillonnage Non uniforme

Groupe de Discussion Big Data Aperçu des technologies et applications. Stéphane MOUTON

Acquisition des données - Big Data. Dario VEGA Senior Sales Consultant


API04 Contribution. Apache Hadoop: Présentation et application dans le domaine des Data Warehouses. Introduction. Architecture

Les technologies du Big Data

20 ans du Master SIAD de Toulouse - BigData par l exemple - Julien DULOUT - 22 mars ans du SIAD -"Big Data par l'exemple" -Julien DULOUT

M2 GL UE DOC «In memory analytics»

Programmation parallèle et distribuée

LES ENJEUX DU BIG DATA

Atelier CluCo : Clustering et Co-clustering. Organisateurs : Vincent Lemaire (Orange Labs), Pascal Cuxac (CNRS-inist), Jean-Charles Lamirel (Loria)

Analytics & Big Data. Focus techniques & nouvelles perspectives pour les actuaires. Université d Eté de l Institut des Actuaires Mardi 8 juillet 2014

Agrégation des portefeuilles de contrats d assurance vie

Optimisation de la compression fractale D images basée sur les réseaux de neurones

NoSQL. Introduction 1/30. I NoSQL : Not Only SQL, ce n est pas du relationnel, et le contexte. I table d associations - Map - de couples (clef,valeur)

La classification automatique de données quantitatives

Formation continue. Ensae-Ensai Formation Continue (Cepe)

Une méthode de classification supervisée sans paramètre pour l apprentissage sur les grandes bases de données

Vers une Optimisation de l Algorithme AntTreeStoch

Contrôle stochastique d allocation de ressources dans le «cloud computing»

Mesure agnostique de la qualité des images.

LES APPROCHES CONCRÈTES POUR LE DÉPLOIEMENT D INFRASTRUCTURES CLOUD AVEC HDS & VMWARE

DEMARRER UN PROJET BIGDATA EN QUELQUES MINUTES GRACE AU CLOUD

Détection de têtes dans un nuage de points 3D à l aide d un modèle de mélange sphérique

Fouillez facilement dans votre système Big Data. Olivier TAVARD

Cassandra et Spark pour gérer la musique On-line

Big Data, un nouveau paradigme et de nouveaux challenges

Nouvelles propositions pour la résolution exacte du sac à dos multi-objectif unidimensionnel en variables binaires

Ricco Rakotomalala R.R. Université Lyon 2

Techniques avancées de traitement numérique pour la réduction d interférences dans les réseaux de capteurs corporels

Organiser vos données - Big Data. Patrick Millart Senior Sales Consultant

BIG DATA en Sciences et Industries de l Environnement

Notes de cours Practical BigData

Plan 1/9/2013. Génération et exploitation de données. CEP et applications. Flux de données et notifications. Traitement des flux Implémentation

Contrôle par commande prédictive d un procédé de cuisson sous infrarouge de peintures en poudre.

Certificat Big Data - Master MAthématiques

Clustering par optimisation de la modularité pour trajectoires d objets mobiles

Objectif et contexte business : piliers du traitement efficace des données -l exemple de RANK- Khalid MEHL Jean-François WASSONG 10 mars 2015

4 Exemples de problèmes MapReduce incrémentaux

I.D.S. Systèmes de détection d intrusion - Link Analysis. par: FOUQUIN MATHIEU. responsable: AKLI ADJAOUTE DEVÈZE BENJAMIN.

Contrôle Non Destructif : Implantation d'algorithmes sur GPU et multi-coeurs. Gilles Rougeron CEA/LIST Département Imagerie Simulation et Contrôle

Big Data Concepts et mise en oeuvre de Hadoop

THÈSE. présentée à TÉLÉCOM PARISTECH. pour obtenir le grade de. DOCTEUR de TÉLÉCOM PARISTECH. Mention Informatique et Réseaux. par.

Stephan Hadinger, Sr. Mgr Solutions Architecture, AWS. Salon du Big Data 11 mars 2015

Sécurisation du stockage de données sur le Cloud Michel Kheirallah

Cluster High Availability. Holger Hennig, HA-Cluster Specialist

HADOOP ET SON ÉCOSYSTÈME

Anticiper et prédire les sinistres avec une approche Big Data

MCMC et approximations en champ moyen pour les modèles de Markov

Big Graph Data Forum Teratec 2013

Prototypage et évaluation de performances d un service de traçabilité avec une architecture distribuée basée sur Hadoop

Les simulations dans l enseignement des sondages Avec le logiciel GENESIS sous SAS et la bibliothèque Sondages sous R

Offre formation Big Data Analytics

NoSQL. Introduction 1/23. I NoSQL : Not Only SQL, ce n est pas du relationnel, et le contexte. I table d associations - Map - de couples (clef,valeur)

A GRASPxELS approach for the Job Shop with generic time-lags and new statistical determination of the parameters

TRAITEMENT DES DONNEES MANQUANTES AU MOYEN DE L ALGORITHME DE KOHONEN

CommentWatcher. plateforme Web open-source pour analyser les discussions sur des forums en ligne. Marian-Andrei RIZOIU

Hadoop, Spark & Big Data 2.0. Exploiter une grappe de calcul pour des problème des données massives

Introduction au Data-Mining

Brève introduction à la fouille de grandes bases de données océaniques

Conception d un lecteur de musique intelligent basé sur l apprentissage automatique.

Définition et diffusion de signatures sémantiques dans les systèmes pair-à-pair

VISUALISATION DE NUAGES DE POINTS

Ne cherchez plus, soyez informés! Robert van Kommer

MapReduce. Malo Jaffré, Pablo Rauzy. 16 avril 2010 ENS. Malo Jaffré, Pablo Rauzy (ENS) MapReduce 16 avril / 15

Big Data : utilisation d un cluster Hadoop HDFS Map/Reduce HBase

Tour d horizon de l apprentissage statistique. from Machine Learning to Big Data Analytics

MapReduce. Nicolas Dugué M2 MIAGE Systèmes d information répartis

Déploiement d une architecture Hadoop pour analyse de flux. françois-xavier.andreu@renater.fr

Aspects théoriques et algorithmiques du calcul réparti L agglomération

Le projet Gaïa, le Big Data au service du traitement de données satellitaires CRIP - 16/10/2013 Pierre-Marie Brunet

Entreposage de données complexes pour la médecine d anticipation personnalisée

ProxiLens : Exploration interactive de données multidimensionnelles à partir de leur projection

Cours de Master Recherche

Equilibrage de charge (Load

Our experience in using Apache Giraph for computing the diameter of large graphs. Paul Bertot - Flavian Jacquot

Transcription:

Université Paris 13, Sorbonne Paris Cité, LIPN, UMR 7030 du CNRS 99 Avenue J-B. Clément - 93430 Villetaneuse - France CLUSTERING DE FLUX DE DONNÉES Mustapha LEBBAH MCF, HdR LIPN Univ. Paris 13 H. Azzag, T. Duong, M. Ghesmoune (doctorant) Journée Clustering, Issy Les Moulineaux le 20 Oct 2015

PLAN Contexte Le Big Data comme du «Data Stream» Stratégie du clustering de flux de données Approches utilisées Conclusion & perspectives 2

PARTITIONNEMENT «CLUSTERING» ET BIG DATA Approche hiérarchique Approche par partitionnement Approche spectrale Approche à base de modèles auto-organisés Versions probabilistes... p1 p2 p3 p4 p9 p10 p11 p12 3

PARTITIONNEMENT «CLUSTERING» ET BIG DATA Approche hiérarchique Approche par partitionnement Approche spectrale Approche à base de modèles auto-organisés Versions probabilistes... p1 p2 p3 p4 p9 p10 p11 p12 4 MLI: An API for Distributed Machine Learning. E. Sparks, et al. In ICDM, 2013. 4

FLUX DE DONNÉES / DATA STREAM Les données massives sont collectées à un rythme exceptionnel. Besoin d une réponse rapide Exemples: Les données de suivi de comportement pour étudier les changements dans les habitudes (achat/de circulation/ intrusion) Suivi des données météorologiques, La taille des bases de données et des échantillons est énorme 5

LA COLLECTE DES DONNÉES NE S ARRÊTE JAMAIS! http://www.flightradar24.com Albert Bifet et al 2015 6

CHALLENGES TRAITER LES «BIG DATA» COMME DU DATA STREAM Ensemble x 1,, x n d observations Potentiellement infini Non-stationnaire Rapide, un seul passage Doit être traité dans cet ordre en une passe Ressources CPU et mémoire utilisées par élément faibles L accès aléatoire n est pas permis x i mémoire Data Stream 7

LE BIG DATA COMME LE DATA STREAM micr o1 micr o2 q micr o3.. micr oq Etape d abstraction des données (phase online) Etape de clustering (phase offline) Partition des données De temps en temps Structure de données (résumé des données) Framework de clustering de flux de données online-offline 8

CLUSTERING DE FLUX DE DONNÉES PRINCIPE DE BASE Stratégie Fenêtre de temps: diviser de manière indépendante le flux en fenêtres temporelles. 9

CLUSTERING DE FLUX DE DONNÉES PRINCIPE DE BASE Stratégie Fenêtre de temps: diviser de manière indépendante le flux en fenêtres temporelles. Pondération des fenêtres temporelles (données) -> «fading» 10

CLUSTERING DE FLUX DE DONNÉES PRINCIPE DE BASE Stratégie Fenêtre de temps: diviser de manière indépendante le flux en fenêtres temporelles. Pondération des fenêtres temporelles (données) -> «fading» 11

CLUSTERING DE FLUX DE DONNÉES PRINCIPE DE BASE Stratégie Fenêtre de temps: diviser de manière indépendante le flux en fenêtres temporelles. Pondération des fenêtres temporelles (données) -> «fading» Décroissance exponentielle pour diminuer l'influence des données affectées aux micro-clusters (traiter la dérive de concept) 12

CLUSTERING DE FLUX DE DONNÉES PRINCIPE DE BASE Stratégie Fenêtre de temps: diviser le flux en fenêtres temporelles Clustering 1 Clustering 2 Réservoir Clustering 3 Clustering final Partitionnement des micro-clusters: utilisation d algorithme de clustering traditionnel (k-means, dbscan) en mode «off-line» de combiner. 13

EVOLUTION D UN CLUSTERING t 1 Clustering 14

EVOLUTION D UN CLUSTERING t 1 t 2 Clustering Éclatement split Clustering fusion 15

EVOLUTION D UN CLUSTERING t 1 t 2 t 3 Clustering Clustering Clustering Éclatement split suppression fusion nouveau 16

LES QUESTIONS Comment traiter les nouvelles données? Affecter à un ancien micro-cluster Création d un nouveau micro-cluster Comment traiter les anciens micro-clusters Supprimer Fusionner des micro-clusters (les plus proches) 17

ALGORITHME SIMPLE Initialiser des micro-cluster vides Pour chaque nouvelle observation Trouver le micro-cluster le plus proche Affecter x au micro-cluster ou créer un autre Mise à jour de la structure sous-jacente des microclusters (une topologie, une hiérarchie.) 18

CLUSTERING DE FLUX DE DONNÉES PRINCIPE DE BASE Stratégie : Micro-Clusters Un micro-cluster est une quantification «résumé» d un ensemble de données qui sont proches les uns aux autres et seront traitées comme une seule unité. résumé compression Cluster Micro-cluster, Macro-Cluster Utiliser les prototypes : centre de gravité, vecteur caractéristique, variance...etc Utiliser le temps d arrivée du cluster 19

VECTEUR CARACTÉRISTIQUE : BIRCH Utiliser la structure ou un vecteur caractéristique pour sauvegarder les données Permet de déduire : le centre de gravité, rayon, diamètre Toutes les informations nécessaires pour le clustering Birch: Balanced Iterative Reducing and Clustering using Hierarchies, by Zhang, Ramakrishnan, Livny 1996 20

VECTEUR CARACTÉRISTIQUE : BIRCH Permet de déduire : le centre de gravité, rayon, diamètre Incrémentalité : à la présentation d un nouveau point LS=LS+X SS=SS+ (X) 2 N=N+1 Additivité : fusion de micro-cluster (CF1, CF2) N3=N1+N2 LS3=LS1+LS2 SS3=SS1+SS3 21

MICROCLUSTERS micr o1 micr o2 q micr o3.. micr oq CluStream Sauvegarder la cardinalité, la somme linéaire et la somme au carré de des données du micro-cluster Fusion/suppression des clusters proches Pour chaque période on génère les macro-clusters le snapshot contient q micro-clusters, q dépend de la disponibilité de la mémoire temps Génération des Macro-clusters Taille de la fenêtre CluStream: A Framework for Clustering Evolving Data Streams, Aggarwal, J. Han, J. Wang, P. Yu (VLDB03) 22

MICROCLUSTERS micr o1 micr o2 micr o3 o-microcluster p-microcluster.. micr oq DenStream Introduction des clusters outliers Les Micro-Clusters sont classés par rapport à leur poids w: Si w µ, MC est un core-microcluster Durant la partie online, on distingue: 1. Potential core-microclusters (p-micro-clusters), avec w β.µ 2. Outlier micro-clusters (omicro-clusters), avec w < β.µ Fenêtre temporelle: poids des données diminue avec le temps: f (t) = 2 -αt, α > 0 core-microcluster 23

MICROCLUSTERS micr o1 micr o2 N LS SS LST SST micr o3.. micr oq D-Stream Affecte la donnée à la grille Grilles pondérés par les récents points 24

STREAMKM++ (CORESETS) Un ensemble S pondéré est un (k, )-corset pour un ensemble de données X si le partitionnement de S se rapproche du partitionnement de X avec une marge d'erreur de StreamKM++: A Clustering Algorithm for Data Streams. Ackermann et al 2010 LBG: Linde, Y.;, A.; Gray, R. (1980). "An Algorithm for Vector Quantizer Design". IEEE Tran.Buzo et al 1980. 25

CONSTRUCTION D UN ARBRE DE CF B-arbre, seuil de diamètre T et L le nombre de microclusters maximum par feuille Les petits micro-clusters sont considérés comme des outliers 26

LE BIG DATA COMME LE DATA STREAM micr o1 micr o2 micr oq Etape d abstraction des données (phase online) Etape de clustering (phase offline) De temps en temps Structure de données (résumé des données) Partition des données Framework de clustering de flux de données online-offline 27

GNG Topologie évolutive Nombre de cellules non fixé GNG: A Growing Neural Gas Network Learns Topologies. Fritzke 1995 28

G-STREAM ET LE RESTE 29

CARACTÉRISTIQUES Un graphe représentant la structure topologique, Pondération des liens et des nœuds p 1 p2 30

G-STREAM: CARACTÉRISTIQUES ET AVANTAGES Pas de phase d initialisation du modèle, Création de plusieurs nœuds (potentiel-microcluster) à la fois, Utilisation d un réservoir Réservoir 31

G-STREAM Mise à jour d une manière «Batch» Mise à jour d une manière stochastique 32

Stream + Batch + MapReduce Aucune maitrise de la distribution des données dans l échosystème. Data Algo. LEA Algo. LEArning LEA LEA LEA MapReduce / Spark 33

SPARK STREAMING Combinaison du traitement du flux et le traitement en batch for (i <- 1 until 10) { val closest = data.map(p => (closestcentroid(p, centroids), (p, 1)) ) val pointstats=closest.reducebykey{ case ((p1, sum1), (p2, sum2)) => (p1 + p2, sum1 + sum2) } pointstats.foreach{case(id, value) => centroids(id) = value._1 / value._2 } } 34 34

G-STREAM : PRINCIPE DE LA VERSION BATCH Version batch de SOM Affecter au plus proche Fonction de voisinage 35

G-STREAM : PRINCIPE DE LA VERSION BATCH Version batch de SOM Affecter au plus proche Fonction de voisinage 36

G-STREAM : LE PROTOTYPE Nouvelles données Anciennes données 37

G-STREAM : LE PROTOTYPE Nouvelles données Anciennes données 38

G-STREAM : LE PROTOTYPE Nouvelles données Anciennes données 39

G-STREAM : LE PROTOTYPE Nouvelles données Anciennes données 40

G-STREAM: AFFECTATION, MAP Map Numéro de cluster 41

G-STREAM Map Map Map 42 42

G-STREAM Map Map Map Fusion : Contrainte must-link sur le numéro de bmu (ou autre) action: sommation des, calcul de la fonction de voisinage, etc Fusion 43

G-STREAM Map Map Map Fusion : Contrainte must-link sur le numéro de bmu (ou autre) action: sommation des, calcul de la fonction de voisinage, etc Fusion 44

LA CHAINE MAP (AFFECTATION) ET RÉDUCE (FUSION) Map Map Map Map Map Fusion Reduce Map Fusion Reduce temps Fusion Reduce 45

G-STREAM : LE PROTOTYPE Nouvelles données Anciennes données (key, [Value0, Value1, Value2, ]) Reduce Output Clusters 46

BASE DE DONNÉES 47

G-STREAM : EXEMPLE G-Stream 48

G-STREAM SUR DS1 49

G-STREAM SUR DS1

G-STREAM SUR DS1

G-STREAM SUR DS1 52

G-STREAM VS GNG-ONLINE: #NŒUDS DS1 DS2 letter4 Sea 53

G-STREAM VS GNG ONLINE: ACCURACY DS1 DS2 Letter4 HyperPlan Sea 54

EVALUATIONS NMI DB 55

NMI 0,8 0,7 G-Stream StreamKM++ DenSream ClusTree 0,6 0,5 0,4 0,3 0,2 0,1 0 DS1 DS2 letter4 Sea HyperPlan KddCup99 CoverType Sensor 56

CONCLUSION & PERSPECTIVES Une diversité d approches Approches probabilistes: EM online, OVEM-DyMix (Online Variationnal Expectation Maximisation for Dynamic Mixture model) L'apprentissage en flux de données n est pas généralement réalisé en un seul passage. C est un processus évolutif..! L intérêt de combiner du «batch» et du «streaming» Différents outils (dont spark) 57

OUTILS DISPONIBLES {M}assive {O}nline {A}nalysis MOA (Bifet et al. 2010) Connecté à WEKA http://moa.cms.waikato.ac.nz/details/stream-clustering/ StreamDM http://spark.apache.org/ 58

OUTILS DISPONIBLES Apache Mahout SAMOA G. De Francisci Morales, et al. "SAMOA: Scalable Advanced Massive Online Analysis." Journal of Machine Learning Research, 16(Jan):149 153, 2015. http://samoa.incubator.apache.org/ https://flink.apache.org/ 59

QUELQUES CHALLENGES S'adapter constamment à l'évolution de l'environnement (autoconfigurable) La prise en compte de l évolution des données et du recouvrement La prise en compte des différents types de données Accélération des programmes: l échantillonnage, hashing, projection aléatoire (LSH) La visualisation Facile à utiliser «ease to use» 60

RÉFÉRENCES G. De Francisci Morales, A. Bifet. "SAMOA: Scalable Advanced Massive Online Analysis." Journal of Machine Learning Research, 16(Jan):149 153, 2015. E. Sparks, A. Talwalkar, V. Smith, J. Kottalam, X. Pan, J. Gonzalez, M. Franklin, M. I. Jordan, T. Kraska. MLI: An API for Distributed Machine Learning. International Conference on Data Mining (ICDM), 2013 Charu C. Aggarwal, Jiawei Han, Jianyong Wang, and Philip S. Yu. A framework for clustering evolving data streams. In Proceedings of the International Conference on Very Large Data Bases (VLDB 03), pages 81 92, 2003. Aggarwal C C, Han J, Wang J, Yu P S. A framework for pro- jected clustering of high dimensional data streams. In Proc. the 30th International Conference on Very Large Data Bases, Volume 30, Aug. 29-Sept. 3, 2004, pp.852-863. Amini A, Wah TY, Saboohi H. On density-based data streams clustering algorithms: A survey. JOURNAL OF COMPUTER SCIENCE AND TECHNOLOGY 29(1): 116 141 Jan. 2014. DOI 10.1007/s11390-013-1416-3 Jonathan A. Silva, Elaine R. Faria, Rodrigo C. Barros, Eduardo R. Hruschka, André C. P. L. F. de Carvalho, and João Gama. 2013. Data stream clustering: A survey. ACM Comput. Surv. 46, 1, Article 13 (July 2013), 31 pages Gianmarco De Francisci Morales, Joao Gama, Albert Bifet, Wei Fan. Big Data Stream Mining Tutorial at IEEE BigData 201 Albert Bifet, Andre C P L F de Carvalho, Joa o Gama. BigData Stream Mining. ECML-PKDD Summer school 2015 Hani El Assaad, Allou Samé, Gérard Govaert, Patrice Aknin: Model-Based Clustering of Temporal Data. ICANN 2013: 9-16 Mohammed Ghesmoune, Mustapha Lebbah, Hanene Azzag. Micro-Batching Growing Neural Gas for Clustering Data Streams using Spark Streaming. Procedia Computer Science journal (2015) pp. 158-166. Doi 10.1016/j.procs.2015.07.290. Mohammed Ghesmoune, Mustapha Lebbah, and Hanene Azzag. Clustering over data streams based on growing neural gas. PAKDD (2) 2015: 134-145. 61