{"id":"https://openalex.org/W2070203924","doi":"https://doi.org/10.1145/1086365.1086374","title":"Dynamic optimization for functional reactive programming using generalized algebraic data types","display_name":"Dynamic optimization for functional reactive programming using generalized algebraic data types","publication_year":2005,"publication_date":"2005-09-12","ids":{"openalex":"https://openalex.org/W2070203924","doi":"https://doi.org/10.1145/1086365.1086374","mag":"2070203924"},"language":"en","primary_location":{"id":"doi:10.1145/1086365.1086374","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1086365.1086374","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the tenth ACM SIGPLAN international conference on Functional programming","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/A5014442955","display_name":"Henrik Nilsson","orcid":"https://orcid.org/0000-0001-5045-8691"},"institutions":[{"id":"https://openalex.org/I142263535","display_name":"University of Nottingham","ror":"https://ror.org/01ee9ar58","country_code":"GB","type":"education","lineage":["https://openalex.org/I142263535"]}],"countries":["GB"],"is_corresponding":true,"raw_author_name":"Henrik Nilsson","raw_affiliation_strings":["University of Nottingham"],"affiliations":[{"raw_affiliation_string":"University of Nottingham","institution_ids":["https://openalex.org/I142263535"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5014442955"],"corresponding_institution_ids":["https://openalex.org/I142263535"],"apc_list":null,"apc_paid":null,"fwci":2.7402,"has_fulltext":false,"cited_by_count":31,"citation_normalized_percentile":{"value":0.90997226,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"54","last_page":"65"},"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.9987000226974487,"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.9987000226974487,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9958000183105469,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.9263657331466675},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8769327402114868},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.7820318937301636},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7268881797790527},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6814457178115845},{"id":"https://openalex.org/keywords/domain-specific-language","display_name":"Domain-specific language","score":0.6267474889755249},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.5870026350021362},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.5035044550895691},{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.501434326171875},{"id":"https://openalex.org/keywords/scope","display_name":"Scope (computer science)","score":0.4987761974334717},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.48081791400909424},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4560622274875641}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9263657331466675},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8769327402114868},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.7820318937301636},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7268881797790527},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6814457178115845},{"id":"https://openalex.org/C135257023","wikidata":"https://www.wikidata.org/wiki/Q691358","display_name":"Domain-specific language","level":2,"score":0.6267474889755249},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.5870026350021362},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.5035044550895691},{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.501434326171875},{"id":"https://openalex.org/C2778012447","wikidata":"https://www.wikidata.org/wiki/Q1034415","display_name":"Scope (computer science)","level":2,"score":0.4987761974334717},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.48081791400909424},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4560622274875641},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","level":1,"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/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1086365.1086374","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1086365.1086374","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the tenth ACM SIGPLAN international conference on Functional programming","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.102.7810","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.102.7810","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.nott.ac.uk/~nhn/Publications/icfp2005.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"score":0.7099999785423279,"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4"}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":30,"referenced_works":["https://openalex.org/W1488750823","https://openalex.org/W1508259349","https://openalex.org/W1509606339","https://openalex.org/W1550049051","https://openalex.org/W1590769334","https://openalex.org/W1663179985","https://openalex.org/W1839902311","https://openalex.org/W1875562881","https://openalex.org/W1966458383","https://openalex.org/W1968464751","https://openalex.org/W1970757850","https://openalex.org/W1995969393","https://openalex.org/W2049440551","https://openalex.org/W2064138295","https://openalex.org/W2070998289","https://openalex.org/W2072644784","https://openalex.org/W2079512738","https://openalex.org/W2081938726","https://openalex.org/W2104896892","https://openalex.org/W2116435685","https://openalex.org/W2121754567","https://openalex.org/W2125415493","https://openalex.org/W2147340401","https://openalex.org/W2147417170","https://openalex.org/W2149935768","https://openalex.org/W2499340346","https://openalex.org/W2561675875","https://openalex.org/W4214684006","https://openalex.org/W4285719527","https://openalex.org/W6811215404"],"related_works":["https://openalex.org/W2090337950","https://openalex.org/W2046806568","https://openalex.org/W3004782279","https://openalex.org/W1602185604","https://openalex.org/W2112263414","https://openalex.org/W2493130382","https://openalex.org/W2145738007","https://openalex.org/W2971609332","https://openalex.org/W2110095505","https://openalex.org/W2779713464"],"abstract_inverted_index":{"A":[0],"limited":[1],"form":[2,103],"of":[3,19,54,71,87,92,104,121,130,152,172,208],"dependent":[4,32],"types,":[5,33],"called":[6],"Generalized":[7],"Algebraic":[8],"Data":[9],"Types":[10],"(GADTs),":[11],"has":[12,113],"recently":[13],"been":[14],"added":[15],"to":[16,117,159,168,182,223],"the":[17,24,51,64,85,90,102,148,153,170,184,191,199,224,236,244],"list":[18],"Haskell":[20,26,108],"extensions":[21],"supported":[22],"by":[23],"Glasgow":[25],"Compiler.":[27],"Despite":[28],"not":[29,157],"being":[30],"full-fledged":[31],"GADTs":[34,49,88,123],"still":[35],"offer":[36,50],"considerably":[37],"enlarged":[38],"scope":[39],"for":[40,97,136,190,215],"enforcing":[41],"important":[42],"code":[43],"and":[44,74,175],"data":[45,76],"invariants":[46,61],"statically.":[47],"Moreover,":[48],"tantalizing":[52],"possibility":[53],"writing":[55],"more":[56,239],"efficient":[57],"programs":[58],"since":[59],"capturing":[60],"statically":[62],"through":[63],"type":[65],"system":[66],"sometimes":[67],"obviates":[68],"entire":[69],"layers":[70],"dynamic":[72],"tests":[73],"associated":[75],"markup.":[77],"This":[78,196],"paper":[79,112],"is":[80,156],"a":[81,94,105,206,226],"case":[82,234],"study":[83],"on":[84,164,176],"applications":[86],"in":[89,101,126,142,232,243],"context":[91],"Yampa,":[93],"domain-specific":[95,138],"language":[96,140],"Functional":[98],"Reactive":[99],"Programming":[100],"self-optimizing,":[106],"arrow-based":[107,144],"combinator":[109],"library.":[110],"The":[111,187],"two":[114,177],"aims.":[115],"Firstly,":[116],"explore":[118],"what":[119],"kind":[120],"optimizations":[122,155],"make":[124],"possible":[125],"this":[127,161],"context.":[128],"Much":[129],"that":[131,198,211],"should":[132],"also":[133],"be":[134,203],"relevant":[135],"other":[137],"embedded":[139],"implementations,":[141],"particular":[143],"ones.":[145],"Secondly,":[146],"as":[147,205],"actual":[149],"performance":[150,188,216,228,237],"impact":[151],"GADT-based":[154],"obvious,":[158],"quantify":[160],"impact,":[162],"both":[163],"tailored":[165],"micro":[166,192],"benchmarks,":[167],"establish":[169],"effectiveness":[171],"individual":[173],"optimizations,":[174],"fairly":[178],"large,":[179],"realistic":[180],"applications,":[181,225],"gauge":[183],"overall":[185],"impact.":[186],"gains":[189],"benchmarks":[193],"are":[194,218],"substantial.":[195],"implies":[197],"Yampa":[200],"API":[201],"could":[202],"simplified":[204],"number":[207],"\"pre-composed\"":[209],"primitives":[210],"were":[212],"there":[213],"mainly":[214],"reasons":[217],"no":[219],"longer":[220],"needed.":[221],"As":[222],"worthwhile":[227],"gain":[229],"was":[230,238],"obtained":[231],"one":[233],"whereas":[235],"or":[240],"less":[241],"unchanged":[242],"other.":[245]},"counts_by_year":[{"year":2023,"cited_by_count":2},{"year":2019,"cited_by_count":1},{"year":2016,"cited_by_count":4},{"year":2015,"cited_by_count":2},{"year":2013,"cited_by_count":5},{"year":2012,"cited_by_count":2}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
