{"id":"https://openalex.org/W2911593804","doi":"https://doi.org/10.1145/3302516.3307357","title":"Revec: program rejuvenation through revectorization","display_name":"Revec: program rejuvenation through revectorization","publication_year":2019,"publication_date":"2019-02-14","ids":{"openalex":"https://openalex.org/W2911593804","doi":"https://doi.org/10.1145/3302516.3307357","mag":"2911593804"},"language":"en","primary_location":{"id":"doi:10.1145/3302516.3307357","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3302516.3307357","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3302516.3307357","source":null,"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 28th International Conference on Compiler Construction","raw_type":"proceedings-article"},"type":"article","indexed_in":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"gold","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3302516.3307357","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":null,"display_name":"Charith Mendis","orcid":null},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Charith Mendis","raw_affiliation_strings":["Massachusetts Institute of Technology, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Ajay Jain","orcid":null},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ajay Jain","raw_affiliation_strings":["Massachusetts Institute of Technology, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Paras Jain","orcid":null},"institutions":[{"id":"https://openalex.org/I95457486","display_name":"University of California, Berkeley","ror":"https://ror.org/01an7q238","country_code":"US","type":"education","lineage":["https://openalex.org/I95457486"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Paras Jain","raw_affiliation_strings":["University of California at Berkeley, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of California at Berkeley, USA","institution_ids":["https://openalex.org/I95457486"]}]},{"author_position":"last","author":{"id":null,"display_name":"Saman Amarasinghe","orcid":null},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Saman Amarasinghe","raw_affiliation_strings":["Massachusetts Institute of Technology, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":[],"corresponding_institution_ids":["https://openalex.org/I63966007"],"apc_list":null,"apc_paid":null,"fwci":1.481,"has_fulltext":true,"cited_by_count":12,"citation_normalized_percentile":{"value":0.79984808,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"29","last_page":"41"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":1.0,"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":1.0,"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/T11181","display_name":"Advanced Data Storage Technologies","score":0.9980000257492065,"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.9966999888420105,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/intrinsics","display_name":"Intrinsics","score":0.8191999793052673},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.7261999845504761},{"id":"https://openalex.org/keywords/exploit","display_name":"Exploit","score":0.6615999937057495},{"id":"https://openalex.org/keywords/retargeting","display_name":"Retargeting","score":0.5888000130653381},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.4765999913215637},{"id":"https://openalex.org/keywords/software-portability","display_name":"Software portability","score":0.446399986743927},{"id":"https://openalex.org/keywords/instruction-level-parallelism","display_name":"Instruction-level parallelism","score":0.35580000281333923},{"id":"https://openalex.org/keywords/parallelism","display_name":"Parallelism (grammar)","score":0.33640000224113464}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8227999806404114},{"id":"https://openalex.org/C2908650547","wikidata":"https://www.wikidata.org/wiki/Q20999234","display_name":"Intrinsics","level":2,"score":0.8191999793052673},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.7261999845504761},{"id":"https://openalex.org/C165696696","wikidata":"https://www.wikidata.org/wiki/Q11287","display_name":"Exploit","level":2,"score":0.6615999937057495},{"id":"https://openalex.org/C2780575108","wikidata":"https://www.wikidata.org/wiki/Q7316652","display_name":"Retargeting","level":2,"score":0.5888000130653381},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5388000011444092},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4986000061035156},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.4765999913215637},{"id":"https://openalex.org/C63000827","wikidata":"https://www.wikidata.org/wiki/Q3080428","display_name":"Software portability","level":2,"score":0.446399986743927},{"id":"https://openalex.org/C140763907","wikidata":"https://www.wikidata.org/wiki/Q2714055","display_name":"Instruction-level parallelism","level":3,"score":0.35580000281333923},{"id":"https://openalex.org/C2781172179","wikidata":"https://www.wikidata.org/wiki/Q853109","display_name":"Parallelism (grammar)","level":2,"score":0.33640000224113464},{"id":"https://openalex.org/C190902152","wikidata":"https://www.wikidata.org/wiki/Q1325106","display_name":"Optimizing compiler","level":3,"score":0.3328000009059906},{"id":"https://openalex.org/C185798385","wikidata":"https://www.wikidata.org/wiki/Q1161707","display_name":"Benchmark (surveying)","level":2,"score":0.3070000112056732},{"id":"https://openalex.org/C98045186","wikidata":"https://www.wikidata.org/wiki/Q205663","display_name":"Process (computing)","level":2,"score":0.302700012922287},{"id":"https://openalex.org/C61483411","wikidata":"https://www.wikidata.org/wiki/Q3124522","display_name":"Data parallelism","level":3,"score":0.2976999878883362},{"id":"https://openalex.org/C204241405","wikidata":"https://www.wikidata.org/wiki/Q461499","display_name":"Transformation (genetics)","level":3,"score":0.29089999198913574},{"id":"https://openalex.org/C139571649","wikidata":"https://www.wikidata.org/wiki/Q1156793","display_name":"Program optimization","level":3,"score":0.27309998869895935},{"id":"https://openalex.org/C128916667","wikidata":"https://www.wikidata.org/wiki/Q1343660","display_name":"Register allocation","level":3,"score":0.26919999718666077},{"id":"https://openalex.org/C158100120","wikidata":"https://www.wikidata.org/wiki/Q1931402","display_name":"ANSI C","level":3,"score":0.2687999904155731},{"id":"https://openalex.org/C202491316","wikidata":"https://www.wikidata.org/wiki/Q272683","display_name":"Instruction set","level":2,"score":0.26600000262260437},{"id":"https://openalex.org/C19024347","wikidata":"https://www.wikidata.org/wiki/Q211496","display_name":"High-level programming language","level":3,"score":0.26579999923706055},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.25459998846054077}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3302516.3307357","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3302516.3307357","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3302516.3307357","source":null,"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 28th International Conference on Compiler Construction","raw_type":"proceedings-article"},{"id":"pmh:oai:arXiv.org:1902.02816","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1902.02816","pdf_url":"https://arxiv.org/pdf/1902.02816","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"}],"best_oa_location":{"id":"doi:10.1145/3302516.3307357","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3302516.3307357","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3302516.3307357","source":null,"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 28th International Conference on Compiler Construction","raw_type":"proceedings-article"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G1341569928","display_name":"XPS: FULL: DSD: Scalable High Performance with Halide and Simit Domain Specific Languages","funder_award_id":"1533753","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G4932736549","display_name":null,"funder_award_id":"DE-SC0018121","funder_id":"https://openalex.org/F4320306084","funder_display_name":"U.S. Department of Energy"},{"id":"https://openalex.org/G6650245637","display_name":null,"funder_award_id":"HR0011-18-3-0007","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G6900561757","display_name":null,"funder_award_id":"CCF-1533753","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G8073515163","display_name":null,"funder_award_id":"DE-SC0008923","funder_id":"https://openalex.org/F4320337506","funder_display_name":"Advanced Scientific Computing Research"},{"id":"https://openalex.org/G8839178245","display_name":null,"funder_award_id":"DE-SC0008923","funder_id":"https://openalex.org/F4320306084","funder_display_name":"U.S. Department of Energy"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320306084","display_name":"U.S. Department of Energy","ror":"https://ror.org/01bj3aw27"},{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"},{"id":"https://openalex.org/F4320332359","display_name":"Office of Science","ror":"https://ror.org/00mmn6b08"},{"id":"https://openalex.org/F4320337506","display_name":"Advanced Scientific Computing Research","ror":"https://ror.org/0012c7r22"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2911593804.pdf","grobid_xml":"https://content.openalex.org/works/W2911593804.grobid-xml"},"referenced_works_count":22,"referenced_works":["https://openalex.org/W1791987072","https://openalex.org/W1966691503","https://openalex.org/W2010452422","https://openalex.org/W2013156670","https://openalex.org/W2018641575","https://openalex.org/W2069504277","https://openalex.org/W2096496252","https://openalex.org/W2099404643","https://openalex.org/W2111394443","https://openalex.org/W2114368073","https://openalex.org/W2118031182","https://openalex.org/W2128985333","https://openalex.org/W2135736783","https://openalex.org/W2147423491","https://openalex.org/W2153185479","https://openalex.org/W2163000655","https://openalex.org/W2171641226","https://openalex.org/W2244555269","https://openalex.org/W2787850818","https://openalex.org/W3010855452","https://openalex.org/W4244894488","https://openalex.org/W4245517424"],"related_works":[],"abstract_inverted_index":{"Modern":[0,51],"microprocessors":[1],"are":[2,37,53],"equipped":[3],"with":[4],"Single":[5],"Instruction":[6],"Multiple":[7],"Data":[8],"(SIMD)":[9],"or":[10],"vector":[11,29,40,63,76,121],"instructions":[12,122],"which":[13,111],"expose":[14],"data":[15,85],"level":[16],"parallelism":[17,25],"at":[18,131],"a":[19,43,79,107],"fine":[20],"granularity.":[21],"Programmers":[22],"exploit":[23,83],"this":[24],"by":[26,116],"using":[27,39,75],"low-level":[28],"intrinsics":[30,41,77],"in":[31],"their":[32],"code.":[33,143],"However,":[34],"once":[35],"programs":[36],"written":[38],"of":[42,78,89,123,141],"specific":[44],"instruction":[45,64,91],"set,":[46],"the":[47,59,72,132],"code":[48,60,74,102],"becomes":[49],"non-portable.":[50],"compilers":[52],"unable":[54],"to":[55,61,69,82,119],"analyze":[56],"and":[57,87,98,137],"retarget":[58],"newer":[62,80,124],"sets.":[65,92],"Hence,":[66],"programmers":[67],"have":[68],"manually":[70],"rewrite":[71],"same":[73],"generation":[81],"higher":[84],"widths":[86],"capabilities":[88],"new":[90],"This":[93],"process":[94],"is":[95,128],"tedious,":[96],"error-prone":[97],"requires":[99],"maintaining":[100],"multiple":[101],"bases.":[103],"We":[104],"propose":[105],"Revec,":[106],"compiler":[108,133],"optimization":[109],"pass":[110],"revectorizes":[112],"already":[113],"vectorized":[114],"code,":[115],"retargeting":[117],"it":[118],"use":[120],"generations.":[125],"The":[126],"transformation":[127],"transparent,":[129],"happening":[130],"intermediate":[134],"representation":[135],"level,":[136],"enables":[138],"performance":[139],"portability":[140],"hand-vectorized":[142]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":2},{"year":2022,"cited_by_count":3},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":1}],"updated_date":"2026-05-12T08:28:47.272897","created_date":"2019-02-21T00:00:00"}
