{"id":"https://openalex.org/W2029753690","doi":"https://doi.org/10.1109/ase.2011.6100067","title":"Differential precondition checking: A lightweight, reusable analysis for refactoring tools","display_name":"Differential precondition checking: A lightweight, reusable analysis for refactoring tools","publication_year":2011,"publication_date":"2011-11-01","ids":{"openalex":"https://openalex.org/W2029753690","doi":"https://doi.org/10.1109/ase.2011.6100067","mag":"2029753690"},"language":"en","primary_location":{"id":"doi:10.1109/ase.2011.6100067","is_oa":false,"landing_page_url":"https://doi.org/10.1109/ase.2011.6100067","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"2011 26th IEEE/ACM International Conference on Automated Software Engineering (ASE 2011)","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/A5049637653","display_name":"Jeffrey Overbey","orcid":null},"institutions":[{"id":"https://openalex.org/I157725225","display_name":"University of Illinois Urbana-Champaign","ror":"https://ror.org/047426m28","country_code":"US","type":"education","lineage":["https://openalex.org/I157725225"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Jeffrey L. Overbey","raw_affiliation_strings":["Department of Computer Science, University of Illinois, Urbana-Champaign, USA","[Dept. of Computer Science, Univ. of Illinois at Urbana, Champaign, USA]"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, University of Illinois, Urbana-Champaign, USA","institution_ids":["https://openalex.org/I157725225"]},{"raw_affiliation_string":"[Dept. of Computer Science, Univ. of Illinois at Urbana, Champaign, USA]","institution_ids":["https://openalex.org/I157725225"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5105988194","display_name":"Ralph E. Johnson","orcid":null},"institutions":[{"id":"https://openalex.org/I157725225","display_name":"University of Illinois Urbana-Champaign","ror":"https://ror.org/047426m28","country_code":"US","type":"education","lineage":["https://openalex.org/I157725225"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ralph E. Johnson","raw_affiliation_strings":["Department of Computer Science, University of Illinois, Urbana-Champaign, USA","[Dept. of Computer Science, Univ. of Illinois at Urbana, Champaign, USA]"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, University of Illinois, Urbana-Champaign, USA","institution_ids":["https://openalex.org/I157725225"]},{"raw_affiliation_string":"[Dept. of Computer Science, Univ. of Illinois at Urbana, Champaign, USA]","institution_ids":["https://openalex.org/I157725225"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5049637653"],"corresponding_institution_ids":["https://openalex.org/I157725225"],"apc_list":null,"apc_paid":null,"fwci":5.8929,"has_fulltext":false,"cited_by_count":28,"citation_normalized_percentile":{"value":0.96501173,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"303","last_page":"312"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9998000264167786,"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"}},"topics":[{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9998000264167786,"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/T11005","display_name":"Radiation Effects in Electronics","score":0.9994000196456909,"subfield":{"id":"https://openalex.org/subfields/2208","display_name":"Electrical and Electronic Engineering"},"field":{"id":"https://openalex.org/fields/22","display_name":"Engineering"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T12423","display_name":"Software Reliability and Analysis Research","score":0.9993000030517578,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/precondition","display_name":"Precondition","score":0.9826704859733582},{"id":"https://openalex.org/keywords/code-refactoring","display_name":"Code refactoring","score":0.9758840799331665},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7906832695007324},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6572490930557251},{"id":"https://openalex.org/keywords/differential","display_name":"Differential (mechanical device)","score":0.5516352653503418},{"id":"https://openalex.org/keywords/fortran","display_name":"Fortran","score":0.4359411597251892},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.4209703207015991},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.3560514450073242},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.17206814885139465},{"id":"https://openalex.org/keywords/engineering","display_name":"Engineering","score":0.07232666015625}],"concepts":[{"id":"https://openalex.org/C192465680","wikidata":"https://www.wikidata.org/wiki/Q1413450","display_name":"Precondition","level":2,"score":0.9826704859733582},{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.9758840799331665},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7906832695007324},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6572490930557251},{"id":"https://openalex.org/C93226319","wikidata":"https://www.wikidata.org/wiki/Q193137","display_name":"Differential (mechanical device)","level":2,"score":0.5516352653503418},{"id":"https://openalex.org/C2778241615","wikidata":"https://www.wikidata.org/wiki/Q83303","display_name":"Fortran","level":2,"score":0.4359411597251892},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.4209703207015991},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.3560514450073242},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.17206814885139465},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.07232666015625},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","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/C146978453","wikidata":"https://www.wikidata.org/wiki/Q3798668","display_name":"Aerospace engineering","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1109/ase.2011.6100067","is_oa":false,"landing_page_url":"https://doi.org/10.1109/ase.2011.6100067","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"2011 26th IEEE/ACM International Conference on Automated Software Engineering (ASE 2011)","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":17,"referenced_works":["https://openalex.org/W65266040","https://openalex.org/W1494930385","https://openalex.org/W1495725173","https://openalex.org/W1558044546","https://openalex.org/W2005710769","https://openalex.org/W2017167760","https://openalex.org/W2056855811","https://openalex.org/W2098664130","https://openalex.org/W2100283823","https://openalex.org/W2104120481","https://openalex.org/W2154563336","https://openalex.org/W2155483096","https://openalex.org/W2159933174","https://openalex.org/W2160231989","https://openalex.org/W2911688310","https://openalex.org/W4238993245","https://openalex.org/W6758519796"],"related_works":["https://openalex.org/W2294916142","https://openalex.org/W4313549863","https://openalex.org/W1988458526","https://openalex.org/W2953046944","https://openalex.org/W4231266416","https://openalex.org/W1581362285","https://openalex.org/W2185407019","https://openalex.org/W2395465245","https://openalex.org/W2150433065","https://openalex.org/W2094959972"],"abstract_inverted_index":{"One":[0],"of":[1,6],"the":[2,42,47,55,79],"most":[3,43],"difficult":[4],"parts":[5],"building":[7],"automated":[8],"refactorings":[9],"is":[10,35,58,89],"ensuring":[11],"that":[12,59,88],"they":[13],"preserve":[14],"behavior.":[15],"This":[16],"paper":[17],"proposes":[18],"a":[19,60,68,86,96],"new":[20],"technique":[21,30],"to":[22,40],"check":[23],"for":[24,75,106],"behavior":[25],"preservation;":[26],"we":[27],"call":[28],"this":[29],"differential":[31,61,97],"precondition":[32,62,98],"checking.":[33],"It":[34],"simple":[36],"yet":[37],"expressive":[38],"enough":[39],"implement":[41],"common":[44],"refactorings,":[45],"and":[46,70,100,110],"core":[48,80],"algorithm":[49,81],"runs":[50],"in":[51,67,72,85,103],"linear":[52],"time.":[53],"However,":[54],"main":[56],"advantage":[57],"checker":[63,99],"can":[64,82],"be":[65,83],"placed":[66],"library":[69],"reused":[71],"refactoring":[73,104],"tools":[74,105],"many":[76],"different":[77],"languages;":[78],"implemented":[84,95],"way":[87],"completely":[90],"language":[91],"independent.":[92],"We":[93],"have":[94],"used":[101],"it":[102],"Fortran":[107],"(Photran),":[108],"PHP,":[109],"BC.":[111]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2017,"cited_by_count":3},{"year":2016,"cited_by_count":4},{"year":2015,"cited_by_count":1},{"year":2014,"cited_by_count":5},{"year":2013,"cited_by_count":4},{"year":2012,"cited_by_count":5}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
