{"id":"https://openalex.org/W2500074838","doi":"https://doi.org/10.1145/2935323.2935329","title":"Automatic generation of parallel C code for stencil applications written in MATLAB","display_name":"Automatic generation of parallel C code for stencil applications written in MATLAB","publication_year":2016,"publication_date":"2016-06-02","ids":{"openalex":"https://openalex.org/W2500074838","doi":"https://doi.org/10.1145/2935323.2935329","mag":"2500074838"},"language":"en","primary_location":{"id":"doi:10.1145/2935323.2935329","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2935323.2935329","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 3rd ACM SIGPLAN International Workshop on Libraries, Languages, and Compilers for Array Programming","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/A5018335774","display_name":"Johannes Spazier","orcid":null},"institutions":[{"id":"https://openalex.org/I176453806","display_name":"University of Potsdam","ror":"https://ror.org/03bnmw459","country_code":"DE","type":"education","lineage":["https://openalex.org/I176453806"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Johannes Spazier","raw_affiliation_strings":["University of Potsdam, Germany"],"affiliations":[{"raw_affiliation_string":"University of Potsdam, Germany","institution_ids":["https://openalex.org/I176453806"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5022420494","display_name":"Steffen Christgau","orcid":"https://orcid.org/0000-0002-8702-8422"},"institutions":[{"id":"https://openalex.org/I176453806","display_name":"University of Potsdam","ror":"https://ror.org/03bnmw459","country_code":"DE","type":"education","lineage":["https://openalex.org/I176453806"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Steffen Christgau","raw_affiliation_strings":["University of Potsdam, Germany"],"affiliations":[{"raw_affiliation_string":"University of Potsdam, Germany","institution_ids":["https://openalex.org/I176453806"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5044374029","display_name":"Bettina Schnor","orcid":"https://orcid.org/0000-0001-7369-8057"},"institutions":[{"id":"https://openalex.org/I176453806","display_name":"University of Potsdam","ror":"https://ror.org/03bnmw459","country_code":"DE","type":"education","lineage":["https://openalex.org/I176453806"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Bettina Schnor","raw_affiliation_strings":["University of Potsdam, Germany"],"affiliations":[{"raw_affiliation_string":"University of Potsdam, Germany","institution_ids":["https://openalex.org/I176453806"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5018335774"],"corresponding_institution_ids":["https://openalex.org/I176453806"],"apc_list":null,"apc_paid":null,"fwci":0.946,"has_fulltext":false,"cited_by_count":5,"citation_normalized_percentile":{"value":0.73518902,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"47","last_page":"54"},"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.9998000264167786,"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.9998000264167786,"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/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9991000294685364,"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/T10904","display_name":"Embedded Systems Design Techniques","score":0.9944000244140625,"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.8951988220214844},{"id":"https://openalex.org/keywords/stencil","display_name":"Stencil","score":0.8641931414604187},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.7768956422805786},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.7493711709976196},{"id":"https://openalex.org/keywords/speedup","display_name":"Speedup","score":0.7017776966094971},{"id":"https://openalex.org/keywords/matlab","display_name":"MATLAB","score":0.6257244348526001},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.5995872616767883},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5569015741348267},{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.4474489688873291},{"id":"https://openalex.org/keywords/parallelism","display_name":"Parallelism (grammar)","score":0.44302308559417725},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3624826967716217},{"id":"https://openalex.org/keywords/computer-architecture","display_name":"Computer architecture","score":0.352450966835022},{"id":"https://openalex.org/keywords/computational-science","display_name":"Computational science","score":0.2712042033672333},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.13000589609146118},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.0788169801235199}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8951988220214844},{"id":"https://openalex.org/C76752949","wikidata":"https://www.wikidata.org/wiki/Q7607499","display_name":"Stencil","level":2,"score":0.8641931414604187},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.7768956422805786},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.7493711709976196},{"id":"https://openalex.org/C68339613","wikidata":"https://www.wikidata.org/wiki/Q1549489","display_name":"Speedup","level":2,"score":0.7017776966094971},{"id":"https://openalex.org/C2780365114","wikidata":"https://www.wikidata.org/wiki/Q169478","display_name":"MATLAB","level":2,"score":0.6257244348526001},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.5995872616767883},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5569015741348267},{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.4474489688873291},{"id":"https://openalex.org/C2781172179","wikidata":"https://www.wikidata.org/wiki/Q853109","display_name":"Parallelism (grammar)","level":2,"score":0.44302308559417725},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3624826967716217},{"id":"https://openalex.org/C118524514","wikidata":"https://www.wikidata.org/wiki/Q173212","display_name":"Computer architecture","level":1,"score":0.352450966835022},{"id":"https://openalex.org/C459310","wikidata":"https://www.wikidata.org/wiki/Q117801","display_name":"Computational science","level":1,"score":0.2712042033672333},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.13000589609146118},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0788169801235199},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2935323.2935329","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2935323.2935329","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 3rd ACM SIGPLAN International Workshop on Libraries, Languages, and Compilers for Array Programming","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":11,"referenced_works":["https://openalex.org/W216026251","https://openalex.org/W1163324558","https://openalex.org/W1600865161","https://openalex.org/W1891842933","https://openalex.org/W1992851788","https://openalex.org/W2002871272","https://openalex.org/W2111354435","https://openalex.org/W2267343865","https://openalex.org/W2400593953","https://openalex.org/W2432215402","https://openalex.org/W4255468259"],"related_works":["https://openalex.org/W2778498407","https://openalex.org/W650988184","https://openalex.org/W2162410319","https://openalex.org/W2137356287","https://openalex.org/W4321184925","https://openalex.org/W2255990315","https://openalex.org/W60915090","https://openalex.org/W4321496380","https://openalex.org/W2025840053","https://openalex.org/W2161692994"],"abstract_inverted_index":{"High-level":[0],"programming":[1],"languages":[2,27],"such":[3],"as":[4],"MATLAB":[5,65,91],"are":[6,21],"widely":[7],"used":[8],"in":[9,25],"scientific":[10],"domains":[11],"to":[12,28,39,48,51],"implement":[13],"prototypes":[14,20],"based":[15],"on":[16],"mathematical":[17],"models.":[18],"These":[19],"finally":[22],"often":[23],"re-implemented":[24],"low-level":[26],"reach":[29],"execution":[30],"times":[31],"required":[32],"for":[33,72,103],"the":[34,52,82,120,123,136,140,143],"operational":[35],"use.":[36],"In":[37],"order":[38],"exploit":[40],"latest":[41],"hardware":[42],"architectures":[43],"additional":[44],"effort":[45],"is":[46,101],"necessary":[47],"add":[49],"parallelism":[50],"applications.":[53],"This":[54],"paper":[55],"presents":[56],"performance":[57,97,141],"results":[58],"of":[59,135,142],"an":[60],"automatic":[61],"translation":[62],"from":[63,90],"a":[64,112,116],"subset":[66],"into":[67],"efficient":[68],"parallelized":[69],"C":[70],"code":[71,89,126,134],"different":[73,109],"architectures:":[74],"multicores,":[75],"compute":[76],"clusters,":[77],"and":[78,93,115],"GPGPUs.":[79],"We":[80],"present":[81],"first":[83],"compiler":[84],"that":[85],"generates":[86],"native":[87],"MPI":[88],"source":[92],"thereby":[94],"showing":[95],"significant":[96],"improvements.":[98],"The":[99,131],"evaluation":[100],"done":[102],"two":[104],"stencil":[105],"applications":[106],"which":[107],"use":[108],"communication":[110],"patterns,":[111],"Game-of-Life":[113,121],"application":[114],"Tsunami":[117,137],"simulation.":[118],"For":[119],"application,":[122],"generated":[124,132],"parallel":[125,133,145],"shows":[127],"nearly":[128],"optimal":[129],"speedup.":[130],"simulation":[138],"reaches":[139],"available":[144],"reference":[146],"implementations.":[147]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":2}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
