{"id":"https://openalex.org/W1990069336","doi":"https://doi.org/10.1145/2814270.2814323","title":"Programming with enumerable sets of structures","display_name":"Programming with enumerable sets of structures","publication_year":2015,"publication_date":"2015-10-23","ids":{"openalex":"https://openalex.org/W1990069336","doi":"https://doi.org/10.1145/2814270.2814323","mag":"1990069336"},"language":"en","primary_location":{"id":"doi:10.1145/2814270.2814323","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2814270.2814323","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN International Conference on Object-Oriented Programming, Systems, Languages, and Applications","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"http://hdl.handle.net/1721.1/116136","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5060646261","display_name":"Ivan Kuraj","orcid":null},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Ivan Kuraj","raw_affiliation_strings":["Massachusetts Institute of Technology, USA","Massachusetts Institute Of Technology, USA"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]},{"raw_affiliation_string":"Massachusetts Institute Of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5008699657","display_name":"Viktor Kun\u010dak","orcid":"https://orcid.org/0000-0001-7044-9522"},"institutions":[{"id":"https://openalex.org/I174424907","display_name":"Laboratoire d'Informatique Fondamentale de Lille","ror":"https://ror.org/05rhg0h08","country_code":"FR","type":"facility","lineage":["https://openalex.org/I174424907"]},{"id":"https://openalex.org/I5124864","display_name":"\u00c9cole Polytechnique F\u00e9d\u00e9rale de Lausanne","ror":"https://ror.org/02s376052","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I5124864"]}],"countries":["CH","FR"],"is_corresponding":false,"raw_author_name":"Viktor Kuncak","raw_affiliation_strings":["EPFL, Switzerland","EPFL, SWITZERLAND"],"affiliations":[{"raw_affiliation_string":"EPFL, Switzerland","institution_ids":["https://openalex.org/I5124864"]},{"raw_affiliation_string":"EPFL, SWITZERLAND","institution_ids":["https://openalex.org/I174424907"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5101853727","display_name":"Daniel Jackson","orcid":"https://orcid.org/0000-0002-1097-0997"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Daniel Jackson","raw_affiliation_strings":["Massachusetts Institute of Technology, USA","Massachusetts Institute Of Technology, USA"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]},{"raw_affiliation_string":"Massachusetts Institute Of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]}],"institutions":[],"countries_distinct_count":3,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5060646261"],"corresponding_institution_ids":["https://openalex.org/I63966007"],"apc_list":null,"apc_paid":null,"fwci":9.8643,"has_fulltext":false,"cited_by_count":25,"citation_normalized_percentile":{"value":0.97765583,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"37","last_page":"56"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9991000294685364,"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"}},"topics":[{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9991000294685364,"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"}},{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9987999796867371,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9979000091552734,"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/enumeration","display_name":"Enumeration","score":0.9273960590362549},{"id":"https://openalex.org/keywords/backtracking","display_name":"Backtracking","score":0.8178547620773315},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7263899445533752},{"id":"https://openalex.org/keywords/combinatory-logic","display_name":"Combinatory logic","score":0.6795791983604431},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.5823008418083191},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.5407898426055908},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.48858126997947693},{"id":"https://openalex.org/keywords/process","display_name":"Process (computing)","score":0.46000176668167114},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.42230919003486633},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3472798466682434},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.22176912426948547},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.19183382391929626}],"concepts":[{"id":"https://openalex.org/C156340839","wikidata":"https://www.wikidata.org/wiki/Q2704791","display_name":"Enumeration","level":2,"score":0.9273960590362549},{"id":"https://openalex.org/C156884757","wikidata":"https://www.wikidata.org/wiki/Q798554","display_name":"Backtracking","level":2,"score":0.8178547620773315},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7263899445533752},{"id":"https://openalex.org/C79678938","wikidata":"https://www.wikidata.org/wiki/Q1481571","display_name":"Combinatory logic","level":2,"score":0.6795791983604431},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.5823008418083191},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.5407898426055908},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.48858126997947693},{"id":"https://openalex.org/C98045186","wikidata":"https://www.wikidata.org/wiki/Q205663","display_name":"Process (computing)","level":2,"score":0.46000176668167114},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.42230919003486633},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3472798466682434},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.22176912426948547},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.19183382391929626},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/2814270.2814323","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2814270.2814323","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN International Conference on Object-Oriented Programming, Systems, Languages, and Applications","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.715.3377","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.715.3377","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://lara.epfl.ch/%7Ekuncak/papers/KurajETAL15ProgrammingEnumerableSetsStructures.pdf","raw_type":"text"},{"id":"pmh:oai:dspace.mit.edu:1721.1/116136","is_oa":true,"landing_page_url":"http://hdl.handle.net/1721.1/116136","pdf_url":null,"source":{"id":"https://openalex.org/S4306400425","display_name":"DSpace@MIT (Massachusetts Institute of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I63966007","host_organization_name":"Massachusetts Institute of Technology","host_organization_lineage":["https://openalex.org/I63966007"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc-sa","license_id":"https://openalex.org/licenses/cc-by-nc-sa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"MIT Web Domain","raw_type":"http://purl.org/eprint/type/ConferencePaper"},{"id":"pmh:oai:infoscience.epfl.ch:216773","is_oa":true,"landing_page_url":"http://infoscience.epfl.ch/record/216773","pdf_url":null,"source":{"id":"https://openalex.org/S4306400487","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Text"}],"best_oa_location":{"id":"pmh:oai:dspace.mit.edu:1721.1/116136","is_oa":true,"landing_page_url":"http://hdl.handle.net/1721.1/116136","pdf_url":null,"source":{"id":"https://openalex.org/S4306400425","display_name":"DSpace@MIT (Massachusetts Institute of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I63966007","host_organization_name":"Massachusetts Institute of Technology","host_organization_lineage":["https://openalex.org/I63966007"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc-sa","license_id":"https://openalex.org/licenses/cc-by-nc-sa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"MIT Web Domain","raw_type":"http://purl.org/eprint/type/ConferencePaper"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":56,"referenced_works":["https://openalex.org/W21977468","https://openalex.org/W1495226832","https://openalex.org/W1507441114","https://openalex.org/W1544048926","https://openalex.org/W1563552952","https://openalex.org/W1564528735","https://openalex.org/W1650556305","https://openalex.org/W1822303551","https://openalex.org/W1948370231","https://openalex.org/W1965194038","https://openalex.org/W1976484136","https://openalex.org/W1979039632","https://openalex.org/W2005957051","https://openalex.org/W2029976661","https://openalex.org/W2030367896","https://openalex.org/W2031872041","https://openalex.org/W2032380869","https://openalex.org/W2043375653","https://openalex.org/W2047652936","https://openalex.org/W2058224907","https://openalex.org/W2060440626","https://openalex.org/W2064138295","https://openalex.org/W2070482555","https://openalex.org/W2074556793","https://openalex.org/W2091385303","https://openalex.org/W2091723900","https://openalex.org/W2103999647","https://openalex.org/W2115261880","https://openalex.org/W2115810994","https://openalex.org/W2118155805","https://openalex.org/W2118595631","https://openalex.org/W2119717320","https://openalex.org/W2125940008","https://openalex.org/W2132840411","https://openalex.org/W2135104168","https://openalex.org/W2138577276","https://openalex.org/W2142679626","https://openalex.org/W2146735819","https://openalex.org/W2152949134","https://openalex.org/W2155024733","https://openalex.org/W2157083801","https://openalex.org/W2157976942","https://openalex.org/W2159933174","https://openalex.org/W2162120832","https://openalex.org/W2164387399","https://openalex.org/W2170682382","https://openalex.org/W2248009306","https://openalex.org/W2999365512","https://openalex.org/W3005608680","https://openalex.org/W4231791389","https://openalex.org/W4243882797","https://openalex.org/W4244488020","https://openalex.org/W4246769448","https://openalex.org/W4253606798","https://openalex.org/W6633970301","https://openalex.org/W6677309063"],"related_works":["https://openalex.org/W2026765907","https://openalex.org/W4307413753","https://openalex.org/W108845024","https://openalex.org/W1975604118","https://openalex.org/W119766800","https://openalex.org/W2313450777","https://openalex.org/W2162268423","https://openalex.org/W2988498873","https://openalex.org/W4242826518","https://openalex.org/W2229588973"],"abstract_inverted_index":{"We":[0,137],"present":[1],"an":[2,123],"efficient,":[3],"modular,":[4],"and":[5,11,35,69,78,104,108,135,153],"feature-rich":[6],"framework":[7,28,55,121,141],"for":[8,17,129],"automated":[9],"generation":[10],"validation":[12],"of":[13,24,31,60,90,125,162],"complex":[14],"structures,":[15,100],"suitable":[16],"tasks":[18],"that":[19,132],"explore":[20],"a":[21,64,143,159],"large":[22],"space":[23],"structured":[25],"values.":[26],"Our":[27,120,148],"is":[29],"capable":[30],"exhaustive,":[32],"incremental,":[33],"parallel,":[34],"memoized":[36],"enumeration":[37,61,80,92,116],"from":[38],"not":[39],"only":[40],"finite":[41],"but":[42],"also":[43],"infinite":[44],"domains,":[45],"while":[46],"providing":[47],"fine-grained":[48],"control":[49],"over":[50],"the":[51,54,58,76,115],"process.":[52],"Furthermore,":[53],"efficiently":[56],"supports":[57],"inverse":[59],"(checking":[62],"whether":[63],"structure":[65,73],"can":[66],"be":[67],"generated":[68],"fast-forwarding":[70],"to":[71,74,98,117,158,165],"this":[72],"continue":[75],"enumeration)":[77],"lazy":[79],"(achieving":[81],"exhaustive":[82],"testing":[83],"without":[84],"generating":[85],"all":[86],"structures).":[87],"The":[88],"foundation":[89],"efficient":[91],"lies":[93],"in":[94,146],"both":[95],"direct":[96],"access":[97],"encoded":[99],"achieved":[101],"with":[102,127],"well-known":[103],"new":[105],"pairing":[106],"functions,":[107],"dependent":[109],"enumeration,":[110],"which":[111],"embeds":[112],"constraints":[113],"into":[114],"avoid":[118],"backtracking.":[119],"defines":[122],"algebra":[124],"enumerators,":[126],"combinators":[128],"their":[130],"composition":[131],"preserve":[133],"exhaustiveness":[134],"efficiency.":[136],"have":[138],"implemented":[139],"our":[140],"as":[142],"domain-specific":[144],"language":[145],"Scala.":[147],"experiments":[149],"demonstrate":[150],"better":[151],"performance":[152],"shorter":[154],"specifications":[155],"by":[156],"up":[157],"few":[160],"orders":[161],"magnitude":[163],"compared":[164],"existing":[166],"approaches.":[167]},"counts_by_year":[{"year":2023,"cited_by_count":2},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":5},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":3},{"year":2017,"cited_by_count":8},{"year":2016,"cited_by_count":4}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
