{"id":"https://openalex.org/W4387667278","doi":"https://doi.org/10.1145/3622817","title":"How Profilers Can Help Navigate Type Migration","display_name":"How Profilers Can Help Navigate Type Migration","publication_year":2023,"publication_date":"2023-10-16","ids":{"openalex":"https://openalex.org/W4387667278","doi":"https://doi.org/10.1145/3622817"},"language":"en","primary_location":{"id":"doi:10.1145/3622817","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3622817","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3622817","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3622817","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5002785598","display_name":"Ben Greenman","orcid":"https://orcid.org/0000-0001-7078-9287"},"institutions":[{"id":"https://openalex.org/I223532165","display_name":"University of Utah","ror":"https://ror.org/03r0ha626","country_code":"US","type":"education","lineage":["https://openalex.org/I223532165"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ben Greenman","raw_affiliation_strings":["University of Utah, Salt Lake City, USA"],"raw_orcid":"https://orcid.org/0000-0001-7078-9287","affiliations":[{"raw_affiliation_string":"University of Utah, Salt Lake City, USA","institution_ids":["https://openalex.org/I223532165"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5000905628","display_name":"Matthias Felleisen","orcid":"https://orcid.org/0000-0001-6678-1004"},"institutions":[{"id":"https://openalex.org/I12912129","display_name":"Northeastern University","ror":"https://ror.org/04t5xt781","country_code":"US","type":"education","lineage":["https://openalex.org/I12912129"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Matthias Felleisen","raw_affiliation_strings":["Northeastern University, Boston, USA"],"raw_orcid":"https://orcid.org/0000-0001-6678-1004","affiliations":[{"raw_affiliation_string":"Northeastern University, Boston, USA","institution_ids":["https://openalex.org/I12912129"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5041562511","display_name":"Christos Dimoulas","orcid":"https://orcid.org/0000-0002-9338-7034"},"institutions":[{"id":"https://openalex.org/I111979921","display_name":"Northwestern University","ror":"https://ror.org/000e0be47","country_code":"US","type":"education","lineage":["https://openalex.org/I111979921"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Christos Dimoulas","raw_affiliation_strings":["Northwestern University, Evanston, USA"],"raw_orcid":"https://orcid.org/0000-0002-9338-7034","affiliations":[{"raw_affiliation_string":"Northwestern University, Evanston, USA","institution_ids":["https://openalex.org/I111979921"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.4285,"has_fulltext":true,"cited_by_count":1,"citation_normalized_percentile":{"value":0.69460028,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":91,"max":95},"biblio":{"volume":"7","issue":"OOPSLA2","first_page":"544","last_page":"573"},"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.9990000128746033,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9976000189781189,"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/computer-science","display_name":"Computer science","score":0.7867901921272278},{"id":"https://openalex.org/keywords/debugging","display_name":"Debugging","score":0.7456203699111938},{"id":"https://openalex.org/keywords/code-refactoring","display_name":"Code refactoring","score":0.7442127466201782},{"id":"https://openalex.org/keywords/programmer","display_name":"Programmer","score":0.7268179059028625},{"id":"https://openalex.org/keywords/profiling","display_name":"Profiling (computer programming)","score":0.6423351764678955},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.46165215969085693},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.1336197853088379}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7867901921272278},{"id":"https://openalex.org/C168065819","wikidata":"https://www.wikidata.org/wiki/Q845566","display_name":"Debugging","level":2,"score":0.7456203699111938},{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.7442127466201782},{"id":"https://openalex.org/C2778514511","wikidata":"https://www.wikidata.org/wiki/Q1374194","display_name":"Programmer","level":2,"score":0.7268179059028625},{"id":"https://openalex.org/C187191949","wikidata":"https://www.wikidata.org/wiki/Q1138496","display_name":"Profiling (computer programming)","level":2,"score":0.6423351764678955},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.46165215969085693},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.1336197853088379}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3622817","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3622817","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3622817","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1145/3622817","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3622817","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3622817","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Reduced inequalities","id":"https://metadata.un.org/sdg/10","score":0.7900000214576721}],"awards":[{"id":"https://openalex.org/G2237822910","display_name":"CAREER: The Rational Programmer, An Investigative Method for Programming Language Pragmatics","funder_award_id":"2237984","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G3163158226","display_name":"CRI: CI-SUSTAIN: Racket on Alternative Platforms","funder_award_id":"1823244","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G3937453680","display_name":null,"funder_award_id":"1763922, 2030859, 2237984, 1823244","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G4084077383","display_name":"SHF: MEDIUM: Performant Sound Gradual Typing","funder_award_id":"1763922","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G7698193007","display_name":"Computing Innovation Fellows 2020 Project","funder_award_id":"2030859","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4387667278.pdf","grobid_xml":"https://content.openalex.org/works/W4387667278.grobid-xml"},"referenced_works_count":59,"referenced_works":["https://openalex.org/W753900477","https://openalex.org/W1496853143","https://openalex.org/W1551643567","https://openalex.org/W1970075481","https://openalex.org/W2003969655","https://openalex.org/W2019912855","https://openalex.org/W2021976477","https://openalex.org/W2052973434","https://openalex.org/W2070088936","https://openalex.org/W2097013380","https://openalex.org/W2102473657","https://openalex.org/W2113419089","https://openalex.org/W2135536553","https://openalex.org/W2144433126","https://openalex.org/W2149207009","https://openalex.org/W2223702412","https://openalex.org/W2534815697","https://openalex.org/W2599572386","https://openalex.org/W2610416669","https://openalex.org/W2762605937","https://openalex.org/W2776911292","https://openalex.org/W2885244083","https://openalex.org/W2899197979","https://openalex.org/W2911692446","https://openalex.org/W2915101224","https://openalex.org/W2947857949","https://openalex.org/W2954950681","https://openalex.org/W2964560944","https://openalex.org/W2966721983","https://openalex.org/W2972625019","https://openalex.org/W2979470607","https://openalex.org/W2996400815","https://openalex.org/W3000266772","https://openalex.org/W3003463695","https://openalex.org/W3087747708","https://openalex.org/W3116525202","https://openalex.org/W3122109907","https://openalex.org/W3163435015","https://openalex.org/W3175123813","https://openalex.org/W3194752080","https://openalex.org/W3200076486","https://openalex.org/W3205670054","https://openalex.org/W3206533211","https://openalex.org/W3207374977","https://openalex.org/W3216307614","https://openalex.org/W4241122238","https://openalex.org/W4244807040","https://openalex.org/W4245545962","https://openalex.org/W4247072772","https://openalex.org/W4249990212","https://openalex.org/W4253591485","https://openalex.org/W4281615790","https://openalex.org/W4289766111","https://openalex.org/W4315705023","https://openalex.org/W4382362141","https://openalex.org/W4384115804","https://openalex.org/W4393539144","https://openalex.org/W6758553006","https://openalex.org/W6804071104"],"related_works":["https://openalex.org/W2168928134","https://openalex.org/W2059759476","https://openalex.org/W2112040168","https://openalex.org/W4241972157","https://openalex.org/W4242556954","https://openalex.org/W2096877983","https://openalex.org/W2053897590","https://openalex.org/W1618604010","https://openalex.org/W2061417947","https://openalex.org/W622882839"],"abstract_inverted_index":{"Sound":[0],"migratory":[1,58],"typing":[2,59],"envisions":[3],"a":[4,33],"safe":[5],"and":[6,83,128],"smooth":[7],"refactoring":[8],"of":[9,19,52,56,88,93,95,117,138],"untyped":[10,129],"code":[11],"bases":[12],"to":[13,47,120],"typed":[14,127],"ones.":[15],"However,":[16],"the":[17,44,53,57,79,86,115,122,147],"cost":[18],"enforcing":[20],"safety":[21],"with":[22],"run-time":[23],"checks":[24],"is":[25,49,114],"often":[26,39],"prohibitively":[27],"high,":[28],"thus":[29],"performance":[30,142],"regressions":[31],"are":[32,144],"likely":[34],"occurrence.":[35],"Additional":[36],"types":[37,119],"can":[38],"recover":[40],"performance,":[41],"but":[42],"choosing":[43],"right":[45],"components":[46],"type":[48],"difficult":[50],"because":[51],"exponential":[54],"size":[55],"lattice.":[60],"In":[61],"principal":[62],"though,":[63],"migration":[64],"could":[65],"be":[66],"guided":[67],"by":[68],"off-the-shelf":[69],"profiling":[70],"tools.":[71],"To":[72],"examine":[73],"this":[74,76,131],"hypothesis,":[75],"paper":[77],"follows":[78],"rational":[80],"programmer":[81],"method":[82],"reports":[84],"on":[85,91],"results":[87],"an":[89,106],"experiment":[90],"tens":[92],"thousands":[94],"performance-debugging":[96],"scenarios":[97,139],"via":[98],"seventeen":[99],"strategies":[100],"for":[101],"turning":[102],"profiler":[103],"output":[104],"into":[105],"actionable":[107],"next":[108],"step.":[109],"The":[110],"most":[111,123],"effective":[112],"strategy":[113,132],"use":[116],"deep":[118],"eliminate":[121],"costly":[124],"boundaries":[125],"between":[126],"components;":[130],"succeeds":[133],"in":[134],"more":[135],"than":[136],"50%":[137],"if":[140],"two":[141],"degradations":[143],"tolerable":[145],"along":[146],"way.":[148]},"counts_by_year":[{"year":2025,"cited_by_count":1}],"updated_date":"2026-06-22T08:00:12.763002","created_date":"2025-10-10T00:00:00"}
