{"id":"https://openalex.org/W2040863504","doi":"https://doi.org/10.1145/1278349.1278353","title":"A practical dynamic single assignment transformation","display_name":"A practical dynamic single assignment transformation","publication_year":2007,"publication_date":"2007-09-01","ids":{"openalex":"https://openalex.org/W2040863504","doi":"https://doi.org/10.1145/1278349.1278353","mag":"2040863504"},"language":"en","primary_location":{"id":"doi:10.1145/1278349.1278353","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1278349.1278353","pdf_url":null,"source":{"id":"https://openalex.org/S105046310","display_name":"ACM Transactions on Design Automation of Electronic Systems","issn_l":"1084-4309","issn":["1084-4309","1557-7309"],"is_oa":false,"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":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Design Automation of Electronic Systems","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://lirias.kuleuven.be/handle/123456789/146589","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5014768003","display_name":"Karolien Vanbroekhoven","orcid":"https://orcid.org/0000-0003-1173-6497"},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]}],"countries":["BE"],"is_corresponding":true,"raw_author_name":"Peter Vanbroekhoven","raw_affiliation_strings":["K. U. Leuven, Belgium","K U Leuven, Belgium#TAB#"],"affiliations":[{"raw_affiliation_string":"K. U. Leuven, Belgium","institution_ids":["https://openalex.org/I99464096"]},{"raw_affiliation_string":"K U Leuven, Belgium#TAB#","institution_ids":["https://openalex.org/I99464096"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5084545304","display_name":"Gerda Janssens","orcid":null},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Gerda Janssens","raw_affiliation_strings":["K. U. Leuven, Belgium","K U Leuven, Belgium#TAB#"],"affiliations":[{"raw_affiliation_string":"K. U. Leuven, Belgium","institution_ids":["https://openalex.org/I99464096"]},{"raw_affiliation_string":"K U Leuven, Belgium#TAB#","institution_ids":["https://openalex.org/I99464096"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5004343076","display_name":"Maurice Bruynooghe","orcid":"https://orcid.org/0000-0002-6881-1462"},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Maurice Bruynooghe","raw_affiliation_strings":["K. U. Leuven, Belgium","K U Leuven, Belgium#TAB#"],"affiliations":[{"raw_affiliation_string":"K. U. Leuven, Belgium","institution_ids":["https://openalex.org/I99464096"]},{"raw_affiliation_string":"K U Leuven, Belgium#TAB#","institution_ids":["https://openalex.org/I99464096"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5033235745","display_name":"Francky Catthoor","orcid":"https://orcid.org/0000-0002-3599-8515"},"institutions":[{"id":"https://openalex.org/I4210114974","display_name":"IMEC","ror":"https://ror.org/02kcbn207","country_code":"BE","type":"nonprofit","lineage":["https://openalex.org/I4210114974"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Francky Catthoor","raw_affiliation_strings":["Interuniversity Micro-Electronics Center, Belgium"],"affiliations":[{"raw_affiliation_string":"Interuniversity Micro-Electronics Center, Belgium","institution_ids":["https://openalex.org/I4210114974"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5014768003"],"corresponding_institution_ids":["https://openalex.org/I99464096"],"apc_list":null,"apc_paid":null,"fwci":1.5913,"has_fulltext":false,"cited_by_count":22,"citation_normalized_percentile":{"value":0.83618792,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":"12","issue":"4","first_page":"40","last_page":"40"},"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.9998999834060669,"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.9998999834060669,"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/T10904","display_name":"Embedded Systems Design Techniques","score":0.9987000226974487,"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/T10126","display_name":"Logic, programming, and type systems","score":0.998199999332428,"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.9137568473815918},{"id":"https://openalex.org/keywords/pointer","display_name":"Pointer (user interface)","score":0.7431756258010864},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.6834710836410522},{"id":"https://openalex.org/keywords/transformation","display_name":"Transformation (genetics)","score":0.5922269821166992},{"id":"https://openalex.org/keywords/data-flow-analysis","display_name":"Data-flow analysis","score":0.5580376982688904},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.5508237481117249},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.4988977909088135},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.46727263927459717},{"id":"https://openalex.org/keywords/program-optimization","display_name":"Program optimization","score":0.4596234858036041},{"id":"https://openalex.org/keywords/construct","display_name":"Construct (python library)","score":0.45602720975875854},{"id":"https://openalex.org/keywords/variable","display_name":"Variable (mathematics)","score":0.4514427185058594},{"id":"https://openalex.org/keywords/static-analysis","display_name":"Static analysis","score":0.4331783652305603},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.4233059883117676},{"id":"https://openalex.org/keywords/data-structure","display_name":"Data structure","score":0.41030097007751465},{"id":"https://openalex.org/keywords/data-flow-diagram","display_name":"Data flow diagram","score":0.36853086948394775},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.35938718914985657},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.28395044803619385},{"id":"https://openalex.org/keywords/computer-hardware","display_name":"Computer hardware","score":0.1102583110332489},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.08963072299957275}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9137568473815918},{"id":"https://openalex.org/C150202949","wikidata":"https://www.wikidata.org/wiki/Q107602","display_name":"Pointer (user interface)","level":2,"score":0.7431756258010864},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.6834710836410522},{"id":"https://openalex.org/C204241405","wikidata":"https://www.wikidata.org/wiki/Q461499","display_name":"Transformation (genetics)","level":3,"score":0.5922269821166992},{"id":"https://openalex.org/C88468194","wikidata":"https://www.wikidata.org/wiki/Q1172416","display_name":"Data-flow analysis","level":3,"score":0.5580376982688904},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.5508237481117249},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.4988977909088135},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.46727263927459717},{"id":"https://openalex.org/C139571649","wikidata":"https://www.wikidata.org/wiki/Q1156793","display_name":"Program optimization","level":3,"score":0.4596234858036041},{"id":"https://openalex.org/C2780801425","wikidata":"https://www.wikidata.org/wiki/Q5164392","display_name":"Construct (python library)","level":2,"score":0.45602720975875854},{"id":"https://openalex.org/C182365436","wikidata":"https://www.wikidata.org/wiki/Q50701","display_name":"Variable (mathematics)","level":2,"score":0.4514427185058594},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.4331783652305603},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4233059883117676},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.41030097007751465},{"id":"https://openalex.org/C489000","wikidata":"https://www.wikidata.org/wiki/Q747385","display_name":"Data flow diagram","level":2,"score":0.36853086948394775},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.35938718914985657},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.28395044803619385},{"id":"https://openalex.org/C9390403","wikidata":"https://www.wikidata.org/wiki/Q3966","display_name":"Computer hardware","level":1,"score":0.1102583110332489},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.08963072299957275},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","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},{"id":"https://openalex.org/C185592680","wikidata":"https://www.wikidata.org/wiki/Q2329","display_name":"Chemistry","level":0,"score":0.0},{"id":"https://openalex.org/C104317684","wikidata":"https://www.wikidata.org/wiki/Q7187","display_name":"Gene","level":2,"score":0.0},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.0},{"id":"https://openalex.org/C55493867","wikidata":"https://www.wikidata.org/wiki/Q7094","display_name":"Biochemistry","level":1,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/1278349.1278353","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1278349.1278353","pdf_url":null,"source":{"id":"https://openalex.org/S105046310","display_name":"ACM Transactions on Design Automation of Electronic Systems","issn_l":"1084-4309","issn":["1084-4309","1557-7309"],"is_oa":false,"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":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Design Automation of Electronic Systems","raw_type":"journal-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.68.2455","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.68.2455","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.kuleuven.be/~dtai/publications/files/42627.pdf","raw_type":"text"},{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/146589","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/146589","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"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":"ACM Transactions on Design Automation of Electronic Systems, vol. 12 (4), Art.No. ARTN 40, (1-12)","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/146589","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/146589","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"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":"ACM Transactions on Design Automation of Electronic Systems, vol. 12 (4), Art.No. ARTN 40, (1-12)","raw_type":"info:eu-repo/semantics/publishedVersion"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":28,"referenced_works":["https://openalex.org/W27004794","https://openalex.org/W40192171","https://openalex.org/W1481726796","https://openalex.org/W1491178396","https://openalex.org/W1510196500","https://openalex.org/W1557064363","https://openalex.org/W1737297434","https://openalex.org/W1982205631","https://openalex.org/W1990087033","https://openalex.org/W1994115836","https://openalex.org/W2002252837","https://openalex.org/W2010706208","https://openalex.org/W2013981372","https://openalex.org/W2019048425","https://openalex.org/W2034674049","https://openalex.org/W2078738604","https://openalex.org/W2079092669","https://openalex.org/W2097699872","https://openalex.org/W2140837302","https://openalex.org/W2141735009","https://openalex.org/W2152161767","https://openalex.org/W2294743625","https://openalex.org/W2340604309","https://openalex.org/W2561675875","https://openalex.org/W4210409048","https://openalex.org/W4213154760","https://openalex.org/W4234407207","https://openalex.org/W4244731564"],"related_works":["https://openalex.org/W2110281220","https://openalex.org/W4200028969","https://openalex.org/W2097653851","https://openalex.org/W1557064363","https://openalex.org/W2127929122","https://openalex.org/W4285814480","https://openalex.org/W4251477416","https://openalex.org/W2140468016","https://openalex.org/W2472218294","https://openalex.org/W2040863504"],"abstract_inverted_index":{"This":[0],"paper":[1],"presents":[2],"a":[3,8,68,82,125],"novel":[4],"method":[5,89,137,160],"to":[6,100],"construct":[7],"dynamic":[9],"single":[10],"assignment":[11],"(DSA)":[12],"form":[13,25],"of":[14,32,61,85,127,130,146,151],"array":[15,35],"intensive,":[16],"pointer":[17],"free":[18],"C":[19],"programs.":[20,62,87],"A":[21],"program":[22,121],"in":[23,143,157,172],"DSA":[24,47,66,114],"does":[26],"not":[27],"perform":[28,67],"any":[29],"destructive":[30],"update":[31],"scalars":[33],"and":[34,59,77,123,138,149,164],"elements;":[36],"that":[37,104,156,165],"is,":[38],"each":[39],"element":[40],"is":[41,140],"written":[42],"at":[43],"most":[44],"once.":[45],"As":[46],"makes":[48],"the":[49,93,101,136,144,159],"dependencies":[50],"between":[51],"variable":[52],"references":[53],"explicit,":[54],"it":[55,105,139],"facilitates":[56],"complex":[57,69],"analyses":[58],"optimizations":[60],"Existing":[63],"transformations":[64],"into":[65],"data":[70,94,109],"flow":[71,95,110],"analysis":[72,75],"with":[73,119],"exponential":[74],"time,":[76],"they":[78,174],"work":[79],"only":[80],"for":[81],"limited":[83],"class":[84],"input":[86],"Our":[88],"removes":[90],"irregularities":[91],"from":[92],"by":[96],"adding":[97],"copy":[98,167],"assignments":[99],"program,":[102],"so":[103],"can":[106,169],"use":[107],"simple":[108],"analyses.":[111],"The":[112],"presented":[113],"transformation":[115],"scales":[116,161],"very":[117],"well":[118,162],"growing":[120],"sizes":[122],"overcomes":[124],"number":[126],"important":[128],"limitations":[129],"existing":[131],"methods.":[132],"We":[133],"have":[134],"implemented":[135],"being":[141],"used":[142],"context":[145],"memory":[147],"optimization":[148],"verification":[150],"those":[152],"optimizations.":[153],"Experiments":[154],"show":[155],"practice,":[158],"indeed,":[163],"added":[166],"operations":[168],"be":[170],"removed":[171],"case":[173],"are":[175],"unwanted.":[176]},"counts_by_year":[{"year":2025,"cited_by_count":3},{"year":2024,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":1},{"year":2016,"cited_by_count":3},{"year":2012,"cited_by_count":5}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
