{"id":"https://openalex.org/W2040687117","doi":"https://doi.org/10.1007/s00165-003-0013-6","title":"Disciplined, efficient, generalised folds for nested datatypes","display_name":"Disciplined, efficient, generalised folds for nested datatypes","publication_year":2004,"publication_date":"2004-03-29","ids":{"openalex":"https://openalex.org/W2040687117","doi":"https://doi.org/10.1007/s00165-003-0013-6","mag":"2040687117"},"language":"en","primary_location":{"id":"doi:10.1007/s00165-003-0013-6","is_oa":true,"landing_page_url":"https://doi.org/10.1007/s00165-003-0013-6","pdf_url":"https://dl.acm.org/doi/pdf/10.1007/s00165-003-0013-6","source":{"id":"https://openalex.org/S128250343","display_name":"Formal Aspects of Computing","issn_l":"0934-5043","issn":["0934-5043","1433-299X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Formal Aspects of Computing","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://dl.acm.org/doi/pdf/10.1007/s00165-003-0013-6","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5009373953","display_name":"Clare Martin","orcid":"https://orcid.org/0000-0002-3147-3746"},"institutions":[{"id":"https://openalex.org/I124261462","display_name":"Oxford Brookes University","ror":"https://ror.org/04v2twj65","country_code":"GB","type":"education","lineage":["https://openalex.org/I124261462"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Clare Martin","raw_affiliation_strings":["School of Computing and Mathematical Sciences, Oxford Brookes University, Oxford, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"School of Computing and Mathematical Sciences, Oxford Brookes University, Oxford, UK","institution_ids":["https://openalex.org/I124261462"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5086558126","display_name":"Jeremy Gibbons","orcid":"https://orcid.org/0000-0002-8426-9917"},"institutions":[{"id":"https://openalex.org/I40120149","display_name":"University of Oxford","ror":"https://ror.org/052gg0110","country_code":"GB","type":"education","lineage":["https://openalex.org/I40120149"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Jeremy Gibbons","raw_affiliation_strings":["Oxford University Computing Laboratory, Oxford, UK","Oxford University Computing Laboratory, School of Computing and Mathematical Sciences, UK#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Oxford University Computing Laboratory, Oxford, UK","institution_ids":["https://openalex.org/I40120149"]},{"raw_affiliation_string":"Oxford University Computing Laboratory, School of Computing and Mathematical Sciences, UK#TAB#","institution_ids":["https://openalex.org/I40120149"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5008165707","display_name":"Ian Bayley","orcid":null},"institutions":[{"id":"https://openalex.org/I40120149","display_name":"University of Oxford","ror":"https://ror.org/052gg0110","country_code":"GB","type":"education","lineage":["https://openalex.org/I40120149"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Ian Bayley","raw_affiliation_strings":["Oxford University Computing Laboratory, Oxford, UK","Oxford University Computing Laboratory, School of Computing and Mathematical Sciences, UK#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Oxford University Computing Laboratory, Oxford, UK","institution_ids":["https://openalex.org/I40120149"]},{"raw_affiliation_string":"Oxford University Computing Laboratory, School of Computing and Mathematical Sciences, UK#TAB#","institution_ids":["https://openalex.org/I40120149"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":3.7009,"has_fulltext":true,"cited_by_count":28,"citation_normalized_percentile":{"value":0.93120417,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":97},"biblio":{"volume":"16","issue":"1","first_page":"19","last_page":"35"},"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.9973000288009644,"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.9973000288009644,"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/T10260","display_name":"Software Engineering Research","score":0.9958000183105469,"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/T10317","display_name":"Advanced Database Systems and Queries","score":0.9936000108718872,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/theory-of-computation","display_name":"Theory of computation","score":0.7921673059463501},{"id":"https://openalex.org/keywords/fold","display_name":"Fold (higher-order function)","score":0.6638102531433105},{"id":"https://openalex.org/keywords/categorical-variable","display_name":"Categorical variable","score":0.6011077165603638},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.5290046334266663},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.5238732695579529},{"id":"https://openalex.org/keywords/inefficiency","display_name":"Inefficiency","score":0.5209516286849976},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.4525716006755829},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3803873360157013},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3339824676513672},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.13440346717834473},{"id":"https://openalex.org/keywords/geology","display_name":"Geology","score":0.09519419074058533},{"id":"https://openalex.org/keywords/paleontology","display_name":"Paleontology","score":0.07017505168914795},{"id":"https://openalex.org/keywords/machine-learning","display_name":"Machine learning","score":0.06742686033248901}],"concepts":[{"id":"https://openalex.org/C24858836","wikidata":"https://www.wikidata.org/wiki/Q844718","display_name":"Theory of computation","level":2,"score":0.7921673059463501},{"id":"https://openalex.org/C53942344","wikidata":"https://www.wikidata.org/wiki/Q951651","display_name":"Fold (higher-order function)","level":2,"score":0.6638102531433105},{"id":"https://openalex.org/C5274069","wikidata":"https://www.wikidata.org/wiki/Q2285707","display_name":"Categorical variable","level":2,"score":0.6011077165603638},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.5290046334266663},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.5238732695579529},{"id":"https://openalex.org/C2778869765","wikidata":"https://www.wikidata.org/wiki/Q6028363","display_name":"Inefficiency","level":2,"score":0.5209516286849976},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.4525716006755829},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3803873360157013},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3339824676513672},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.13440346717834473},{"id":"https://openalex.org/C127313418","wikidata":"https://www.wikidata.org/wiki/Q1069","display_name":"Geology","level":0,"score":0.09519419074058533},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","level":1,"score":0.07017505168914795},{"id":"https://openalex.org/C119857082","wikidata":"https://www.wikidata.org/wiki/Q2539","display_name":"Machine learning","level":1,"score":0.06742686033248901},{"id":"https://openalex.org/C162324750","wikidata":"https://www.wikidata.org/wiki/Q8134","display_name":"Economics","level":0,"score":0.0},{"id":"https://openalex.org/C175444787","wikidata":"https://www.wikidata.org/wiki/Q39072","display_name":"Microeconomics","level":1,"score":0.0}],"mesh":[],"locations_count":5,"locations":[{"id":"doi:10.1007/s00165-003-0013-6","is_oa":true,"landing_page_url":"https://doi.org/10.1007/s00165-003-0013-6","pdf_url":"https://dl.acm.org/doi/pdf/10.1007/s00165-003-0013-6","source":{"id":"https://openalex.org/S128250343","display_name":"Formal Aspects of Computing","issn_l":"0934-5043","issn":["0934-5043","1433-299X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Formal Aspects of Computing","raw_type":"journal-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.159.1577","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.159.1577","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.comlab.ox.ac.uk/oucl/work/jeremy.gibbons/publications/efolds.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.16.8985","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.16.8985","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://web.comlab.ox.ac.uk/oucl/work/jeremy.gibbons/publications/efolds.pdf","raw_type":"text"},{"id":"pmh:oai:ora.ox.ac.uk:uuid:e4d24e52-abb4-4764-b120-4f57ba6749ed","is_oa":false,"landing_page_url":"https://ora.ox.ac.uk/objects/uuid:e4d24e52-abb4-4764-b120-4f57ba6749ed","pdf_url":null,"source":{"id":"https://openalex.org/S4306402636","display_name":"Oxford University Research Archive (ORA) (University of Oxford)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I40120149","host_organization_name":"University of Oxford","host_organization_lineage":["https://openalex.org/I40120149"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Symplectic Elements at Oxford","raw_type":"Journal article"},{"id":"pmh:oai:ora.ox.ac.uk:uuid:e67c8494-5c28-43a4-8534-2dc2e1b361b6","is_oa":false,"landing_page_url":"https://ora.ox.ac.uk/objects/uuid:e67c8494-5c28-43a4-8534-2dc2e1b361b6","pdf_url":null,"source":{"id":"https://openalex.org/S4306402636","display_name":"Oxford University Research Archive (ORA) (University of Oxford)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I40120149","host_organization_name":"University of Oxford","host_organization_lineage":["https://openalex.org/I40120149"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Department of Computer Science","raw_type":"Journal article"}],"best_oa_location":{"id":"doi:10.1007/s00165-003-0013-6","is_oa":true,"landing_page_url":"https://doi.org/10.1007/s00165-003-0013-6","pdf_url":"https://dl.acm.org/doi/pdf/10.1007/s00165-003-0013-6","source":{"id":"https://openalex.org/S128250343","display_name":"Formal Aspects of Computing","issn_l":"0934-5043","issn":["0934-5043","1433-299X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Formal Aspects of Computing","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2040687117.pdf","grobid_xml":"https://content.openalex.org/works/W2040687117.grobid-xml"},"referenced_works_count":14,"referenced_works":["https://openalex.org/W1492124994","https://openalex.org/W1504424419","https://openalex.org/W1556536463","https://openalex.org/W1563218161","https://openalex.org/W1571615440","https://openalex.org/W1939765599","https://openalex.org/W2005501477","https://openalex.org/W2034676877","https://openalex.org/W2105045857","https://openalex.org/W2120713972","https://openalex.org/W2123360309","https://openalex.org/W2151015971","https://openalex.org/W2167373162","https://openalex.org/W2913811625"],"related_works":["https://openalex.org/W2349865494","https://openalex.org/W2372553222","https://openalex.org/W3157620392","https://openalex.org/W2925832130","https://openalex.org/W2045715842","https://openalex.org/W2377441856","https://openalex.org/W2105880240","https://openalex.org/W1996301369","https://openalex.org/W2019004897","https://openalex.org/W2566242093"],"abstract_inverted_index":{"Abstract.":[0],"Nested":[1],"(or":[2],"non-uniform,":[3],"or":[4,74],"non-regular)":[5],"datatypes":[6],"have":[7],"recursive":[8],"definitions":[9],"in":[10,20,65],"which":[11],"the":[12,37,81,90,96],"type":[13,24],"parameter":[14],"changes.":[15],"Their":[16],"folds":[17,31,44,57],"are":[18],"restricted":[19],"power":[21],"due":[22],"to":[23,51,58],"constraints.":[25],"Bird":[26,101],"and":[27,102],"Paterson":[28],"introduced":[29,54],"generalised":[30,56],"for":[32,85],"extra":[33],"power,":[34],"but":[35,62],"at":[36],"cost":[38],"of":[39,42,92,100],"a":[40,66],"loss":[41],"efficiency:":[43],"may":[45],"take":[46],"more":[47],"than":[48],"linear":[49],"time":[50],"evaluate.":[52],"Hinze":[53],"efficient":[55],"counter":[59],"this":[60],"inefficiency,":[61],"did":[63,70,78],"so":[64,77],"pragmatic":[67],"way:":[68],"he":[69],"not":[71,79],"provide":[72],"categorical":[73],"equivalent":[75],"underpinnings,":[76],"get":[80],"associated":[82],"universal":[83],"properties":[84],"manipulating":[86],"folds.":[87],"We":[88],"combine":[89],"efficiency":[91],"Hinze\u2019s":[93],"construction":[94],"with":[95],"powerful":[97],"reasoning":[98],"tools":[99],"Paterson\u2019s.":[103]},"counts_by_year":[{"year":2022,"cited_by_count":1},{"year":2017,"cited_by_count":2},{"year":2015,"cited_by_count":1},{"year":2012,"cited_by_count":3}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
