{"id":"https://openalex.org/W2123360309","doi":"https://doi.org/10.1017/s0956796899003366","title":"de Bruijn notation as a nested datatype","display_name":"de Bruijn notation as a nested datatype","publication_year":1999,"publication_date":"1999-01-01","ids":{"openalex":"https://openalex.org/W2123360309","doi":"https://doi.org/10.1017/s0956796899003366","mag":"2123360309"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796899003366","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796899003366","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D8BFA383FDA7EA3DC443B4C42A168F30/S0956796899003366a.pdf/div-class-title-de-bruijn-notation-as-a-nested-datatype-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D8BFA383FDA7EA3DC443B4C42A168F30/S0956796899003366a.pdf/div-class-title-de-bruijn-notation-as-a-nested-datatype-div.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5068829812","display_name":"Richard Bird","orcid":null},"institutions":[{"id":"https://openalex.org/I2802123492","display_name":"Oxford Research Group","ror":"https://ror.org/00z4w4f29","country_code":"GB","type":"nonprofit","lineage":["https://openalex.org/I2802123492"]},{"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":"RICHARD S. BIRD","raw_affiliation_strings":["Programming Research Group, Oxford University, Wolfson Building, Parks Road, Oxford OX1 3QD, UK","Programming Research Group, Oxford University, Wolfson Building, Parks Road, Oxford, OX1 3QD, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Programming Research Group, Oxford University, Wolfson Building, Parks Road, Oxford OX1 3QD, UK","institution_ids":["https://openalex.org/I2802123492","https://openalex.org/I40120149"]},{"raw_affiliation_string":"Programming Research Group, Oxford University, Wolfson Building, Parks Road, Oxford, OX1 3QD, UK","institution_ids":["https://openalex.org/I2802123492","https://openalex.org/I40120149"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5013758319","display_name":"Ross Paterson","orcid":"https://orcid.org/0000-0002-5430-6609"},"institutions":[{"id":"https://openalex.org/I180825142","display_name":"City, University of London","ror":"https://ror.org/04489at23","country_code":"GB","type":"education","lineage":["https://openalex.org/I124357947","https://openalex.org/I180825142"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"ROSS PATERSON","raw_affiliation_strings":["Department of Computer Science, City University, Northampton Square, London EC1V 0HB, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Department of Computer Science, City University, Northampton Square, London EC1V 0HB, UK","institution_ids":["https://openalex.org/I180825142"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":5.7279,"has_fulltext":true,"cited_by_count":146,"citation_normalized_percentile":{"value":0.96007826,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":94,"max":99},"biblio":{"volume":"9","issue":"1","first_page":"77","last_page":"91"},"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.9991999864578247,"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.9991999864578247,"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/T11567","display_name":"semigroups and automata theory","score":0.9898999929428101,"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/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.9818999767303467,"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/computer-science","display_name":"Computer science","score":0.7709850072860718},{"id":"https://openalex.org/keywords/de-bruijn-sequence","display_name":"De Bruijn sequence","score":0.6592040061950684},{"id":"https://openalex.org/keywords/invariant","display_name":"Invariant (physics)","score":0.47694411873817444},{"id":"https://openalex.org/keywords/notation","display_name":"Notation","score":0.4643915295600891},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4400864243507385},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.41564658284187317},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.36772671341896057},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.29328352212905884},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.18326464295387268},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.1829756200313568},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.13576918840408325},{"id":"https://openalex.org/keywords/arithmetic","display_name":"Arithmetic","score":0.12250494956970215}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7709850072860718},{"id":"https://openalex.org/C170320093","wikidata":"https://www.wikidata.org/wiki/Q1953457","display_name":"De Bruijn sequence","level":2,"score":0.6592040061950684},{"id":"https://openalex.org/C190470478","wikidata":"https://www.wikidata.org/wiki/Q2370229","display_name":"Invariant (physics)","level":2,"score":0.47694411873817444},{"id":"https://openalex.org/C45357846","wikidata":"https://www.wikidata.org/wiki/Q2001982","display_name":"Notation","level":2,"score":0.4643915295600891},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4400864243507385},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.41564658284187317},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.36772671341896057},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.29328352212905884},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.18326464295387268},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.1829756200313568},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.13576918840408325},{"id":"https://openalex.org/C94375191","wikidata":"https://www.wikidata.org/wiki/Q11205","display_name":"Arithmetic","level":1,"score":0.12250494956970215},{"id":"https://openalex.org/C37914503","wikidata":"https://www.wikidata.org/wiki/Q156495","display_name":"Mathematical physics","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1017/s0956796899003366","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796899003366","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D8BFA383FDA7EA3DC443B4C42A168F30/S0956796899003366a.pdf/div-class-title-de-bruijn-notation-as-a-nested-datatype-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.217.1225","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.217.1225","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.uwyo.edu/~jlc/courses/5000/debruijn_as_nested_datatype.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.42.4731","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.42.4731","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.soi.city.ac.uk/~ross/papers/debruijn.ps.gz","raw_type":"text"},{"id":"pmh:oai:ora.ox.ac.uk:uuid:94c9d39d-b63e-4798-932f-ca1e86d828a4","is_oa":false,"landing_page_url":"https://ora.ox.ac.uk/objects/uuid:94c9d39d-b63e-4798-932f-ca1e86d828a4","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.1017/s0956796899003366","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796899003366","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D8BFA383FDA7EA3DC443B4C42A168F30/S0956796899003366a.pdf/div-class-title-de-bruijn-notation-as-a-nested-datatype-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16","score":0.7300000190734863}],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2123360309.pdf","grobid_xml":"https://content.openalex.org/works/W2123360309.grobid-xml"},"referenced_works_count":14,"referenced_works":["https://openalex.org/W184339100","https://openalex.org/W583126019","https://openalex.org/W1507693023","https://openalex.org/W1725475383","https://openalex.org/W1796676969","https://openalex.org/W1998875295","https://openalex.org/W2050613794","https://openalex.org/W2057292961","https://openalex.org/W2096314727","https://openalex.org/W2101225843","https://openalex.org/W2125360711","https://openalex.org/W2143566245","https://openalex.org/W2151015971","https://openalex.org/W2913811625"],"related_works":["https://openalex.org/W2189052291","https://openalex.org/W2067607302","https://openalex.org/W102335353","https://openalex.org/W4247404391","https://openalex.org/W2924405342","https://openalex.org/W1851310281","https://openalex.org/W1978871081","https://openalex.org/W2051876501","https://openalex.org/W2395886377","https://openalex.org/W2355315340"],"abstract_inverted_index":{"\u201cI":[0],"have":[1,80],"no":[2],"data":[3],"yet.":[4],"It":[5],"is":[6,28,43,112,123,175,185],"a":[7,29,39,46,92,100,125],"capital":[8],"mistake":[9],"to":[10,55,81,137,161],"theorise":[11],"before":[12],"one":[13],"has":[14],"data.\u201d":[15],"Sir":[16],"Arthur":[17],"Conan":[18],"Doyle":[19],"The":[20],"Adventures":[21],"of":[22,31,38,149,169,181],"Sherlock":[23],"Holmes":[24],"de":[25,71],"Bruijn":[26,72],"notation":[27],"coding":[30],"lambda":[32,170],"terms":[33,105,148],"in":[34,66,102,147],"which":[35,103],"each":[36],"occurrence":[37,54],"bound":[40],"variable":[41],"x":[42,60],"replaced":[44],"by":[45,90,115],"natural":[47],"number,":[48],"indicating":[49],"the":[50,53,56,74,110,116,155,167,179],"\u2018distance\u2019":[51],"from":[52],"abstraction":[57,171],"that":[58,65,109],"introduced":[59],".":[61],"One":[62],"might":[63],"suppose":[64],"any":[67],"datatype":[68,87],"for":[69,154],"representing":[70],"terms,":[73],"distance":[75],"restriction":[76],"on":[77],"numbers":[78],"would":[79],"be":[82],"maintained":[83],"as":[84],"an":[85,150],"explicit":[86],"invariant.":[88],"However,":[89],"using":[91,158],"nested":[93,121],"(or":[94],"non-regular)":[95],"datatype,":[96],"we":[97,135],"can":[98],"define":[99],"representation":[101],"all":[104],"are":[106],"well-formed,":[107],"so":[108],"invariant":[111],"enforced":[113],"automatically":[114],"type":[117],"system.":[118],"Programming":[119],"with":[120,131],"types":[122],"only":[124],"little":[126],"more":[127],"difficult":[128],"than":[129],"programming":[130],"regular":[132],"types,":[133],"provided":[134],"stick":[136],"well-established":[138],"structuring":[139],"techniques.":[140],"These":[141],"involve":[142],"expressing":[143],"inductively":[144],"defined":[145],"functions":[146],"appropriate":[151],"fold":[152],"function":[153],"type,":[156],"and":[157,172,178],"fusion":[159],"laws":[160],"establish":[162],"their":[163,182],"properties.":[164],"In":[165],"particular,":[166],"definition":[168],"beta":[173],"reduction":[174],"particularly":[176],"simple,":[177],"proof":[180],"associated":[183],"properties":[184],"entirely":[186],"mechanical.":[187]},"counts_by_year":[{"year":2025,"cited_by_count":5},{"year":2024,"cited_by_count":7},{"year":2023,"cited_by_count":5},{"year":2022,"cited_by_count":5},{"year":2021,"cited_by_count":3},{"year":2020,"cited_by_count":3},{"year":2019,"cited_by_count":5},{"year":2018,"cited_by_count":9},{"year":2017,"cited_by_count":6},{"year":2016,"cited_by_count":4},{"year":2015,"cited_by_count":2},{"year":2014,"cited_by_count":3},{"year":2013,"cited_by_count":3},{"year":2012,"cited_by_count":6}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
