{"id":"https://openalex.org/W2148707178","doi":"https://doi.org/10.1145/1542476.1542526","title":"Binary analysis for measurement and attribution of program performance","display_name":"Binary analysis for measurement and attribution of program performance","publication_year":2009,"publication_date":"2009-06-15","ids":{"openalex":"https://openalex.org/W2148707178","doi":"https://doi.org/10.1145/1542476.1542526","mag":"2148707178"},"language":"en","primary_location":{"id":"doi:10.1145/1542476.1542526","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1542476.1542526","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 30th ACM SIGPLAN Conference on Programming Language Design and Implementation","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/A5047746050","display_name":"Nathan R. Tallent","orcid":"https://orcid.org/0000-0003-4297-3057"},"institutions":[{"id":"https://openalex.org/I74775410","display_name":"Rice University","ror":"https://ror.org/008zs3103","country_code":"US","type":"education","lineage":["https://openalex.org/I74775410"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Nathan R. Tallent","raw_affiliation_strings":["Rice University, Houston, TX, USA"],"affiliations":[{"raw_affiliation_string":"Rice University, Houston, TX, USA","institution_ids":["https://openalex.org/I74775410"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5089709469","display_name":"John Mellor\u2010Crummey","orcid":"https://orcid.org/0000-0002-9026-5453"},"institutions":[{"id":"https://openalex.org/I74775410","display_name":"Rice University","ror":"https://ror.org/008zs3103","country_code":"US","type":"education","lineage":["https://openalex.org/I74775410"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"John M. Mellor-Crummey","raw_affiliation_strings":["Rice University, Houston, TX, USA"],"affiliations":[{"raw_affiliation_string":"Rice University, Houston, TX, USA","institution_ids":["https://openalex.org/I74775410"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5072936498","display_name":"Michael Fagan","orcid":null},"institutions":[{"id":"https://openalex.org/I74775410","display_name":"Rice University","ror":"https://ror.org/008zs3103","country_code":"US","type":"education","lineage":["https://openalex.org/I74775410"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Michael W. Fagan","raw_affiliation_strings":["Rice University, Houston, TX, USA"],"affiliations":[{"raw_affiliation_string":"Rice University, Houston, TX, USA","institution_ids":["https://openalex.org/I74775410"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5047746050"],"corresponding_institution_ids":["https://openalex.org/I74775410"],"apc_list":null,"apc_paid":null,"fwci":6.9677,"has_fulltext":false,"cited_by_count":58,"citation_normalized_percentile":{"value":0.97415996,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"441","last_page":"452"},"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.9998000264167786,"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.9998000264167786,"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/T12127","display_name":"Software System Performance and Reliability","score":0.998199999332428,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/T11181","display_name":"Advanced Data Storage Technologies","score":0.9980999827384949,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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.8505978584289551},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.6691136360168457},{"id":"https://openalex.org/keywords/debugging","display_name":"Debugging","score":0.6649043560028076},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.6252410411834717},{"id":"https://openalex.org/keywords/static-analysis","display_name":"Static analysis","score":0.6189054846763611},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.6102665662765503},{"id":"https://openalex.org/keywords/static-program-analysis","display_name":"Static program analysis","score":0.607566773891449},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.5074848532676697},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.4921066164970398},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.4893140494823456},{"id":"https://openalex.org/keywords/binary-code","display_name":"Binary code","score":0.47932183742523193},{"id":"https://openalex.org/keywords/binary-number","display_name":"Binary number","score":0.4141082465648651},{"id":"https://openalex.org/keywords/program-slicing","display_name":"Program slicing","score":0.4124566614627838},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.38037002086639404},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.2767311930656433},{"id":"https://openalex.org/keywords/software-development","display_name":"Software development","score":0.14186981320381165}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8505978584289551},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.6691136360168457},{"id":"https://openalex.org/C168065819","wikidata":"https://www.wikidata.org/wiki/Q845566","display_name":"Debugging","level":2,"score":0.6649043560028076},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.6252410411834717},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.6189054846763611},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.6102665662765503},{"id":"https://openalex.org/C137287247","wikidata":"https://www.wikidata.org/wiki/Q1329550","display_name":"Static program analysis","level":4,"score":0.607566773891449},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.5074848532676697},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.4921066164970398},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.4893140494823456},{"id":"https://openalex.org/C63435697","wikidata":"https://www.wikidata.org/wiki/Q864135","display_name":"Binary code","level":3,"score":0.47932183742523193},{"id":"https://openalex.org/C48372109","wikidata":"https://www.wikidata.org/wiki/Q3913","display_name":"Binary number","level":2,"score":0.4141082465648651},{"id":"https://openalex.org/C91071405","wikidata":"https://www.wikidata.org/wiki/Q1413145","display_name":"Program slicing","level":3,"score":0.4124566614627838},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.38037002086639404},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.2767311930656433},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.14186981320381165},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","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/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0},{"id":"https://openalex.org/C94375191","wikidata":"https://www.wikidata.org/wiki/Q11205","display_name":"Arithmetic","level":1,"score":0.0},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/1542476.1542526","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1542476.1542526","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 30th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.160.2427","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.160.2427","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.rice.edu/~johnmc/papers/hpctoolkit-pldi-2009.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.399.3368","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.399.3368","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.hpctoolkit.org/pubs/pldi-2009-hpctoolkit-binary-analysis.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":22,"referenced_works":["https://openalex.org/W1544432721","https://openalex.org/W1599277697","https://openalex.org/W1983412169","https://openalex.org/W2005795572","https://openalex.org/W2009741116","https://openalex.org/W2020009542","https://openalex.org/W2051533028","https://openalex.org/W2075402035","https://openalex.org/W2082318969","https://openalex.org/W2088909053","https://openalex.org/W2095455436","https://openalex.org/W2125295642","https://openalex.org/W2134633067","https://openalex.org/W2136434791","https://openalex.org/W2144433126","https://openalex.org/W2153530968","https://openalex.org/W2160468841","https://openalex.org/W2161563510","https://openalex.org/W2162612712","https://openalex.org/W4239813889","https://openalex.org/W4248649658","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W2289630902","https://openalex.org/W4297908618","https://openalex.org/W2765641823","https://openalex.org/W2867457158","https://openalex.org/W2354385412","https://openalex.org/W2070948110","https://openalex.org/W2132874107","https://openalex.org/W3111646971","https://openalex.org/W48604291","https://openalex.org/W4285814480"],"abstract_inverted_index":{"Modern":[0],"programs":[1],"frequently":[2],"employ":[3],"sophisticated":[4],"modular":[5,71,170],"designs.":[6],"As":[7],"a":[8,28,119],"result,":[9],"performance":[10,24,33,45,67,142,167,179],"problems":[11],"cannot":[12],"be":[13],"identified":[14],"from":[15],"costs":[16,95],"attributed":[17],"to":[18,57,87,96,112,122,144],"routines":[19],"in":[20,37,176],"isolation;":[21],"understanding":[22],"code":[23,86,107],"requires":[25],"information":[26,161],"about":[27],"routine's":[29],"calling":[30,98,135,145],"context.":[31],"Existing":[32],"tools":[34,180],"fall":[35],"short":[36],"this":[38,160],"respect.":[39],"Prior":[40],"strategies":[41],"for":[42],"attributing":[43],"context-sensitive":[44],"at":[46],"the":[47,58,66,128,157,166,177],"source":[48,124],"level":[49],"either":[50],"compromise":[51],"measurement":[52],"accuracy,":[53],"remain":[54],"too":[55],"close":[56],"binary,":[59],"or":[60],"require":[61],"custom":[62],"compilers.":[63],"To":[64],"understand":[65],"of":[68,83,94,104,152,159,168],"fully":[69],"optimized":[70,84,105],"code,":[72],"we":[73,138],"developed":[74],"two":[75],"novel":[76],"binary":[77],"analysis":[78,82,103],"techniques:":[79],"1)":[80],"on-the-fly":[81],"machine":[85,106],"enable":[88],"minimally":[89],"intrusive":[90],"and":[91,100,108,117,149],"accurate":[92],"attribution":[93],"dynamic":[97,134],"contexts;":[99],"2)":[101],"post-mortem":[102],"its":[109,114,123],"debugging":[110],"sections":[111],"recover":[113],"program":[115,131],"structure":[116,132],"reconstruct":[118],"mapping":[120],"back":[121],"code.":[125],"By":[126],"combining":[127],"recovered":[129],"static":[130],"with":[133],"context":[136],"information,":[137],"can":[139],"accurately":[140],"attribute":[141],"metrics":[143],"contexts,":[146],"procedures,":[147],"loops,":[148],"inlined":[150],"instances":[151],"procedures.":[153],"We":[154],"demonstrate":[155],"that":[156],"fusion":[158],"provides":[162],"unique":[163],"insight":[164],"into":[165],"complex":[169],"codes.":[171],"This":[172],"work":[173],"is":[174],"implemented":[175],"HPCToolkit":[178],"(http://hpctoolkit.org).":[181]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":3},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":2},{"year":2015,"cited_by_count":5},{"year":2014,"cited_by_count":7},{"year":2013,"cited_by_count":6},{"year":2012,"cited_by_count":4}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
