{"id":"https://openalex.org/W2118751596","doi":"https://doi.org/10.1145/1082983.1083248","title":"Refactoring gcc using structure field access traces and concept analysis","display_name":"Refactoring gcc using structure field access traces and concept analysis","publication_year":2005,"publication_date":"2005-05-17","ids":{"openalex":"https://openalex.org/W2118751596","doi":"https://doi.org/10.1145/1082983.1083248","mag":"2118751596"},"language":"en","primary_location":{"id":"doi:10.1145/1082983.1083248","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1082983.1083248","pdf_url":null,"source":{"id":"https://openalex.org/S186921487","display_name":"ACM SIGSOFT Software Engineering Notes","issn_l":"0163-5948","issn":["0163-5948","1943-5843"],"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 SIGSOFT Software Engineering Notes","raw_type":"journal-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/A5024447954","display_name":"Robert W. Bowdidge","orcid":null},"institutions":[{"id":"https://openalex.org/I1311269955","display_name":"Apple (Israel)","ror":"https://ror.org/04ehjr030","country_code":"IL","type":"company","lineage":["https://openalex.org/I1311269955","https://openalex.org/I4210153776"]},{"id":"https://openalex.org/I4210153776","display_name":"Apple (United States)","ror":"https://ror.org/059hsda18","country_code":"US","type":"company","lineage":["https://openalex.org/I4210153776"]}],"countries":["IL","US"],"is_corresponding":true,"raw_author_name":"Robert W. Bowdidge","raw_affiliation_strings":["Apple Computer, Cupertino, CA","Apple Computer, Cupertino, CA#TAB#"],"affiliations":[{"raw_affiliation_string":"Apple Computer, Cupertino, CA","institution_ids":["https://openalex.org/I4210153776"]},{"raw_affiliation_string":"Apple Computer, Cupertino, CA#TAB#","institution_ids":["https://openalex.org/I1311269955"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5024447954"],"corresponding_institution_ids":["https://openalex.org/I1311269955","https://openalex.org/I4210153776"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":false,"cited_by_count":0,"citation_normalized_percentile":{"value":0.14082263,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"30","issue":"4","first_page":"1","last_page":"7"},"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9997000098228455,"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/T12423","display_name":"Software Reliability and Analysis Research","score":0.9995999932289124,"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/code-refactoring","display_name":"Code refactoring","score":0.9805095195770264},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8344710469245911},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6716466546058655},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6183691024780273},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.5653125643730164},{"id":"https://openalex.org/keywords/static-analysis","display_name":"Static analysis","score":0.5368103981018066},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.498431921005249},{"id":"https://openalex.org/keywords/heap","display_name":"Heap (data structure)","score":0.49769046902656555},{"id":"https://openalex.org/keywords/data-structure","display_name":"Data structure","score":0.48140430450439453},{"id":"https://openalex.org/keywords/hierarchy","display_name":"Hierarchy","score":0.41050031781196594},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.32714536786079407}],"concepts":[{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.9805095195770264},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8344710469245911},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6716466546058655},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6183691024780273},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.5653125643730164},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.5368103981018066},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.498431921005249},{"id":"https://openalex.org/C134757568","wikidata":"https://www.wikidata.org/wiki/Q274089","display_name":"Heap (data structure)","level":2,"score":0.49769046902656555},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.48140430450439453},{"id":"https://openalex.org/C31170391","wikidata":"https://www.wikidata.org/wiki/Q188619","display_name":"Hierarchy","level":2,"score":0.41050031781196594},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.32714536786079407},{"id":"https://openalex.org/C162324750","wikidata":"https://www.wikidata.org/wiki/Q8134","display_name":"Economics","level":0,"score":0.0},{"id":"https://openalex.org/C34447519","wikidata":"https://www.wikidata.org/wiki/Q179522","display_name":"Market economy","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/1082983.1083248","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1082983.1083248","pdf_url":null,"source":{"id":"https://openalex.org/S186921487","display_name":"ACM SIGSOFT Software Engineering Notes","issn_l":"0163-5948","issn":["0163-5948","1943-5843"],"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 SIGSOFT Software Engineering Notes","raw_type":"journal-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":15,"referenced_works":["https://openalex.org/W1503729935","https://openalex.org/W1508660681","https://openalex.org/W1637866372","https://openalex.org/W1972064644","https://openalex.org/W2008059648","https://openalex.org/W2060389467","https://openalex.org/W2101462267","https://openalex.org/W2106697582","https://openalex.org/W2109859526","https://openalex.org/W2124961838","https://openalex.org/W2153887189","https://openalex.org/W2164621430","https://openalex.org/W2172168118","https://openalex.org/W2787379525","https://openalex.org/W3106729728"],"related_works":["https://openalex.org/W2019530272","https://openalex.org/W1578255156","https://openalex.org/W3035018584","https://openalex.org/W2761428514","https://openalex.org/W2479720249","https://openalex.org/W4299986738","https://openalex.org/W2867457158","https://openalex.org/W1552130108","https://openalex.org/W2765641823","https://openalex.org/W4297908618"],"abstract_inverted_index":{"Refactoring":[0],"usually":[1],"involves":[2],"statically":[3],"analyzing":[4,37],"source":[5,39],"code":[6,40,70],"to":[7,58,64,99,108,125,154,167,171],"understand":[8],"which":[9],"transformations":[10],"safely":[11],"preserve":[12],"execution":[13],"behavior":[14],"of":[15,80,88,103,141,196],"the":[16,38,45,60,96,110,129,142,155,174,180,186],"program.":[17],"However,":[18],"static":[19],"analysis":[20,29],"may":[21],"not":[22,49],"scale":[23],"well":[24],"for":[25,36,68],"large":[26],"programs":[27],"when":[28,34,44],"results":[30,149],"are":[31,41],"too":[32],"general,":[33],"tools":[35,46],"unwieldy,":[42],"or":[43],"simply":[47],"do":[48],"exist.":[50],"In":[51,106],"such":[52],"cases,":[53,198],"it":[54],"can":[55,77],"be":[56,133,165,183,202],"simpler":[57],"analyze":[59],"program":[61],"at":[62],"runtime":[63],"gather":[65,168],"answers":[66],"needed":[67,166],"safe":[69],"changes.":[71],"I":[72,91,94,118,135,157],"show":[73,92],"how":[74,93,128],"dynamic":[75,187],"data":[76,83,112,120,130,143],"guide":[78],"refactoring":[79,181],"a":[81,86],"single":[82],"structure":[84,113,121,131,144],"into":[85,114],"hierarchy":[87],"classes.":[89],"Specifically,":[90],"refactored":[95],"gcc":[97],"compiler":[98],"cut":[100],"its":[101],"use":[102],"heap":[104],"memory.":[105],"order":[107],"partition":[109],"declaration":[111],"more":[115],"efficiently-sized":[116],"parts,":[117],"used":[119],"field":[122],"access":[123],"traces":[124,191],"automatically":[126],"identify":[127],"might":[132],"refactored.":[134],"also":[136],"identified":[137],"other":[138],"potential":[139],"refactorings":[140],"using":[145],"concept":[146],"analysis.":[147],"These":[148],"then":[150],"guided":[151],"by-hand":[152],"modifications":[153],"compiler.":[156],"finally":[158],"evaluated":[159],"what":[160],"size":[161],"test":[162,197],"cases":[163],"would":[164,201],"adequate":[169],"information":[170],"correctly":[172],"perform":[173],"refactoring.":[175],"The":[176],"case":[177],"study":[178],"showed":[179],"could":[182],"performed":[184],"with":[185],"information,":[188],"but":[189],"without":[190],"from":[192],"an":[193],"exhaustive":[194],"set":[195],"some":[199],"fields":[200],"moved":[203],"incorrectly.":[204]},"counts_by_year":[],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
