{"id":"https://openalex.org/W1987469059","doi":"https://doi.org/10.1145/1869459.1869491","title":"Dynamic parallelization of recursive code","display_name":"Dynamic parallelization of recursive code","publication_year":2010,"publication_date":"2010-10-17","ids":{"openalex":"https://openalex.org/W1987469059","doi":"https://doi.org/10.1145/1869459.1869491","mag":"1987469059"},"language":"en","primary_location":{"id":"doi:10.1145/1869459.1869491","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1869459.1869491","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM international conference on Object oriented programming systems languages and applications","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/A5003882528","display_name":"Charlotte Herzeel","orcid":"https://orcid.org/0000-0002-9319-9885"},"institutions":[{"id":"https://openalex.org/I13469542","display_name":"Vrije Universiteit Brussel","ror":"https://ror.org/006e5kg04","country_code":"BE","type":"education","lineage":["https://openalex.org/I13469542"]}],"countries":["BE"],"is_corresponding":true,"raw_author_name":"Charlotte Herzeel","raw_affiliation_strings":["Vrije Universiteit Brussel, Brussels, Belgium"],"affiliations":[{"raw_affiliation_string":"Vrije Universiteit Brussel, Brussels, Belgium","institution_ids":["https://openalex.org/I13469542"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5082125013","display_name":"Pascal Costanza","orcid":"https://orcid.org/0000-0001-8894-3238"},"institutions":[{"id":"https://openalex.org/I13469542","display_name":"Vrije Universiteit Brussel","ror":"https://ror.org/006e5kg04","country_code":"BE","type":"education","lineage":["https://openalex.org/I13469542"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Pascal Costanza","raw_affiliation_strings":["Vrije Universiteit Brussel, Brussels, Belgium"],"affiliations":[{"raw_affiliation_string":"Vrije Universiteit Brussel, Brussels, Belgium","institution_ids":["https://openalex.org/I13469542"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5003882528"],"corresponding_institution_ids":["https://openalex.org/I13469542"],"apc_list":null,"apc_paid":null,"fwci":0.9987,"has_fulltext":false,"cited_by_count":6,"citation_normalized_percentile":{"value":0.76640648,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":94},"biblio":{"volume":null,"issue":null,"first_page":"377","last_page":"396"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":1.0,"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":1.0,"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/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9990000128746033,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9988999962806702,"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/computer-science","display_name":"Computer science","score":0.9075237512588501},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.7618240118026733},{"id":"https://openalex.org/keywords/automatic-parallelization","display_name":"Automatic parallelization","score":0.7146801352500916},{"id":"https://openalex.org/keywords/benchmark","display_name":"Benchmark (surveying)","score":0.6401234865188599},{"id":"https://openalex.org/keywords/lisp","display_name":"Lisp","score":0.6273823976516724},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6049758791923523},{"id":"https://openalex.org/keywords/scheme","display_name":"Scheme (mathematics)","score":0.5498669743537903},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5322909951210022},{"id":"https://openalex.org/keywords/suite","display_name":"Suite","score":0.527324378490448},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.47223520278930664},{"id":"https://openalex.org/keywords/focus","display_name":"Focus (optics)","score":0.43825873732566833},{"id":"https://openalex.org/keywords/interpreter","display_name":"Interpreter","score":0.4378896951675415},{"id":"https://openalex.org/keywords/loop","display_name":"Loop (graph theory)","score":0.4333828091621399},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3207155466079712},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.19348794221878052}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9075237512588501},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.7618240118026733},{"id":"https://openalex.org/C164833996","wikidata":"https://www.wikidata.org/wiki/Q2323839","display_name":"Automatic parallelization","level":3,"score":0.7146801352500916},{"id":"https://openalex.org/C185798385","wikidata":"https://www.wikidata.org/wiki/Q1161707","display_name":"Benchmark (surveying)","level":2,"score":0.6401234865188599},{"id":"https://openalex.org/C190883126","wikidata":"https://www.wikidata.org/wiki/Q132874","display_name":"Lisp","level":2,"score":0.6273823976516724},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6049758791923523},{"id":"https://openalex.org/C77618280","wikidata":"https://www.wikidata.org/wiki/Q1155772","display_name":"Scheme (mathematics)","level":2,"score":0.5498669743537903},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5322909951210022},{"id":"https://openalex.org/C79581498","wikidata":"https://www.wikidata.org/wiki/Q1367530","display_name":"Suite","level":2,"score":0.527324378490448},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.47223520278930664},{"id":"https://openalex.org/C192209626","wikidata":"https://www.wikidata.org/wiki/Q190909","display_name":"Focus (optics)","level":2,"score":0.43825873732566833},{"id":"https://openalex.org/C122783720","wikidata":"https://www.wikidata.org/wiki/Q183065","display_name":"Interpreter","level":2,"score":0.4378896951675415},{"id":"https://openalex.org/C184670325","wikidata":"https://www.wikidata.org/wiki/Q512604","display_name":"Loop (graph theory)","level":2,"score":0.4333828091621399},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3207155466079712},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.19348794221878052},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C166957645","wikidata":"https://www.wikidata.org/wiki/Q23498","display_name":"Archaeology","level":1,"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/C95457728","wikidata":"https://www.wikidata.org/wiki/Q309","display_name":"History","level":0,"score":0.0},{"id":"https://openalex.org/C205649164","wikidata":"https://www.wikidata.org/wiki/Q1071","display_name":"Geography","level":0,"score":0.0},{"id":"https://openalex.org/C114614502","wikidata":"https://www.wikidata.org/wiki/Q76592","display_name":"Combinatorics","level":1,"score":0.0},{"id":"https://openalex.org/C120665830","wikidata":"https://www.wikidata.org/wiki/Q14620","display_name":"Optics","level":1,"score":0.0},{"id":"https://openalex.org/C13280743","wikidata":"https://www.wikidata.org/wiki/Q131089","display_name":"Geodesy","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/1869459.1869491","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1869459.1869491","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM international conference on Object oriented programming systems languages and applications","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":64,"referenced_works":["https://openalex.org/W171436000","https://openalex.org/W1486666371","https://openalex.org/W1492601037","https://openalex.org/W1494930385","https://openalex.org/W1503001724","https://openalex.org/W1528199841","https://openalex.org/W1542872339","https://openalex.org/W1555915743","https://openalex.org/W1568246207","https://openalex.org/W1578086264","https://openalex.org/W1583092647","https://openalex.org/W1604928976","https://openalex.org/W1842410071","https://openalex.org/W1968020161","https://openalex.org/W1983587324","https://openalex.org/W1983744444","https://openalex.org/W2000050212","https://openalex.org/W2002107083","https://openalex.org/W2007760863","https://openalex.org/W2016559894","https://openalex.org/W2017586706","https://openalex.org/W2020156556","https://openalex.org/W2024374951","https://openalex.org/W2034761517","https://openalex.org/W2045380064","https://openalex.org/W2049206910","https://openalex.org/W2054983537","https://openalex.org/W2057651724","https://openalex.org/W2064556673","https://openalex.org/W2070049093","https://openalex.org/W2070912453","https://openalex.org/W2074559757","https://openalex.org/W2080457852","https://openalex.org/W2089674328","https://openalex.org/W2096740961","https://openalex.org/W2101225843","https://openalex.org/W2101951782","https://openalex.org/W2104861744","https://openalex.org/W2108204150","https://openalex.org/W2109192102","https://openalex.org/W2116136092","https://openalex.org/W2118950848","https://openalex.org/W2122410182","https://openalex.org/W2123200683","https://openalex.org/W2124692036","https://openalex.org/W2126126443","https://openalex.org/W2135522367","https://openalex.org/W2141194372","https://openalex.org/W2143238865","https://openalex.org/W2155410188","https://openalex.org/W2160482662","https://openalex.org/W2161962607","https://openalex.org/W2395077608","https://openalex.org/W2514165658","https://openalex.org/W2955325419","https://openalex.org/W2998551599","https://openalex.org/W3151489216","https://openalex.org/W4205190765","https://openalex.org/W4242949098","https://openalex.org/W4252680206","https://openalex.org/W4256238177","https://openalex.org/W4285719527","https://openalex.org/W4298160452","https://openalex.org/W4298285990"],"related_works":["https://openalex.org/W2028766178","https://openalex.org/W1601755775","https://openalex.org/W4239564513","https://openalex.org/W2001586921","https://openalex.org/W2204482284","https://openalex.org/W4313143199","https://openalex.org/W2024370225","https://openalex.org/W1568883111","https://openalex.org/W1495312391","https://openalex.org/W2074559757"],"abstract_inverted_index":{"While":[0],"most":[1],"approaches":[2,9],"to":[3,44,81],"automatic":[4],"parallelization":[5],"focus":[6],"on":[7,109],"compilation":[8],"for":[10,18,102,122],"parallelizing":[11],"loop":[12],"iterations,":[13],"we":[14,33,94],"advocate":[15],"the":[16,25,61,71,82,86,96,114,118],"need":[17],"new":[19],"virtual":[20],"machines":[21],"that":[22,35,67],"can":[23,38],"parallelize":[24],"execution":[26],"of":[27,51,85,92,98],"recursive":[28,36],"programs.":[29],"In":[30],"this":[31],"paper,":[32],"show":[34,113],"programs":[37],"be":[39],"effectively":[40],"parallelized":[41,87],"when":[42],"arguments":[43],"procedures":[45],"are":[46,54],"evaluated":[47],"concurrently":[48,76],"and":[49,69,112],"branches":[50],"conditional":[52],"statements":[53],"speculatively":[55],"executed":[56],"in":[57,105],"parallel.":[58],"We":[59],"introduce":[60],"continuator":[62],"concept,":[63,93],"a":[64,90,99],"runtime":[65],"structure":[66],"tracks":[68],"manages":[70],"control":[72],"dependences":[73],"between":[74],"such":[75],"spawned":[77],"tasks,":[78],"ensuring":[79],"adherence":[80],"sequential":[83],"semantics":[84],"program.":[88],"As":[89],"proof":[91],"discuss":[95],"details":[97],"parallel":[100],"interpreter":[101],"Scheme":[103],"(implemented":[104],"Common":[106],"Lisp)":[107],"based":[108],"these":[110],"ideas,":[111],"results":[115],"from":[116],"executing":[117],"Clinger":[119],"benchmark":[120],"suite":[121],"Scheme.":[123]},"counts_by_year":[{"year":2017,"cited_by_count":1},{"year":2014,"cited_by_count":1},{"year":2013,"cited_by_count":1},{"year":2012,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
