{"id":"https://openalex.org/W2017543653","doi":"https://doi.org/10.1145/1480945.1480959","title":"A flexible framework for programming with non-deterministicfunctions","display_name":"A flexible framework for programming with non-deterministicfunctions","publication_year":2009,"publication_date":"2009-01-19","ids":{"openalex":"https://openalex.org/W2017543653","doi":"https://doi.org/10.1145/1480945.1480959","mag":"2017543653"},"language":"en","primary_location":{"id":"doi:10.1145/1480945.1480959","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1480945.1480959","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2009 ACM SIGPLAN workshop on Partial evaluation and program manipulation","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/A5073297779","display_name":"Francisco J. L\u00f3pez-Fraguas","orcid":"https://orcid.org/0000-0001-8898-8647"},"institutions":[{"id":"https://openalex.org/I121748325","display_name":"Universidad Complutense de Madrid","ror":"https://ror.org/02p0gd045","country_code":"ES","type":"education","lineage":["https://openalex.org/I121748325"]}],"countries":["ES"],"is_corresponding":true,"raw_author_name":"Francisco J. Lopez-Fraguas","raw_affiliation_strings":["Universidad Complutense de Madrid, Madrid, Spain"],"affiliations":[{"raw_affiliation_string":"Universidad Complutense de Madrid, Madrid, Spain","institution_ids":["https://openalex.org/I121748325"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5024844226","display_name":"Juan Rodr\u00edguez-Hortal\u00e1","orcid":null},"institutions":[{"id":"https://openalex.org/I121748325","display_name":"Universidad Complutense de Madrid","ror":"https://ror.org/02p0gd045","country_code":"ES","type":"education","lineage":["https://openalex.org/I121748325"]}],"countries":["ES"],"is_corresponding":false,"raw_author_name":"Juan Rodriguez-Hortala","raw_affiliation_strings":["Universidad Complutense de Madrid, Madrid, Spain"],"affiliations":[{"raw_affiliation_string":"Universidad Complutense de Madrid, Madrid, Spain","institution_ids":["https://openalex.org/I121748325"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5061438901","display_name":"Jaime S\u00e1nchez-Hern\u00e1ndez","orcid":"https://orcid.org/0000-0002-8940-5543"},"institutions":[{"id":"https://openalex.org/I121748325","display_name":"Universidad Complutense de Madrid","ror":"https://ror.org/02p0gd045","country_code":"ES","type":"education","lineage":["https://openalex.org/I121748325"]}],"countries":["ES"],"is_corresponding":false,"raw_author_name":"Jaime Sanchez-Hernandez","raw_affiliation_strings":["Universidad Complutense de Madrid, Madrid, Spain"],"affiliations":[{"raw_affiliation_string":"Universidad Complutense de Madrid, Madrid, Spain","institution_ids":["https://openalex.org/I121748325"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5073297779"],"corresponding_institution_ids":["https://openalex.org/I121748325"],"apc_list":null,"apc_paid":null,"fwci":2.6171,"has_fulltext":false,"cited_by_count":8,"citation_normalized_percentile":{"value":0.90396122,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"91","last_page":"100"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998999834060669,"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"}},"topics":[{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998999834060669,"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/T10142","display_name":"Formal Methods in Verification","score":0.9979000091552734,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"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/T10260","display_name":"Software Engineering Research","score":0.9955000281333923,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/rewriting","display_name":"Rewriting","score":0.8544920086860657},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8286218643188477},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6869720816612244},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.660773515701294},{"id":"https://openalex.org/keywords/lazy-evaluation","display_name":"Lazy evaluation","score":0.6534382104873657},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.6384941339492798},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.5980884432792664},{"id":"https://openalex.org/keywords/embedding","display_name":"Embedding","score":0.5359853506088257},{"id":"https://openalex.org/keywords/construct","display_name":"Construct (python library)","score":0.5001175403594971},{"id":"https://openalex.org/keywords/function","display_name":"Function (biology)","score":0.4347842335700989},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.41672295331954956},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.19498786330223083}],"concepts":[{"id":"https://openalex.org/C154690210","wikidata":"https://www.wikidata.org/wiki/Q1668499","display_name":"Rewriting","level":2,"score":0.8544920086860657},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8286218643188477},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6869720816612244},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.660773515701294},{"id":"https://openalex.org/C128099668","wikidata":"https://www.wikidata.org/wiki/Q573952","display_name":"Lazy evaluation","level":3,"score":0.6534382104873657},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.6384941339492798},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.5980884432792664},{"id":"https://openalex.org/C41608201","wikidata":"https://www.wikidata.org/wiki/Q980509","display_name":"Embedding","level":2,"score":0.5359853506088257},{"id":"https://openalex.org/C2780801425","wikidata":"https://www.wikidata.org/wiki/Q5164392","display_name":"Construct (python library)","level":2,"score":0.5001175403594971},{"id":"https://openalex.org/C14036430","wikidata":"https://www.wikidata.org/wiki/Q3736076","display_name":"Function (biology)","level":2,"score":0.4347842335700989},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.41672295331954956},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.19498786330223083},{"id":"https://openalex.org/C78458016","wikidata":"https://www.wikidata.org/wiki/Q840400","display_name":"Evolutionary biology","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}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/1480945.1480959","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1480945.1480959","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2009 ACM SIGPLAN workshop on Partial evaluation and program manipulation","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/4","score":0.5899999737739563,"display_name":"Quality Education"}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":27,"referenced_works":["https://openalex.org/W78995489","https://openalex.org/W205382243","https://openalex.org/W1512480360","https://openalex.org/W1521843416","https://openalex.org/W1522154830","https://openalex.org/W1539487186","https://openalex.org/W1753263750","https://openalex.org/W1980781982","https://openalex.org/W2004843654","https://openalex.org/W2010331618","https://openalex.org/W2017543653","https://openalex.org/W2023922836","https://openalex.org/W2030663607","https://openalex.org/W2044013129","https://openalex.org/W2053867970","https://openalex.org/W2063521547","https://openalex.org/W2089241138","https://openalex.org/W2089674328","https://openalex.org/W2105144754","https://openalex.org/W2112022010","https://openalex.org/W2119156278","https://openalex.org/W2137198597","https://openalex.org/W2138319635","https://openalex.org/W2168144301","https://openalex.org/W2394749920","https://openalex.org/W4214503682","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W1553079342","https://openalex.org/W2764317176","https://openalex.org/W2168393711","https://openalex.org/W778229461","https://openalex.org/W2099473324","https://openalex.org/W1516233466","https://openalex.org/W4451720","https://openalex.org/W2079778730","https://openalex.org/W135379672","https://openalex.org/W2182584643"],"abstract_inverted_index":{"The":[0,126],"possibility":[1],"of":[2,9,35,107,150,156,169,176,185],"non-deterministic":[3],"reductions":[4],"is":[5,29,59,128],"a":[6,22,74,91,102,119,129,157],"distinctive":[7],"feature":[8],"some":[10],"declarative":[11],"languages.":[12],"Two":[13],"semantics":[14,58,78],"commonly":[15],"adopted":[16],"for":[17],"non-determinism":[18],"are":[19,53,87],"call-time":[20,124,140,170],"choice--":[21,114,152],"notion":[23],"that":[24],"at":[25],"the":[26,32,77,148,167,174,177,186],"operational":[27],"level":[28],"related":[30],"to":[31,47,70,81,100,122],"sharing":[33],"mechanism":[34],"lazy":[36],"evaluation":[37],"in":[38,63,73,163],"functional":[39],"languages--":[40],"and":[41],"run-time":[42,113,138,151],"choice,":[43],"which":[44,133],"corresponds":[45],"closely":[46],"ordinary":[48,108],"term":[49],"rewriting.":[50],"But":[51],"there":[52],"practical":[54],"situations":[55],"where":[56],"neither":[57],"appropriate,":[60],"if":[61],"used":[62],"isolation.":[64],"In":[65],"this":[66],"paper":[67],"we":[68],"propose":[69],"annotate":[71],"functions":[72],"program":[75,159],"with":[76,112,115],"most":[79],"adequate":[80],"its":[82],"intended":[83],"use.":[84],"Annotated":[85],"programs":[86],"then":[88],"mapped":[89],"into":[90,132],"unified":[92],"core":[93],"language":[94],"(but":[95],"still":[96],"high":[97],"level),":[98],"designed":[99],"achieve":[101],"careful":[103],"but":[104],"neat":[105],"combination":[106],"rewriting":[109],"--to":[110],"cope":[111],"local":[116],"bindings":[117],"via":[118],"let-construct":[120],"devised":[121],"express":[123],"choice.":[125],"result":[127],"flexible":[130],"framework":[131],"existing":[134],"languages":[135],"using":[136],"pure":[137],"or":[139,153],"choice":[141],"can":[142],"be":[143],"embedded,":[144],"either":[145],"directly":[146],"--in":[147],"case":[149,168],"by":[154],"means":[155],"simple":[158],"transformation":[160],"introducing":[161],"lets":[162],"function":[164],"definitions":[165],"--for":[166],"choice--.":[171],"We":[172],"prove":[173],"adequacy":[175],"embedding,":[178],"as":[179,181],"well":[180],"other":[182],"relevant":[183],"properties":[184],"framework.":[187]},"counts_by_year":[{"year":2013,"cited_by_count":1},{"year":2012,"cited_by_count":2}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
