{"id":"https://openalex.org/W2000952465","doi":"https://doi.org/10.1145/1961204.1961205","title":"Refactoring using type constraints","display_name":"Refactoring using type constraints","publication_year":2011,"publication_date":"2011-04-01","ids":{"openalex":"https://openalex.org/W2000952465","doi":"https://doi.org/10.1145/1961204.1961205","mag":"2000952465"},"language":"en","primary_location":{"id":"doi:10.1145/1961204.1961205","is_oa":true,"landing_page_url":"https://doi.org/10.1145/1961204.1961205","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/1961204.1961205","source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"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 Programming Languages and Systems","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://dl.acm.org/doi/pdf/10.1145/1961204.1961205","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5087594876","display_name":"Frank Tip","orcid":"https://orcid.org/0000-0002-1862-3498"},"institutions":[{"id":"https://openalex.org/I4210114115","display_name":"IBM Research - Thomas J. Watson Research Center","ror":"https://ror.org/0265w5591","country_code":"US","type":"facility","lineage":["https://openalex.org/I1341412227","https://openalex.org/I4210114115"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Frank Tip","raw_affiliation_strings":["IBM T. J. Watson Research Center, Yorktown Heights, NY","IBM -- T. J. Watson Research Center, Yorktown Heights, NY"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"IBM T. J. Watson Research Center, Yorktown Heights, NY","institution_ids":["https://openalex.org/I4210114115"]},{"raw_affiliation_string":"IBM -- T. J. Watson Research Center, Yorktown Heights, NY","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5074598360","display_name":"Robert M. Fuhrer","orcid":null},"institutions":[{"id":"https://openalex.org/I4210114115","display_name":"IBM Research - Thomas J. Watson Research Center","ror":"https://ror.org/0265w5591","country_code":"US","type":"facility","lineage":["https://openalex.org/I1341412227","https://openalex.org/I4210114115"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Robert M. Fuhrer","raw_affiliation_strings":["IBM T. J. Watson Research Center, Yorktown Heights, NY","IBM -- T. J. Watson Research Center, Yorktown Heights, NY"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"IBM T. J. Watson Research Center, Yorktown Heights, NY","institution_ids":["https://openalex.org/I4210114115"]},{"raw_affiliation_string":"IBM -- T. J. Watson Research Center, Yorktown Heights, NY","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5019170764","display_name":"Adam Kie\u017cun","orcid":"https://orcid.org/0000-0002-6634-1073"},"institutions":[{"id":"https://openalex.org/I1283280774","display_name":"Brigham and Women's Hospital","ror":"https://ror.org/04b6nzv94","country_code":"US","type":"healthcare","lineage":["https://openalex.org/I1283280774","https://openalex.org/I48633490"]},{"id":"https://openalex.org/I136199984","display_name":"Harvard University","ror":"https://ror.org/03vek6s52","country_code":"US","type":"education","lineage":["https://openalex.org/I136199984"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Adam Kie\u017cun","raw_affiliation_strings":["Brigham and Women's Hospital/Harvard Medical School, Boston, MA","Brigham and Women's Hospital Harvard Medical School, Boston, MA;"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Brigham and Women's Hospital/Harvard Medical School, Boston, MA","institution_ids":["https://openalex.org/I1283280774","https://openalex.org/I136199984"]},{"raw_affiliation_string":"Brigham and Women's Hospital Harvard Medical School, Boston, MA;","institution_ids":["https://openalex.org/I1283280774"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5032068969","display_name":"Michael D. Ernst","orcid":"https://orcid.org/0000-0001-9379-277X"},"institutions":[{"id":"https://openalex.org/I201448701","display_name":"University of Washington","ror":"https://ror.org/00cvxb145","country_code":"US","type":"education","lineage":["https://openalex.org/I201448701"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Michael D. Ernst","raw_affiliation_strings":["University of Washington, Seattle WA","University Of Washington (Seattle, WA)"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Washington, Seattle WA","institution_ids":["https://openalex.org/I201448701"]},{"raw_affiliation_string":"University Of Washington (Seattle, WA)","institution_ids":["https://openalex.org/I201448701"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5032293396","display_name":"Ittai Balaban","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Ittai Balaban","raw_affiliation_strings":["World Evolved Services, New York, NY"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"World Evolved Services, New York, NY","institution_ids":[]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5090947977","display_name":"Bjorn De Sutter","orcid":"https://orcid.org/0000-0003-0317-2089"},"institutions":[{"id":"https://openalex.org/I13469542","display_name":"Vrije Universiteit Brussel","ror":"https://ror.org/006e5kg04","country_code":"BE","type":"education","lineage":["https://openalex.org/I13469542"]},{"id":"https://openalex.org/I32597200","display_name":"Ghent University","ror":"https://ror.org/00cv9y106","country_code":"BE","type":"education","lineage":["https://openalex.org/I32597200"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Bjorn De Sutter","raw_affiliation_strings":["Ghent University and Vrije Universiteit Brussel, Gent, Belgium","Ghent University and Vrije Universiteit Brussel, Gent, Belgium#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Ghent University and Vrije Universiteit Brussel, Gent, Belgium","institution_ids":["https://openalex.org/I13469542","https://openalex.org/I32597200"]},{"raw_affiliation_string":"Ghent University and Vrije Universiteit Brussel, Gent, Belgium#TAB#","institution_ids":["https://openalex.org/I13469542"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":6,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":20.6317,"has_fulltext":true,"cited_by_count":66,"citation_normalized_percentile":{"value":0.99136179,"is_in_top_1_percent":true,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":100},"biblio":{"volume":"33","issue":"3","first_page":"1","last_page":"47"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9998999834060669,"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"}},"topics":[{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9998999834060669,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9988999962806702,"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"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9957000017166138,"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/code-refactoring","display_name":"Code refactoring","score":0.9486030340194702},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8277957439422607},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.7863180637359619},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.7311129570007324},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.7092955112457275},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6356631517410278},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.5496007204055786},{"id":"https://openalex.org/keywords/constraint","display_name":"Constraint (computer-aided design)","score":0.514141857624054},{"id":"https://openalex.org/keywords/eclipse","display_name":"Eclipse","score":0.49592098593711853},{"id":"https://openalex.org/keywords/class","display_name":"Class (philosophy)","score":0.46969059109687805},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.4631155729293823},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.4351264238357544},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.43448707461357117},{"id":"https://openalex.org/keywords/basis","display_name":"Basis (linear algebra)","score":0.42487403750419617},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.1756308376789093},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.14148357510566711},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.13332119584083557}],"concepts":[{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.9486030340194702},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8277957439422607},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.7863180637359619},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.7311129570007324},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.7092955112457275},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6356631517410278},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.5496007204055786},{"id":"https://openalex.org/C2776036281","wikidata":"https://www.wikidata.org/wiki/Q48769818","display_name":"Constraint (computer-aided design)","level":2,"score":0.514141857624054},{"id":"https://openalex.org/C2778505590","wikidata":"https://www.wikidata.org/wiki/Q141022","display_name":"Eclipse","level":2,"score":0.49592098593711853},{"id":"https://openalex.org/C2777212361","wikidata":"https://www.wikidata.org/wiki/Q5127848","display_name":"Class (philosophy)","level":2,"score":0.46969059109687805},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.4631155729293823},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.4351264238357544},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.43448707461357117},{"id":"https://openalex.org/C12426560","wikidata":"https://www.wikidata.org/wiki/Q189569","display_name":"Basis (linear algebra)","level":2,"score":0.42487403750419617},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.1756308376789093},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.14148357510566711},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.13332119584083557},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C1276947","wikidata":"https://www.wikidata.org/wiki/Q333","display_name":"Astronomy","level":1,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1961204.1961205","is_oa":true,"landing_page_url":"https://doi.org/10.1145/1961204.1961205","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/1961204.1961205","source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"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 Programming Languages and Systems","raw_type":"journal-article"},{"id":"pmh:oai:archive.ugent.be:2006632","is_oa":false,"landing_page_url":"http://hdl.handle.net/1854/LU-2006632","pdf_url":null,"source":{"id":"https://openalex.org/S4306400478","display_name":"Ghent University Academic Bibliography (Ghent University)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I32597200","host_organization_name":"Ghent University","host_organization_lineage":["https://openalex.org/I32597200"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"ISSN: 0164-0925","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"doi:10.1145/1961204.1961205","is_oa":true,"landing_page_url":"https://doi.org/10.1145/1961204.1961205","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/1961204.1961205","source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"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 Programming Languages and Systems","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G2427813900","display_name":null,"funder_award_id":"NBCH30390004","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"}],"funders":[{"id":"https://openalex.org/F4320327336","display_name":"Vlaamse regering","ror":null},{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"},{"id":"https://openalex.org/F4320332815","display_name":"Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2000952465.pdf","grobid_xml":"https://content.openalex.org/works/W2000952465.grobid-xml"},"referenced_works_count":35,"referenced_works":["https://openalex.org/W36134198","https://openalex.org/W50561030","https://openalex.org/W194677851","https://openalex.org/W1487664366","https://openalex.org/W1491579163","https://openalex.org/W1493688518","https://openalex.org/W1498770298","https://openalex.org/W1521332670","https://openalex.org/W1532892735","https://openalex.org/W1533004102","https://openalex.org/W1545985476","https://openalex.org/W1608862494","https://openalex.org/W1847665756","https://openalex.org/W1964973627","https://openalex.org/W1972064644","https://openalex.org/W1972445726","https://openalex.org/W2008059648","https://openalex.org/W2014530617","https://openalex.org/W2017785995","https://openalex.org/W2030793354","https://openalex.org/W2031246684","https://openalex.org/W2081365411","https://openalex.org/W2096012235","https://openalex.org/W2097302885","https://openalex.org/W2108690834","https://openalex.org/W2109783046","https://openalex.org/W2109859526","https://openalex.org/W2115694885","https://openalex.org/W2144777691","https://openalex.org/W2153887189","https://openalex.org/W2171383742","https://openalex.org/W2278011425","https://openalex.org/W6629538277","https://openalex.org/W6629724254","https://openalex.org/W6806595813"],"related_works":["https://openalex.org/W2376156947","https://openalex.org/W4206918066","https://openalex.org/W2606260126","https://openalex.org/W1836373119","https://openalex.org/W2076653850","https://openalex.org/W3130884665","https://openalex.org/W2949482260","https://openalex.org/W4296000674","https://openalex.org/W4287632524","https://openalex.org/W2144952376"],"abstract_inverted_index":{"Type":[0,21],"constraints":[1,22,43,61],"express":[2],"subtype":[3],"relationships":[4,14],"between":[5],"the":[6,48,77,126],"types":[7,112],"of":[8,59,100,108,129],"program":[9,67],"expressions,":[10],"for":[11,18,30,50,110],"example,":[12],"those":[13],"that":[15,79,90,95],"are":[16,131],"required":[17],"type":[19,32,35,42,60,121],"correctness.":[20],"were":[23],"originally":[24],"proposed":[25],"as":[26,47],"a":[27,57,65,106],"convenient":[28],"framework":[29],"solving":[31],"checking":[33],"and":[34,89,113],"inference":[36],"problems.":[37],"This":[38],"paper":[39],"shows":[40],"how":[41,105],"can":[44,116],"be":[45,117],"used":[46],"basis":[49],"practical":[51],"refactoring":[52],"tools.":[53],"In":[54],"our":[55,74,134],"approach,":[56],"set":[58],"is":[62,76],"derived":[63],"from":[64],"type-correct":[66],"P":[68,80,101],".":[69,102],"The":[70],"main":[71],"insight":[72],"behind":[73],"work":[75],"fact":[78],"constitutes":[81],"just":[82],"one":[83],"solution":[84],"to":[85,97],"this":[86],"constraint":[87],"system,":[88],"alternative":[91],"solutions":[92],"may":[93],"exist":[94],"correspond":[96],"refactored":[98],"versions":[99],"We":[103],"show":[104],"number":[107],"refactorings":[109,124],"manipulating":[111],"class":[114],"hierarchies":[115],"expressed":[118],"naturally":[119],"using":[120],"constraints.":[122],"Several":[123],"in":[125],"standard":[127],"distribution":[128],"Eclipse":[130],"based":[132],"on":[133],"work.":[135]},"counts_by_year":[{"year":2025,"cited_by_count":4},{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":4},{"year":2021,"cited_by_count":3},{"year":2020,"cited_by_count":5},{"year":2019,"cited_by_count":4},{"year":2018,"cited_by_count":4},{"year":2017,"cited_by_count":4},{"year":2016,"cited_by_count":2},{"year":2015,"cited_by_count":3},{"year":2014,"cited_by_count":2},{"year":2013,"cited_by_count":13},{"year":2012,"cited_by_count":11}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
