{"id":"https://openalex.org/W4309468401","doi":"https://doi.org/10.1145/3571283","title":"Source Matching and Rewriting for MLIR Using String-Based Automata","display_name":"Source Matching and Rewriting for MLIR Using String-Based Automata","publication_year":2022,"publication_date":"2022-11-18","ids":{"openalex":"https://openalex.org/W4309468401","doi":"https://doi.org/10.1145/3571283"},"language":"en","primary_location":{"id":"doi:10.1145/3571283","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3571283","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3571283","source":{"id":"https://openalex.org/S26056741","display_name":"ACM Transactions on Architecture and Code Optimization","issn_l":"1544-3566","issn":["1544-3566","1544-3973"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Architecture and Code Optimization","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3571283","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5006918861","display_name":"Vin\u00edcius Couto Espindola","orcid":"https://orcid.org/0000-0002-3131-741X"},"institutions":[{"id":"https://openalex.org/I181391015","display_name":"Universidade Estadual de Campinas (UNICAMP)","ror":"https://ror.org/04wffgt70","country_code":"BR","type":"education","lineage":["https://openalex.org/I181391015"]}],"countries":["BR"],"is_corresponding":true,"raw_author_name":"Vinicius Espindola","raw_affiliation_strings":["Institute of Computing - UNICAMP, Campinas, Brazil"],"affiliations":[{"raw_affiliation_string":"Institute of Computing - UNICAMP, Campinas, Brazil","institution_ids":["https://openalex.org/I181391015"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5090102088","display_name":"Luciano Zago","orcid":"https://orcid.org/0000-0003-4417-163X"},"institutions":[{"id":"https://openalex.org/I181391015","display_name":"Universidade Estadual de Campinas (UNICAMP)","ror":"https://ror.org/04wffgt70","country_code":"BR","type":"education","lineage":["https://openalex.org/I181391015"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Luciano Zago","raw_affiliation_strings":["Institute of Computing - UNICAMP, Campinas, Brazil"],"affiliations":[{"raw_affiliation_string":"Institute of Computing - UNICAMP, Campinas, Brazil","institution_ids":["https://openalex.org/I181391015"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5066663156","display_name":"Herv\u00e9 Yviquel","orcid":"https://orcid.org/0000-0003-1214-3431"},"institutions":[{"id":"https://openalex.org/I181391015","display_name":"Universidade Estadual de Campinas (UNICAMP)","ror":"https://ror.org/04wffgt70","country_code":"BR","type":"education","lineage":["https://openalex.org/I181391015"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Herv\u00e9 Yviquel","raw_affiliation_strings":["Institute of Computing - UNICAMP, Campinas, Brazil"],"affiliations":[{"raw_affiliation_string":"Institute of Computing - UNICAMP, Campinas, Brazil","institution_ids":["https://openalex.org/I181391015"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5067675731","display_name":"Guido Ara\u00fajo","orcid":"https://orcid.org/0000-0003-4869-5190"},"institutions":[{"id":"https://openalex.org/I181391015","display_name":"Universidade Estadual de Campinas (UNICAMP)","ror":"https://ror.org/04wffgt70","country_code":"BR","type":"education","lineage":["https://openalex.org/I181391015"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Guido Araujo","raw_affiliation_strings":["Institute of Computing - UNICAMP, Campinas, Brazil"],"affiliations":[{"raw_affiliation_string":"Institute of Computing - UNICAMP, Campinas, Brazil","institution_ids":["https://openalex.org/I181391015"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5006918861"],"corresponding_institution_ids":["https://openalex.org/I181391015"],"apc_list":null,"apc_paid":null,"fwci":2.3184,"has_fulltext":true,"cited_by_count":11,"citation_normalized_percentile":{"value":0.88199095,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":96,"max":99},"biblio":{"volume":"20","issue":"2","first_page":"1","last_page":"26"},"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9965000152587891,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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/T10126","display_name":"Logic, programming, and type systems","score":0.9939000010490417,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"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.9052259922027588},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.8201877474784851},{"id":"https://openalex.org/keywords/rewriting","display_name":"Rewriting","score":0.671312153339386},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6371317505836487},{"id":"https://openalex.org/keywords/parsing","display_name":"Parsing","score":0.5726838111877441},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.548826277256012},{"id":"https://openalex.org/keywords/control-flow","display_name":"Control flow","score":0.5431079864501953},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.5280241370201111},{"id":"https://openalex.org/keywords/optimizing-compiler","display_name":"Optimizing compiler","score":0.5272300243377686},{"id":"https://openalex.org/keywords/dead-code-elimination","display_name":"Dead code elimination","score":0.5179656744003296},{"id":"https://openalex.org/keywords/automaton","display_name":"Automaton","score":0.4902971088886261},{"id":"https://openalex.org/keywords/abstract-syntax-tree","display_name":"Abstract syntax tree","score":0.48461636900901794},{"id":"https://openalex.org/keywords/pattern-matching","display_name":"Pattern matching","score":0.45472896099090576},{"id":"https://openalex.org/keywords/matching","display_name":"Matching (statistics)","score":0.447451114654541},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.43280163407325745},{"id":"https://openalex.org/keywords/control-flow-graph","display_name":"Control flow graph","score":0.4308006167411804},{"id":"https://openalex.org/keywords/object-code","display_name":"Object code","score":0.4242500960826874},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.42063167691230774},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.39811208844184875},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.36675959825515747},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.12378349900245667},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.10426446795463562}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9052259922027588},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.8201877474784851},{"id":"https://openalex.org/C154690210","wikidata":"https://www.wikidata.org/wiki/Q1668499","display_name":"Rewriting","level":2,"score":0.671312153339386},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6371317505836487},{"id":"https://openalex.org/C186644900","wikidata":"https://www.wikidata.org/wiki/Q194152","display_name":"Parsing","level":2,"score":0.5726838111877441},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.548826277256012},{"id":"https://openalex.org/C160191386","wikidata":"https://www.wikidata.org/wiki/Q868299","display_name":"Control flow","level":2,"score":0.5431079864501953},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.5280241370201111},{"id":"https://openalex.org/C190902152","wikidata":"https://www.wikidata.org/wiki/Q1325106","display_name":"Optimizing compiler","level":3,"score":0.5272300243377686},{"id":"https://openalex.org/C2144512","wikidata":"https://www.wikidata.org/wiki/Q1143090","display_name":"Dead code elimination","level":5,"score":0.5179656744003296},{"id":"https://openalex.org/C112505250","wikidata":"https://www.wikidata.org/wiki/Q787116","display_name":"Automaton","level":2,"score":0.4902971088886261},{"id":"https://openalex.org/C58646249","wikidata":"https://www.wikidata.org/wiki/Q127380","display_name":"Abstract syntax tree","level":3,"score":0.48461636900901794},{"id":"https://openalex.org/C68859911","wikidata":"https://www.wikidata.org/wiki/Q1503724","display_name":"Pattern matching","level":2,"score":0.45472896099090576},{"id":"https://openalex.org/C165064840","wikidata":"https://www.wikidata.org/wiki/Q1321061","display_name":"Matching (statistics)","level":2,"score":0.447451114654541},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.43280163407325745},{"id":"https://openalex.org/C27458966","wikidata":"https://www.wikidata.org/wiki/Q1187693","display_name":"Control flow graph","level":2,"score":0.4308006167411804},{"id":"https://openalex.org/C154526789","wikidata":"https://www.wikidata.org/wiki/Q157965","display_name":"Object code","level":4,"score":0.4242500960826874},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.42063167691230774},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.39811208844184875},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.36675959825515747},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.12378349900245667},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.10426446795463562},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3571283","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3571283","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3571283","source":{"id":"https://openalex.org/S26056741","display_name":"ACM Transactions on Architecture and Code Optimization","issn_l":"1544-3566","issn":["1544-3566","1544-3973"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Architecture and Code Optimization","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1145/3571283","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3571283","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3571283","source":{"id":"https://openalex.org/S26056741","display_name":"ACM Transactions on Architecture and Code Optimization","issn_l":"1544-3566","issn":["1544-3566","1544-3973"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Architecture and Code Optimization","raw_type":"journal-article"},"sustainable_development_goals":[{"score":0.6399999856948853,"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4"}],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4309468401.pdf","grobid_xml":"https://content.openalex.org/works/W4309468401.grobid-xml"},"referenced_works_count":39,"referenced_works":["https://openalex.org/W1491178396","https://openalex.org/W1517684295","https://openalex.org/W1583837637","https://openalex.org/W1843198456","https://openalex.org/W2010714123","https://openalex.org/W2010920360","https://openalex.org/W2057455870","https://openalex.org/W2059696856","https://openalex.org/W2070053315","https://openalex.org/W2073061372","https://openalex.org/W2102976251","https://openalex.org/W2136285318","https://openalex.org/W2154555766","https://openalex.org/W2168315159","https://openalex.org/W2244005500","https://openalex.org/W2412440871","https://openalex.org/W2421250929","https://openalex.org/W2789599444","https://openalex.org/W2891477368","https://openalex.org/W2954776426","https://openalex.org/W2997238241","https://openalex.org/W3002820667","https://openalex.org/W3008964021","https://openalex.org/W3034313155","https://openalex.org/W3090768939","https://openalex.org/W3099929288","https://openalex.org/W3100934400","https://openalex.org/W3114760331","https://openalex.org/W3121932930","https://openalex.org/W3122286897","https://openalex.org/W3129800153","https://openalex.org/W3155036733","https://openalex.org/W3175004880","https://openalex.org/W3197083970","https://openalex.org/W3205717712","https://openalex.org/W3213528054","https://openalex.org/W4246166885","https://openalex.org/W4281862314","https://openalex.org/W6778966719"],"related_works":["https://openalex.org/W1524758670","https://openalex.org/W4250715714","https://openalex.org/W2102229283","https://openalex.org/W1606793177","https://openalex.org/W2134984227","https://openalex.org/W2143964278","https://openalex.org/W3175817815","https://openalex.org/W1996886894","https://openalex.org/W2400781971","https://openalex.org/W2109064399"],"abstract_inverted_index":{"A":[0],"typical":[1],"compiler":[2,78,107],"flow":[3],"relies":[4],"on":[5,63,75,121],"a":[6,92,106,112,145],"uni-directional":[7],"sequence":[8],"of":[9],"translation/optimization":[10],"steps":[11],"that":[12,102,141,176],"lower":[13],"the":[14,31,43,125,133,150,158,170],"program":[15,24,50],"abstract":[16],"representation,":[17],"making":[18],"it":[19],"hard":[20],"to":[21,46,52,136,149,195,207],"preserve":[22],"higher-level":[23],"information":[25],"across":[26],"each":[27],"transformation":[28],"step.":[29],"On":[30],"other":[32],"hand,":[33],"modern":[34],"ISA":[35],"extensions":[36],"and":[37,48,89,100,167,185,216],"hardware":[38,217],"accelerators":[39],"can":[40,178],"benefit":[41],"from":[42,157,182],"compiler\u2019s":[44],"ability":[45],"detect":[47],"raise":[49],"idioms":[51,181],"acceleration":[53],"instructions":[54],"or":[55,80],"optimized":[56],"library":[57],"calls.":[58],"Although":[59],"recent":[60],"works":[61],"based":[62],"Multi-Level":[64],"IR":[65],"(MLIR)":[66],"have":[67,144,161],"been":[68],"proposed":[69],"for":[70,96],"code":[71,139,155,209],"raising,":[72],"they":[73],"rely":[74],"specialized":[76],"languages,":[77],"recompilation,":[79],"in-depth":[81],"dialect":[82],"knowledge.":[83],"This":[84],"article":[85],"presents":[86],"Source":[87],"Matching":[88],"Rewriting":[90],"(SMR),":[91],"user-oriented":[93],"source-code-based":[94],"approach":[95],"MLIR":[97],"idiom":[98,126,171],"matching":[99],"rewriting":[101],"does":[103],"not":[104,143],"require":[105],"expert\u2019s":[108],"intervention.":[109],"SMR":[110,177,206],"uses":[111],"two-phase":[113],"automaton-based":[114],"DAG-matching":[115],"algorithm":[116],"inspired":[117],"by":[118],"early":[119],"work":[120],"tree-pattern":[122],"matching.":[123],"First,":[124],"Control-Dependency":[127],"Graph":[128],"(CDG)":[129],"is":[130],"matched":[131,168],"against":[132,169],"program\u2019s":[134],"CDG":[135],"rule":[137],"out":[138],"fragments":[140,156],"do":[142],"control-flow":[146],"structure":[147],"similar":[148],"desired":[151],"idiom.":[152],"Second,":[153],"candidate":[154],"previous":[159],"phase":[160],"their":[162],"Data-Dependency":[163],"Graphs":[164],"(DDGs)":[165],"constructed":[166],"DDG.":[172],"Experimental":[173],"results":[174],"show":[175,201],"effectively":[179],"match":[180],"Fortran":[183],"(FIR)":[184],"C":[186],"(CIL)":[187],"programs":[188],"while":[189],"raising":[190],"them":[191],"as":[192],"BLAS":[193],"calls":[194],"improve":[196],"performance.":[197],"Additional":[198],"experiments":[199],"also":[200],"performance":[202],"improvements":[203],"when":[204],"using":[205],"enable":[208],"replacement":[210],"in":[211],"areas":[212],"like":[213],"approximate":[214],"computing":[215],"acceleration.":[218]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":6},{"year":2024,"cited_by_count":4}],"updated_date":"2026-03-27T05:58:40.876381","created_date":"2025-10-10T00:00:00"}
