{"id":"https://openalex.org/W2023614281","doi":"https://doi.org/10.1145/1596527.1596530","title":"An experimental analysis of self-adjusting computation","display_name":"An experimental analysis of self-adjusting computation","publication_year":2009,"publication_date":"2009-10-01","ids":{"openalex":"https://openalex.org/W2023614281","doi":"https://doi.org/10.1145/1596527.1596530","mag":"2023614281"},"language":"en","primary_location":{"id":"doi:10.1145/1596527.1596530","is_oa":true,"landing_page_url":"https://doi.org/10.1145/1596527.1596530","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/1596527.1596530","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/1596527.1596530","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5015051107","display_name":"Umut A. Acar","orcid":"https://orcid.org/0000-0002-2623-4986"},"institutions":[{"id":"https://openalex.org/I160992636","display_name":"Toyota Technological Institute at Chicago","ror":"https://ror.org/02sn5gb64","country_code":"US","type":"education","lineage":["https://openalex.org/I160992636"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Umut A. Acar","raw_affiliation_strings":["Toyota Technological Institute at Chicago","TOYOTA TECHNOLOGICAL INSTITUTE AT CHICAGO"],"affiliations":[{"raw_affiliation_string":"Toyota Technological Institute at Chicago","institution_ids":["https://openalex.org/I160992636"]},{"raw_affiliation_string":"TOYOTA TECHNOLOGICAL INSTITUTE AT CHICAGO","institution_ids":["https://openalex.org/I160992636"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5033930662","display_name":"Guy E. Blelloch","orcid":"https://orcid.org/0000-0003-0224-9187"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Guy E. Blelloch","raw_affiliation_strings":["Carnegie Mellon University"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5107211321","display_name":"M. Blume","orcid":null},"institutions":[{"id":"https://openalex.org/I160992636","display_name":"Toyota Technological Institute at Chicago","ror":"https://ror.org/02sn5gb64","country_code":"US","type":"education","lineage":["https://openalex.org/I160992636"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Matthias Blume","raw_affiliation_strings":["Toyota Technological Institute at Chicago","TOYOTA TECHNOLOGICAL INSTITUTE AT CHICAGO"],"affiliations":[{"raw_affiliation_string":"Toyota Technological Institute at Chicago","institution_ids":["https://openalex.org/I160992636"]},{"raw_affiliation_string":"TOYOTA TECHNOLOGICAL INSTITUTE AT CHICAGO","institution_ids":["https://openalex.org/I160992636"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5028720578","display_name":"Robert Harper","orcid":"https://orcid.org/0000-0002-9400-2941"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Robert Harper","raw_affiliation_strings":["Carnegie Mellon University"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5054849628","display_name":"Kanat Tangwongsan","orcid":"https://orcid.org/0000-0001-9775-8165"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Kanat Tangwongsan","raw_affiliation_strings":["Carnegie Mellon University"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University","institution_ids":["https://openalex.org/I74973139"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5015051107"],"corresponding_institution_ids":["https://openalex.org/I160992636"],"apc_list":null,"apc_paid":null,"fwci":8.545,"has_fulltext":true,"cited_by_count":71,"citation_normalized_percentile":{"value":0.9790927,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":100},"biblio":{"volume":"32","issue":"1","first_page":"1","last_page":"53"},"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.9954000115394592,"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.9954000115394592,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9930999875068665,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9889000058174133,"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/memoization","display_name":"Memoization","score":0.9865781664848328},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8825962543487549},{"id":"https://openalex.org/keywords/computation","display_name":"Computation","score":0.8035809993743896},{"id":"https://openalex.org/keywords/reuse","display_name":"Reuse","score":0.6558239459991455},{"id":"https://openalex.org/keywords/scratch","display_name":"Scratch","score":0.5688998103141785},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.447476327419281},{"id":"https://openalex.org/keywords/model-of-computation","display_name":"Model of computation","score":0.4425007402896881},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3926190435886383},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3629396855831146},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.20147854089736938}],"concepts":[{"id":"https://openalex.org/C79516417","wikidata":"https://www.wikidata.org/wiki/Q1376168","display_name":"Memoization","level":4,"score":0.9865781664848328},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8825962543487549},{"id":"https://openalex.org/C45374587","wikidata":"https://www.wikidata.org/wiki/Q12525525","display_name":"Computation","level":2,"score":0.8035809993743896},{"id":"https://openalex.org/C206588197","wikidata":"https://www.wikidata.org/wiki/Q846574","display_name":"Reuse","level":2,"score":0.6558239459991455},{"id":"https://openalex.org/C2781235140","wikidata":"https://www.wikidata.org/wiki/Q275131","display_name":"Scratch","level":2,"score":0.5688998103141785},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.447476327419281},{"id":"https://openalex.org/C184596265","wikidata":"https://www.wikidata.org/wiki/Q2651576","display_name":"Model of computation","level":3,"score":0.4425007402896881},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3926190435886383},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3629396855831146},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.20147854089736938},{"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/C186644900","wikidata":"https://www.wikidata.org/wiki/Q194152","display_name":"Parsing","level":2,"score":0.0},{"id":"https://openalex.org/C42560504","wikidata":"https://www.wikidata.org/wiki/Q15419395","display_name":"Top-down parsing","level":3,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/1596527.1596530","is_oa":true,"landing_page_url":"https://doi.org/10.1145/1596527.1596530","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/1596527.1596530","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:CiteSeerX.psu:10.1.1.146.2396","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.146.2396","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://ttic.uchicago.edu/~blume/papers/sap-toplas-draft.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.186.8509","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.186.8509","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.cmu.edu/%7Ektangwon/research/toplas09.pdf","raw_type":"text"}],"best_oa_location":{"id":"doi:10.1145/1596527.1596530","is_oa":true,"landing_page_url":"https://doi.org/10.1145/1596527.1596530","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/1596527.1596530","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":[{"score":0.7900000214576721,"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4"}],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2023614281.pdf","grobid_xml":"https://content.openalex.org/works/W2023614281.grobid-xml"},"referenced_works_count":94,"referenced_works":["https://openalex.org/W100509257","https://openalex.org/W119385306","https://openalex.org/W200699361","https://openalex.org/W243610207","https://openalex.org/W1425488884","https://openalex.org/W1486260668","https://openalex.org/W1497729523","https://openalex.org/W1583464938","https://openalex.org/W1593563200","https://openalex.org/W1596636544","https://openalex.org/W1612498707","https://openalex.org/W1657869212","https://openalex.org/W1676865579","https://openalex.org/W1753348055","https://openalex.org/W1805323477","https://openalex.org/W1816717522","https://openalex.org/W1883947180","https://openalex.org/W1965784613","https://openalex.org/W1967890297","https://openalex.org/W1968301997","https://openalex.org/W1970448777","https://openalex.org/W1971597822","https://openalex.org/W1976915153","https://openalex.org/W1977155699","https://openalex.org/W1990488650","https://openalex.org/W1992869351","https://openalex.org/W1995307698","https://openalex.org/W1998872256","https://openalex.org/W1999707021","https://openalex.org/W2001280137","https://openalex.org/W2007009457","https://openalex.org/W2008926781","https://openalex.org/W2009695707","https://openalex.org/W2011055092","https://openalex.org/W2014832211","https://openalex.org/W2018804864","https://openalex.org/W2022163094","https://openalex.org/W2025299767","https://openalex.org/W2025791989","https://openalex.org/W2026511056","https://openalex.org/W2028423097","https://openalex.org/W2035829578","https://openalex.org/W2038118137","https://openalex.org/W2045430818","https://openalex.org/W2049074379","https://openalex.org/W2051716170","https://openalex.org/W2054014036","https://openalex.org/W2061532023","https://openalex.org/W2066509127","https://openalex.org/W2069718764","https://openalex.org/W2073065242","https://openalex.org/W2086474457","https://openalex.org/W2089020545","https://openalex.org/W2090193162","https://openalex.org/W2096606628","https://openalex.org/W2097284499","https://openalex.org/W2104196725","https://openalex.org/W2107371087","https://openalex.org/W2108369594","https://openalex.org/W2112648314","https://openalex.org/W2120621946","https://openalex.org/W2121473031","https://openalex.org/W2126884146","https://openalex.org/W2128744826","https://openalex.org/W2130055503","https://openalex.org/W2132445073","https://openalex.org/W2135068828","https://openalex.org/W2139865986","https://openalex.org/W2153504150","https://openalex.org/W2163690888","https://openalex.org/W2166089338","https://openalex.org/W2167205086","https://openalex.org/W2171901695","https://openalex.org/W2172288767","https://openalex.org/W2252991550","https://openalex.org/W2294191420","https://openalex.org/W2341171179","https://openalex.org/W2478175895","https://openalex.org/W2521273508","https://openalex.org/W2614835259","https://openalex.org/W2752853835","https://openalex.org/W2915030386","https://openalex.org/W3190573802","https://openalex.org/W3199565109","https://openalex.org/W4214936872","https://openalex.org/W4235858940","https://openalex.org/W4244805165","https://openalex.org/W4252017042","https://openalex.org/W4253063713","https://openalex.org/W6644144004","https://openalex.org/W6684244709","https://openalex.org/W6704298589","https://openalex.org/W6754610334","https://openalex.org/W6759313948"],"related_works":["https://openalex.org/W2023614281","https://openalex.org/W124095581","https://openalex.org/W2348761119","https://openalex.org/W4298032262","https://openalex.org/W2284153003","https://openalex.org/W1974158449","https://openalex.org/W134510267","https://openalex.org/W3082255678","https://openalex.org/W98899188","https://openalex.org/W1568173680"],"abstract_inverted_index":{"Recent":[0],"work":[1],"on":[2],"adaptive":[3],"functional":[4,201],"programming":[5],"(AFP)":[6],"developed":[7],"techniques":[8],"for":[9,106,218,251,257],"writing":[10],"programs":[11,30,299],"that":[12,38,48,141,163,178,241,287],"can":[13,52,84,142],"respond":[14,85,300],"to":[15,17,86,136,151,154,171,186,280,295,301,304],"modifications":[16,89,303],"their":[18,234,305],"data":[19,40,306],"by":[20,63,72,166,181,247],"performing":[21],"change":[22,111],"propagation":[23,112],".":[24],"To":[25],"achieve":[26],"this,":[27],"executions":[28,235],"of":[29,68,80,160,175,226,273,308],"are":[31,104,164,194],"represented":[32,236],"with":[33,215,237,270],"dynamic":[34,128],"dependence":[35,129],"graphs":[36,130],"(DDGs)":[37],"record":[39],"dependences":[41,44],"and":[42,109,131,133,156,220,261,263],"control":[43],"in":[45,230,292],"a":[46,49,125,138,209,216,249,271],"way":[47],"change-propagation":[50,76,139],"algorithm":[51,140],"update":[53],"the":[54,58,66,69,73,81,158,161,173,176,182,224,242,259,288],"computation":[55,70,145,162,177,204],"as":[56,189],"if":[57],"program":[59],"were":[60],"from":[61,94,118,276],"scratch,":[62,95],"re-executing":[64],"only":[65,77],"parts":[67,79,159,174],"affected":[71,165],"changes.":[74,183],"Since":[75,192],"re-executes":[78],"computation,":[82,202,253],"it":[83],"certain":[87],"incremental":[88],"asymptotically":[90],"faster":[91,115],"than":[92,116],"recomputing":[93,117,296],"potentially":[96],"offering":[97],"significant":[98],"speedups.":[99],"Such":[100],"asymptotic":[101],"speedups,":[102],"however,":[103],"rare:":[105],"many":[107],"computations":[108],"modifications,":[110,167],"is":[113,150,245,290],"no":[114],"scratch.":[119],"In":[120],"this":[121,187,213],"article,":[122],"we":[123],"realize":[124],"duality":[126],"between":[127],"memoization,":[132],"combine":[134],"them":[135],"give":[137],"dramatically":[143],"increase":[144],"reuse.":[146],"The":[147],"key":[148],"idea":[149],"use":[152],"DDGs":[153,193],"identify":[155,172],"re-execute":[157],"while":[168],"using":[169],"memoization":[170,198,207],"remain":[179],"unaffected":[180],"We":[184,211,239],"refer":[185],"approach":[188,244,289],"self-adjusting":[190,252,298],"computation.":[191],"imperative,":[195],"but":[196,233],"(traditional)":[197],"requires":[199],"purely":[200],"reusing":[203,221],"correctly":[205],"via":[206],"becomes":[208],"challenge.":[210],"overcome":[212],"challenge":[214],"technique":[217],"remembering":[219],"not":[222],"just":[223],"results":[225],"function":[227],"calls":[228],"(as":[229],"conventional":[231],"memoization),":[232],"DDGs.":[238],"show":[240],"proposed":[243],"realistic":[246],"describing":[248,262],"library":[250],"presenting":[254],"efficient":[255],"algorithms":[256],"realizing":[258],"library,":[260],"evaluating":[264],"an":[265],"implementation.":[266],"Our":[267],"experimental":[268],"evaluation":[269],"variety":[272],"applications,":[274],"ranging":[275],"simple":[277],"list":[278],"primitives":[279],"more":[281],"sophisticated":[282],"computational":[283],"geometry":[284],"algorithms,":[285],"shows":[286],"effective":[291],"practice:":[293],"compared":[294],"from-scratch;":[297],"small":[302],"orders":[307],"magnitude":[309],"faster.":[310]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":3},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":5},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":9},{"year":2015,"cited_by_count":6},{"year":2014,"cited_by_count":13},{"year":2013,"cited_by_count":5},{"year":2012,"cited_by_count":2}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
