Afficher la notice abrégée

dc.contributor.advisorBarthou, Denis
dc.contributor.authorHAINE, Christopher
dc.contributor.otherBarthou, Denis
dc.contributor.otherJeannot, Emmanuel
dc.contributor.otherCharles, Henri-Pierre
dc.contributor.otherMalony, Allen
dc.contributor.otherRossé-Laurent, Pascale
dc.contributor.otherAumage, Olivier
dc.date2017-07-03
dc.identifier.urihttp://www.theses.fr/2017BORD0639/abes
dc.identifier.uri
dc.identifier.urihttps://tel.archives-ouvertes.fr/tel-01841485
dc.identifier.nnt2017BORD0639
dc.description.abstractBien penser la structuration de données est primordial pour obtenir de hautes performances, alors que les processeurs actuels perdent un temps considérable à attendre la complétion de transactions mémoires. En particulier les localités spatiales et temporelles de données doivent être optimisées.Cependant, les transformations de structures de données ne sont pas proprement explorées par les compilateurs, en raison de la difficulté que pose l'évaluation de performance des transformations potentielles. De plus,l'optimisation des structures de données est chronophage, sujette à erreur etles transformations à considérer sont trop nombreuses pour être implémentées à la main dans l'optique de trouver une version de code efficace.On propose de guider les programmeurs à travers le processus de restructuration de données grace à un retour utilisateur approfondi, tout d'abord en donnant une description multidimensionnelle de la structure de donnée initiale, faite par une analyse de traces mémoire issues du binaire de l'application de l'utilisateur, dans le but de localiser des problèmes de stride au niveau instruction, indépendemment du langage d'entrée. On choisit de focaliser notre étude sur les transformations de structure de données, traduisibles dans un formalisme proche du C pour favoriser la compréhension de l'utilisateur, que l'on applique et évalue sur deux cas d'étude qui sont des applications réelles,à savoir une simulation d'ondes cardiaques et une simulation de chromodynamique quantique sur réseau, avec différents jeux d'entrées. La prédiction de performance de différentes transformations est conforme à 5% près aux versions réécrites à la main.
dc.description.abstractEnCareful data layout design is crucial for achieving high performance, as nowadays processors waste a considerable amount of time being stalled by memory transactions, and in particular spacial and temporal locality have to be optimized. However, data layout transformations is an area left largely unexplored by state-of-the-art compilers, due to the difficulty to evaluate the possible performance gains of transformations. Moreover, optimizing data layout is time-consuming, error-prone, and layout transformations are too numerous tobe experimented by hand in hope to discover a high performance version. We propose to guide application programmers through data layout restructuring with an extensive feedback, firstly by providing a comprehensive multidimensional description of the initial layout, built via analysis of memory traces collected from the application binary textit {in fine} aiming at pinpointing problematic strides at the instruction level, independently of theinput language. We choose to focus on layout transformations,translatable to C-formalism to aid user understanding, that we apply and assesson case study composed of two representative multithreaded real-lifeapplications, a cardiac wave simulation and lattice QCD simulation, with different inputs and parameters. The performance prediction of different transformations matches (within 5%) with hand-optimized layout code.
dc.language.isoen
dc.subjectProfilage de performance
dc.subjectRestructuration de données
dc.subjectVectorisation
dc.subjectRéécriture de binaire
dc.subject.enPerformance profiling
dc.subject.enLayout restructuring
dc.subject.enVectorization
dc.subject.enBinary rewriting
dc.titleKernel optimization by layout restructuring
dc.title.enEstimation d'efficacité et restructuration automatisées de noyaux de calcul
dc.typeThèses de doctorat
dc.contributor.jurypresidentJeannot, Emmanuel
bordeaux.hal.laboratoriesLaboratoire bordelais de recherche en informatique
bordeaux.type.institutionBordeaux
bordeaux.thesis.disciplineInformatique
bordeaux.ecole.doctoraleÉcole doctorale de mathématiques et informatique (Talence, Gironde)
star.origin.linkhttps://www.theses.fr/2017BORD0639
dc.contributor.rapporteurCharles, Henri-Pierre
dc.contributor.rapporteurMalony, Allen
bordeaux.COinSctx_ver=Z39.88-2004&rft_val_fmt=info:ofi/fmt:kev:mtx:journal&rft.title=Kernel%20optimization%20by%20layout%20restructuring&rft.atitle=Kernel%20optimization%20by%20layout%20restructuring&rft.au=HAINE,%20Christopher&rft.genre=unknown


Fichier(s) constituant ce document

FichiersTailleFormatVue

Il n'y a pas de fichiers associés à ce document.

Ce document figure dans la(les) collection(s) suivante(s)

Afficher la notice abrégée