{"id":"https://openalex.org/W2289151794","doi":"https://doi.org/10.1145/2854038.2854042","title":"Have abstraction and eat performance, too: optimized heterogeneous computing with parallel patterns","display_name":"Have abstraction and eat performance, too: optimized heterogeneous computing with parallel patterns","publication_year":2016,"publication_date":"2016-02-29","ids":{"openalex":"https://openalex.org/W2289151794","doi":"https://doi.org/10.1145/2854038.2854042","mag":"2289151794"},"language":"en","primary_location":{"id":"doi:10.1145/2854038.2854042","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2854038.2854042","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2016 International Symposium on Code Generation and Optimization","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5103616447","display_name":"Kevin J. Brown","orcid":null},"institutions":[{"id":"https://openalex.org/I97018004","display_name":"Stanford University","ror":"https://ror.org/00f54p054","country_code":"US","type":"education","lineage":["https://openalex.org/I97018004"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Kevin J. Brown","raw_affiliation_strings":["Stanford University, USA"],"affiliations":[{"raw_affiliation_string":"Stanford University, USA","institution_ids":["https://openalex.org/I97018004"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5047315031","display_name":"HyoukJoong Lee","orcid":null},"institutions":[{"id":"https://openalex.org/I97018004","display_name":"Stanford University","ror":"https://ror.org/00f54p054","country_code":"US","type":"education","lineage":["https://openalex.org/I97018004"]},{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"HyoukJoong Lee","raw_affiliation_strings":["Stanford University, USA / Google, USA"],"affiliations":[{"raw_affiliation_string":"Stanford University, USA / Google, USA","institution_ids":["https://openalex.org/I1291425158","https://openalex.org/I97018004"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5003153354","display_name":"Tiark Rompf","orcid":"https://orcid.org/0000-0002-2068-3238"},"institutions":[{"id":"https://openalex.org/I219193219","display_name":"Purdue University West Lafayette","ror":"https://ror.org/02dqehb95","country_code":"US","type":"education","lineage":["https://openalex.org/I219193219"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Tiark Rompf","raw_affiliation_strings":["Purdue University, USA"],"affiliations":[{"raw_affiliation_string":"Purdue University, USA","institution_ids":["https://openalex.org/I219193219"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5027289345","display_name":"Arvind K. Sujeeth","orcid":null},"institutions":[{"id":"https://openalex.org/I97018004","display_name":"Stanford University","ror":"https://ror.org/00f54p054","country_code":"US","type":"education","lineage":["https://openalex.org/I97018004"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Arvind K. Sujeeth","raw_affiliation_strings":["Stanford University, USA"],"affiliations":[{"raw_affiliation_string":"Stanford University, USA","institution_ids":["https://openalex.org/I97018004"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5041869459","display_name":"Christopher De","orcid":"https://orcid.org/0000-0002-3610-2696"},"institutions":[{"id":"https://openalex.org/I97018004","display_name":"Stanford University","ror":"https://ror.org/00f54p054","country_code":"US","type":"education","lineage":["https://openalex.org/I97018004"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Christopher De Sa","raw_affiliation_strings":["Stanford University, USA"],"affiliations":[{"raw_affiliation_string":"Stanford University, USA","institution_ids":["https://openalex.org/I97018004"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5067487295","display_name":"Christopher R. Aberger","orcid":null},"institutions":[{"id":"https://openalex.org/I97018004","display_name":"Stanford University","ror":"https://ror.org/00f54p054","country_code":"US","type":"education","lineage":["https://openalex.org/I97018004"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Christopher Aberger","raw_affiliation_strings":["Stanford University, USA"],"affiliations":[{"raw_affiliation_string":"Stanford University, USA","institution_ids":["https://openalex.org/I97018004"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5023857198","display_name":"Kunle Olukotun","orcid":"https://orcid.org/0000-0002-8779-0636"},"institutions":[{"id":"https://openalex.org/I97018004","display_name":"Stanford University","ror":"https://ror.org/00f54p054","country_code":"US","type":"education","lineage":["https://openalex.org/I97018004"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Kunle Olukotun","raw_affiliation_strings":["Stanford University, USA"],"affiliations":[{"raw_affiliation_string":"Stanford University, USA","institution_ids":["https://openalex.org/I97018004"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":7,"corresponding_author_ids":["https://openalex.org/A5103616447"],"corresponding_institution_ids":["https://openalex.org/I97018004"],"apc_list":null,"apc_paid":null,"fwci":10.4233,"has_fulltext":false,"cited_by_count":45,"citation_normalized_percentile":{"value":0.98406953,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":100},"biblio":{"volume":null,"issue":null,"first_page":"194","last_page":"205"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/T10101","display_name":"Cloud Computing and Resource Management","score":0.9998000264167786,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9997000098228455,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.9001641869544983},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.6843752861022949},{"id":"https://openalex.org/keywords/abstraction","display_name":"Abstraction","score":0.6124979853630066},{"id":"https://openalex.org/keywords/variety","display_name":"Variety (cybernetics)","score":0.5505620241165161},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.5476677417755127},{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.5299946665763855},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.4996943473815918},{"id":"https://openalex.org/keywords/symmetric-multiprocessor-system","display_name":"Symmetric multiprocessor system","score":0.44663283228874207},{"id":"https://openalex.org/keywords/parallel-programming-model","display_name":"Parallel programming model","score":0.4187115430831909},{"id":"https://openalex.org/keywords/computation","display_name":"Computation","score":0.41209131479263306},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.33323344588279724},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.09540417790412903}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9001641869544983},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.6843752861022949},{"id":"https://openalex.org/C124304363","wikidata":"https://www.wikidata.org/wiki/Q673661","display_name":"Abstraction","level":2,"score":0.6124979853630066},{"id":"https://openalex.org/C136197465","wikidata":"https://www.wikidata.org/wiki/Q1729295","display_name":"Variety (cybernetics)","level":2,"score":0.5505620241165161},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.5476677417755127},{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.5299946665763855},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4996943473815918},{"id":"https://openalex.org/C172430144","wikidata":"https://www.wikidata.org/wiki/Q17111997","display_name":"Symmetric multiprocessor system","level":2,"score":0.44663283228874207},{"id":"https://openalex.org/C137364921","wikidata":"https://www.wikidata.org/wiki/Q27929394","display_name":"Parallel programming model","level":3,"score":0.4187115430831909},{"id":"https://openalex.org/C45374587","wikidata":"https://www.wikidata.org/wiki/Q12525525","display_name":"Computation","level":2,"score":0.41209131479263306},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.33323344588279724},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.09540417790412903},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2854038.2854042","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2854038.2854042","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2016 International Symposium on Code Generation and Optimization","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"}],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":41,"referenced_works":["https://openalex.org/W78077100","https://openalex.org/W109260298","https://openalex.org/W790941020","https://openalex.org/W1425731158","https://openalex.org/W1553195691","https://openalex.org/W1598202309","https://openalex.org/W1749979338","https://openalex.org/W1788418780","https://openalex.org/W1964646627","https://openalex.org/W1978924650","https://openalex.org/W2008070495","https://openalex.org/W2034102265","https://openalex.org/W2054625910","https://openalex.org/W2061313045","https://openalex.org/W2065887019","https://openalex.org/W2077143534","https://openalex.org/W2100830825","https://openalex.org/W2102976251","https://openalex.org/W2104959526","https://openalex.org/W2110423393","https://openalex.org/W2112523971","https://openalex.org/W2129603526","https://openalex.org/W2130179171","https://openalex.org/W2131975293","https://openalex.org/W2138243089","https://openalex.org/W2146757372","https://openalex.org/W2152885483","https://openalex.org/W2157036282","https://openalex.org/W2163496769","https://openalex.org/W2166906890","https://openalex.org/W2170616854","https://openalex.org/W2173213060","https://openalex.org/W2244101089","https://openalex.org/W2436525433","https://openalex.org/W2951781666","https://openalex.org/W3017193247","https://openalex.org/W3117114023","https://openalex.org/W4242946001","https://openalex.org/W4244523606","https://openalex.org/W4300937065","https://openalex.org/W6675660707"],"related_works":["https://openalex.org/W1571189856","https://openalex.org/W1177194838","https://openalex.org/W2002195829","https://openalex.org/W2102103803","https://openalex.org/W2810639508","https://openalex.org/W2487079071","https://openalex.org/W2076357067","https://openalex.org/W1526435074","https://openalex.org/W2783439599","https://openalex.org/W3124194311"],"abstract_inverted_index":{"High":[0],"performance":[1],"in":[2,40,183],"modern":[3,49,53],"computing":[4],"platforms":[5],"requires":[6],"programs":[7],"to":[8,25,28,64,73,81,92,123,137,154,180],"be":[9],"parallel,":[10],"distributed,":[11],"and":[12,36,51,78,157,174],"run":[13],"on":[14,113,140],"heterogeneous":[15,86,127,160],"hardware.":[16,87],"However":[17],"programming":[18,34,58,186],"such":[19],"architectures":[20],"is":[21,61],"extremely":[22],"difficult":[23],"due":[24],"the":[26,30,103,119],"need":[27,56],"implement":[29],"application":[31],"using":[32],"multiple":[33,172,184],"models":[35],"combine":[37],"them":[38],"together":[39],"ad-hoc":[41],"ways.":[42],"To":[43],"optimize":[44,158],"distributed":[45,126,185],"applications":[46,170],"both":[47],"for":[48,52,159,166],"hardware":[50],"programmers":[54],"we":[55,101],"a":[57,66,83,108,167],"model":[59],"that":[60,117,133,151],"sufficiently":[62,71,79],"expressive":[63],"support":[65,82],"variety":[67,84],"of":[68,85,95,148,169],"parallel":[69,115],"applications,":[70],"performant":[72],"surpass":[74],"hand-optimized":[75],"sequential":[76],"implementations,":[77],"portable":[80],"Unfortunately":[88],"existing":[89],"systems":[90],"tend":[91],"fall":[93],"short":[94],"these":[96],"requirements.":[97],"In":[98],"this":[99],"paper":[100],"introduce":[102],"Distributed":[104],"Multiloop":[105],"Language":[106],"(DMLL),":[107],"new":[109],"intermediate":[110],"language":[111],"based":[112,139],"common":[114],"patterns":[116,150],"captures":[118],"necessary":[120],"semantic":[121],"knowledge":[122],"efficiently":[124],"target":[125],"architectures.":[128],"We":[129,162],"show":[130],"straightforward":[131],"analyses":[132],"determine":[134],"what":[135],"data":[136],"distribute":[138],"its":[141],"usage":[142],"as":[143,145],"well":[144],"powerful":[146],"transformations":[147],"nested":[149],"restructure":[152],"computation":[153],"enable":[155],"distribution":[156],"devices.":[161],"present":[163],"experimental":[164],"results":[165],"range":[168],"spanning":[171],"domains":[173],"demonstrate":[175],"highly":[176],"efficient":[177],"execution":[178],"compared":[179],"manually-optimized":[181],"counterparts":[182],"models.":[187]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2022,"cited_by_count":4},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":3},{"year":2019,"cited_by_count":5},{"year":2018,"cited_by_count":13},{"year":2017,"cited_by_count":11},{"year":2016,"cited_by_count":7}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
