Mostrar el registro sencillo del ítem
Plantilla parallel_for heterogénea implementada en INTEL ONEAPI
dc.contributor.advisor | Asenjo-Plaza, Rafael | |
dc.contributor.author | Domínguez Berdún, Juan Pedro | |
dc.contributor.other | Arquitectura de Computadores | es_ES |
dc.date.accessioned | 2021-03-15T07:23:05Z | |
dc.date.available | 2021-03-15T07:23:05Z | |
dc.date.created | 2021-02 | |
dc.date.issued | 2021 | |
dc.identifier.uri | https://hdl.handle.net/10630/21115 | |
dc.description.abstract | Este trabajo consiste en el desarrollo e implementación de un template de alto nivel, basado en la librería oneTBB de Intel, que permita la ejecución de bucles paralelos de forma heterogénea (Heterogeneous Parallel For). El template se apoya en un planificador llamado LogFit que permite el reparto automático de la carga entre los cores de CPU y la GPU. Se proporciona una implementación basada en oneTBB 2020 que usa las clases Flow Graph con soporte de nodos OpenCL, y otra basada en oneAPI/SYCL y oneTBB 2021 que permite mantener en el mismo fuente el código de GPU y el de CPU. Este nuevo template permite la ejecución de forma fácil y eficiente de bucles paralelos sobre plataformas heterogéneas CPU GPU, simplemente proporcionándole el rango de iteraciones del bucle, la función a ejecutar en CPU (en caso de ser este el dispositivo elegido para ejecutar un subrango de las mismas) y el kernel (en lenguaje OpenCL o en SYCL) a ejecutar en la GPU (en caso de ser esta la elegida). Además de la implementación del template y la comprobación de su correcto funcionamiento, se ha realizado una comparación de rendimientos entre distintas implementaciones de dos kernels computacionales. Además del rendimiento se ha evaluado tanto la sobrecarga de la nueva abstracción y la reducción del esfuerzo de programación. | es_ES |
dc.language.iso | spa | es_ES |
dc.rights | info:eu-repo/semantics/openAccess | es_ES |
dc.rights.uri | http://creativecommons.org/licenses/by-nc-nd/4.0/ | * |
dc.subject | Programación en paralelo (Informática) | es_ES |
dc.subject | Ordenadores paralelos | es_ES |
dc.subject | Arquitectura de ordenadores | es_ES |
dc.subject | Informática - Trabajos Fin de Grado | es_ES |
dc.subject | Grado en Ingeniería Informática - Trabajos Fin de Grado | es_ES |
dc.subject.other | C++ | es_ES |
dc.subject.other | TBB | es_ES |
dc.subject.other | OpenCL | es_ES |
dc.subject.other | Computación paralela | es_ES |
dc.subject.other | Computación heterogénea | es_ES |
dc.subject.other | GPU | es_ES |
dc.subject.other | oneAPI | es_ES |
dc.subject.other | DPC++ | es_ES |
dc.subject.other | SYCL | es_ES |
dc.title | Plantilla parallel_for heterogénea implementada en INTEL ONEAPI | es_ES |
dc.title.alternative | INTEL ONEAPI implementation of a heterogeneous parallel_for template | es_ES |
dc.type | info:eu-repo/semantics/bachelorThesis | es_ES |
dc.centro | E.T.S.I. Informática | es_ES |
dc.rights.cc | Attribution-NonCommercial-NoDerivatives 4.0 Internacional | * |