{"id":"https://openalex.org/W2155780123","doi":"https://doi.org/10.1145/2371401.2371407","title":"Synthesizing iterators from abstraction functions","display_name":"Synthesizing iterators from abstraction functions","publication_year":2012,"publication_date":"2012-09-26","ids":{"openalex":"https://openalex.org/W2155780123","doi":"https://doi.org/10.1145/2371401.2371407","mag":"2155780123"},"language":"en","primary_location":{"id":"doi:10.1145/2371401.2371407","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2371401.2371407","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 11th International Conference on Generative Programming and Component Engineering","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/A5091689542","display_name":"Derek Rayside","orcid":null},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":true,"raw_author_name":"Derek Rayside","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5004030629","display_name":"Vajihollah Montaghami","orcid":null},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Vajihollah Montaghami","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5090884687","display_name":"Francesca Leung","orcid":null},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Francesca Leung","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5047273633","display_name":"Albert Yuen","orcid":null},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Albert Yuen","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5102153874","display_name":"Kevin Xu","orcid":null},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Kevin Xu","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5101853727","display_name":"Daniel Jackson","orcid":"https://orcid.org/0000-0002-1097-0997"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Daniel Jackson","raw_affiliation_strings":["MIT CSAIL"],"affiliations":[{"raw_affiliation_string":"MIT CSAIL","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":6,"corresponding_author_ids":["https://openalex.org/A5091689542"],"corresponding_institution_ids":["https://openalex.org/I151746483"],"apc_list":null,"apc_paid":null,"fwci":2.3598,"has_fulltext":false,"cited_by_count":10,"citation_normalized_percentile":{"value":0.90203396,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":null,"issue":null,"first_page":"31","last_page":"40"},"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.9998000264167786,"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.9998000264167786,"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/T10142","display_name":"Formal Methods in Verification","score":0.9997000098228455,"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/T12423","display_name":"Software Reliability and Analysis Research","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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8304879665374756},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7000364065170288},{"id":"https://openalex.org/keywords/transitive-closure","display_name":"Transitive closure","score":0.694852352142334},{"id":"https://openalex.org/keywords/tuple","display_name":"Tuple","score":0.638563871383667},{"id":"https://openalex.org/keywords/tree-traversal","display_name":"Tree traversal","score":0.6356561183929443},{"id":"https://openalex.org/keywords/reachability","display_name":"Reachability","score":0.5397158265113831},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.44088485836982727},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.11427611112594604}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8304879665374756},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7000364065170288},{"id":"https://openalex.org/C128896722","wikidata":"https://www.wikidata.org/wiki/Q1501387","display_name":"Transitive closure","level":2,"score":0.694852352142334},{"id":"https://openalex.org/C118930307","wikidata":"https://www.wikidata.org/wiki/Q600590","display_name":"Tuple","level":2,"score":0.638563871383667},{"id":"https://openalex.org/C140745168","wikidata":"https://www.wikidata.org/wiki/Q1210082","display_name":"Tree traversal","level":2,"score":0.6356561183929443},{"id":"https://openalex.org/C136643341","wikidata":"https://www.wikidata.org/wiki/Q1361526","display_name":"Reachability","level":2,"score":0.5397158265113831},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.44088485836982727},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.11427611112594604},{"id":"https://openalex.org/C114614502","wikidata":"https://www.wikidata.org/wiki/Q76592","display_name":"Combinatorics","level":1,"score":0.0},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2371401.2371407","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2371401.2371407","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 11th International Conference on Generative Programming and Component Engineering","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":63,"referenced_works":["https://openalex.org/W60733025","https://openalex.org/W122118143","https://openalex.org/W166724137","https://openalex.org/W1480731572","https://openalex.org/W1481333791","https://openalex.org/W1485766696","https://openalex.org/W1519503479","https://openalex.org/W1531781692","https://openalex.org/W1532939744","https://openalex.org/W1541759503","https://openalex.org/W1546460551","https://openalex.org/W1552647623","https://openalex.org/W1557470769","https://openalex.org/W1587947078","https://openalex.org/W1588812554","https://openalex.org/W1895387792","https://openalex.org/W1964830323","https://openalex.org/W1970113369","https://openalex.org/W1975442062","https://openalex.org/W1982328732","https://openalex.org/W2009245364","https://openalex.org/W2012189654","https://openalex.org/W2023878728","https://openalex.org/W2038917144","https://openalex.org/W2048872634","https://openalex.org/W2091089602","https://openalex.org/W2093896470","https://openalex.org/W2094160561","https://openalex.org/W2104376684","https://openalex.org/W2107709519","https://openalex.org/W2107778618","https://openalex.org/W2110050316","https://openalex.org/W2114222087","https://openalex.org/W2115900163","https://openalex.org/W2128953477","https://openalex.org/W2129304537","https://openalex.org/W2131351054","https://openalex.org/W2131364475","https://openalex.org/W2137824953","https://openalex.org/W2145751310","https://openalex.org/W2147650421","https://openalex.org/W2165247635","https://openalex.org/W2168617729","https://openalex.org/W2171119274","https://openalex.org/W2208923056","https://openalex.org/W2243801415","https://openalex.org/W2295387843","https://openalex.org/W2295917400","https://openalex.org/W2321831709","https://openalex.org/W2752885492","https://openalex.org/W2936157456","https://openalex.org/W3023216518","https://openalex.org/W3145128584","https://openalex.org/W4210727445","https://openalex.org/W4214807841","https://openalex.org/W4386688170","https://openalex.org/W6629210407","https://openalex.org/W6631080801","https://openalex.org/W6631881778","https://openalex.org/W6633088893","https://openalex.org/W6683942877","https://openalex.org/W6685424916","https://openalex.org/W7029321148"],"related_works":["https://openalex.org/W2127267268","https://openalex.org/W2136512912","https://openalex.org/W170547082","https://openalex.org/W2067910792","https://openalex.org/W2156446763","https://openalex.org/W2136735429","https://openalex.org/W2143461633","https://openalex.org/W4250225510","https://openalex.org/W1979520342","https://openalex.org/W2963892764"],"abstract_inverted_index":{"A":[0],"technique":[1],"for":[2,29],"synthesizing":[3],"iterators":[4],"from":[5],"declarative":[6],"abstraction":[7],"functions":[8],"written":[9],"in":[10],"a":[11,21],"relational":[12],"logic":[13,19],"specification":[14],"language":[15],"is":[16],"described.":[17],"The":[18],"includes":[20],"transitive":[22],"closure":[23],"operator":[24],"that":[25],"makes":[26],"it":[27],"convenient":[28],"expressing":[30],"reachability":[31],"queries":[32],"on":[33],"linked":[34],"data":[35],"structures.":[36],"Some":[37],"optimizations,":[38],"including":[39],"tuple":[40],"elimination,":[41],"iterator":[42],"flattening,":[43],"and":[44],"traversal":[45],"state":[46],"reduction,":[47],"are":[48],"used":[49],"to":[50],"improve":[51],"performance":[52],"of":[53],"the":[54],"generated":[55],"iterators.":[56]},"counts_by_year":[{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2015,"cited_by_count":2},{"year":2014,"cited_by_count":1},{"year":2013,"cited_by_count":3}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
