{"id":"https://openalex.org/W2581768997","doi":"https://doi.org/10.1145/3026937.3026942","title":"Towards Composable GPU Programming","display_name":"Towards Composable GPU Programming","publication_year":2017,"publication_date":"2017-01-27","ids":{"openalex":"https://openalex.org/W2581768997","doi":"https://doi.org/10.1145/3026937.3026942","mag":"2581768997"},"language":"en","primary_location":{"id":"doi:10.1145/3026937.3026942","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3026937.3026942","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 8th International Workshop on Programming Models and Applications for Multicores and Manycores","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://www.research.ed.ac.uk/en/publications/fff66ade-3077-40d0-ac28-5851a7d7f938","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5017380426","display_name":"Michael Haidl","orcid":"https://orcid.org/0000-0003-0225-498X"},"institutions":[{"id":"https://openalex.org/I22465464","display_name":"University of M\u00fcnster","ror":"https://ror.org/00pd74e08","country_code":"DE","type":"education","lineage":["https://openalex.org/I22465464"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Michael Haidl","raw_affiliation_strings":["University of M\u00fcnster, Germany"],"affiliations":[{"raw_affiliation_string":"University of M\u00fcnster, Germany","institution_ids":["https://openalex.org/I22465464"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5016319844","display_name":"Michel Steuwer","orcid":"https://orcid.org/0000-0001-5048-0741"},"institutions":[{"id":"https://openalex.org/I98677209","display_name":"University of Edinburgh","ror":"https://ror.org/01nrxwf90","country_code":"GB","type":"education","lineage":["https://openalex.org/I98677209"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Michel Steuwer","raw_affiliation_strings":["University of Edinburgh, UK"],"affiliations":[{"raw_affiliation_string":"University of Edinburgh, UK","institution_ids":["https://openalex.org/I98677209"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5005859383","display_name":"Hendrik Dirks","orcid":null},"institutions":[{"id":"https://openalex.org/I22465464","display_name":"University of M\u00fcnster","ror":"https://ror.org/00pd74e08","country_code":"DE","type":"education","lineage":["https://openalex.org/I22465464"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Hendrik Dirks","raw_affiliation_strings":["University of M\u00fcnster, Germany"],"affiliations":[{"raw_affiliation_string":"University of M\u00fcnster, Germany","institution_ids":["https://openalex.org/I22465464"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5052026949","display_name":"Tim Humernbrum","orcid":null},"institutions":[{"id":"https://openalex.org/I22465464","display_name":"University of M\u00fcnster","ror":"https://ror.org/00pd74e08","country_code":"DE","type":"education","lineage":["https://openalex.org/I22465464"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Tim Humernbrum","raw_affiliation_strings":["University of M\u00fcnster, Germany"],"affiliations":[{"raw_affiliation_string":"University of M\u00fcnster, Germany","institution_ids":["https://openalex.org/I22465464"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5061421539","display_name":"Sergei Gorlatch","orcid":"https://orcid.org/0000-0003-3857-9380"},"institutions":[{"id":"https://openalex.org/I22465464","display_name":"University of M\u00fcnster","ror":"https://ror.org/00pd74e08","country_code":"DE","type":"education","lineage":["https://openalex.org/I22465464"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Sergei Gorlatch","raw_affiliation_strings":["University of M\u00fcnster, Germany"],"affiliations":[{"raw_affiliation_string":"University of M\u00fcnster, Germany","institution_ids":["https://openalex.org/I22465464"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5017380426"],"corresponding_institution_ids":["https://openalex.org/I22465464"],"apc_list":null,"apc_paid":null,"fwci":0.2253,"has_fulltext":false,"cited_by_count":2,"citation_normalized_percentile":{"value":0.4502917,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":null,"issue":null,"first_page":"58","last_page":"67"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9994999766349792,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9994999766349792,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10627","display_name":"Advanced Image and Video Retrieval Techniques","score":0.9940999746322632,"subfield":{"id":"https://openalex.org/subfields/1707","display_name":"Computer Vision and Pattern Recognition"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10036","display_name":"Advanced Neural Network Applications","score":0.9940000176429749,"subfield":{"id":"https://openalex.org/subfields/1707","display_name":"Computer Vision and Pattern Recognition"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8289639949798584},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.5046707391738892},{"id":"https://openalex.org/keywords/general-purpose-computing-on-graphics-processing-units","display_name":"General-purpose computing on graphics processing units","score":0.4918077290058136},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.4649699032306671},{"id":"https://openalex.org/keywords/cuda","display_name":"CUDA","score":0.4210623800754547},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.38400962948799133},{"id":"https://openalex.org/keywords/computer-architecture","display_name":"Computer architecture","score":0.33591461181640625},{"id":"https://openalex.org/keywords/computer-graphics","display_name":"Computer graphics (images)","score":0.272164911031723},{"id":"https://openalex.org/keywords/graphics","display_name":"Graphics","score":0.17446056008338928}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8289639949798584},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.5046707391738892},{"id":"https://openalex.org/C50630238","wikidata":"https://www.wikidata.org/wiki/Q971505","display_name":"General-purpose computing on graphics processing units","level":3,"score":0.4918077290058136},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.4649699032306671},{"id":"https://openalex.org/C2778119891","wikidata":"https://www.wikidata.org/wiki/Q477690","display_name":"CUDA","level":2,"score":0.4210623800754547},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.38400962948799133},{"id":"https://openalex.org/C118524514","wikidata":"https://www.wikidata.org/wiki/Q173212","display_name":"Computer architecture","level":1,"score":0.33591461181640625},{"id":"https://openalex.org/C121684516","wikidata":"https://www.wikidata.org/wiki/Q7600677","display_name":"Computer graphics (images)","level":1,"score":0.272164911031723},{"id":"https://openalex.org/C21442007","wikidata":"https://www.wikidata.org/wiki/Q1027879","display_name":"Graphics","level":2,"score":0.17446056008338928}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/3026937.3026942","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3026937.3026942","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 8th International Workshop on Programming Models and Applications for Multicores and Manycores","raw_type":"proceedings-article"},{"id":"pmh:oai:eprints.gla.ac.uk:146597","is_oa":false,"landing_page_url":null,"pdf_url":null,"source":{"id":"https://openalex.org/S4210235606","display_name":"ENLIGHTEN (Jurnal Bimbingan dan Konseling Islam)","issn_l":"2622-8912","issn":["2622-8912","2622-8920"],"is_oa":false,"is_in_doaj":true,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":"","raw_type":"Conference Proceedings"},{"id":"pmh:oai:pure.ed.ac.uk:openaire/fff66ade-3077-40d0-ac28-5851a7d7f938","is_oa":true,"landing_page_url":"https://www.research.ed.ac.uk/en/publications/fff66ade-3077-40d0-ac28-5851a7d7f938","pdf_url":null,"source":{"id":"https://openalex.org/S4406922455","display_name":"Edinburgh Research Explorer","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Haidl, M, Steuwer, M, Dirks, H, Hummernbrum, T & Gorlatch, S 2017, Towards Composable GPU Programming: Programming GPUs with Eager Actions and Lazy Views. in PMAM'17 Proceedings of the 8th International Workshop on Programming Models and Applications for Multicores and Manycores. pp. 58-67, 8th International Workshop on Programming Models and Applications for Multicores and Manycores, Austin, Texas, United States, 4/02/17. https://doi.org/10.1145/3026937.3026942","raw_type":"contributionToPeriodical"},{"id":"pmh:oai:pure.ed.ac.uk:publications/fff66ade-3077-40d0-ac28-5851a7d7f938","is_oa":false,"landing_page_url":"http://hdl.handle.net/20.500.11820/fff66ade-3077-40d0-ac28-5851a7d7f938","pdf_url":null,"source":{"id":"https://openalex.org/S4406922455","display_name":"Edinburgh Research Explorer","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":""}],"best_oa_location":{"id":"pmh:oai:pure.ed.ac.uk:openaire/fff66ade-3077-40d0-ac28-5851a7d7f938","is_oa":true,"landing_page_url":"https://www.research.ed.ac.uk/en/publications/fff66ade-3077-40d0-ac28-5851a7d7f938","pdf_url":null,"source":{"id":"https://openalex.org/S4406922455","display_name":"Edinburgh Research Explorer","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Haidl, M, Steuwer, M, Dirks, H, Hummernbrum, T & Gorlatch, S 2017, Towards Composable GPU Programming: Programming GPUs with Eager Actions and Lazy Views. in PMAM'17 Proceedings of the 8th International Workshop on Programming Models and Applications for Multicores and Manycores. pp. 58-67, 8th International Workshop on Programming Models and Applications for Multicores and Manycores, Austin, Texas, United States, 4/02/17. https://doi.org/10.1145/3026937.3026942","raw_type":"contributionToPeriodical"},"sustainable_development_goals":[],"awards":[],"funders":[{"id":"https://openalex.org/F4320309480","display_name":"Nvidia","ror":"https://ror.org/03jdj4y14"}],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":16,"referenced_works":["https://openalex.org/W1480958225","https://openalex.org/W1997978901","https://openalex.org/W1999534369","https://openalex.org/W2083310717","https://openalex.org/W2092663520","https://openalex.org/W2103559027","https://openalex.org/W2107096626","https://openalex.org/W2222053960","https://openalex.org/W2249637006","https://openalex.org/W2301928242","https://openalex.org/W2572546943","https://openalex.org/W2762746832","https://openalex.org/W2964279072","https://openalex.org/W6731603714","https://openalex.org/W6831535640","https://openalex.org/W6832800064"],"related_works":["https://openalex.org/W1963859303","https://openalex.org/W2364044215","https://openalex.org/W2389600408","https://openalex.org/W240129890","https://openalex.org/W3048701459","https://openalex.org/W3213381848","https://openalex.org/W2149078538","https://openalex.org/W2080146221","https://openalex.org/W2370314112","https://openalex.org/W1912958759"],"abstract_inverted_index":{"In":[0],"this":[1],"paper,":[2],"we":[3],"advocate":[4],"a":[5,65],"composable":[6],"approach":[7],"to":[8,69],"programming":[9,27],"systems":[10],"with":[11],"Graphics":[12],"Processing":[13],"Units":[14],"(GPU):":[15],"programs":[16],"are":[17],"developed":[18],"as":[19],"compositions":[20],"of":[21,47,72],"generic,":[22],"reusable":[23],"patterns.":[24],"Current":[25],"GPU":[26],"approaches":[28],"either":[29],"rely":[30],"on":[31],"low-level,":[32],"monolithic":[33],"code":[34],"without":[35],"patterns":[36],"(CUDA":[37],"and":[38,49],"OpenCL),":[39],"which":[40],"achieves":[41],"high":[42],"performance":[43,66],"at":[44],"the":[45,55],"cost":[46],"cumbersome":[48],"error-prone":[50],"programming,":[51],"or":[52],"they":[53],"improve":[54],"programmability":[56],"by":[57],"using":[58],"pattern-based":[59],"abstractions":[60],"(e.g.,":[61],"Thrust)":[62],"but":[63],"pay":[64],"penalty":[67],"due":[68],"inefficient":[70],"implementations":[71],"pattern":[73],"composition.":[74]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2018,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2017-02-03T00:00:00"}
