{"id":"https://openalex.org/W1997644097","doi":"https://doi.org/10.1017/s0956796898003050","title":"Monadic parsing in Haskell","display_name":"Monadic parsing in Haskell","publication_year":1998,"publication_date":"1998-07-01","ids":{"openalex":"https://openalex.org/W1997644097","doi":"https://doi.org/10.1017/s0956796898003050","mag":"1997644097"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796898003050","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s0956796898003050","pdf_url":null,"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":"green","oa_url":"https://nottingham-repository.worktribe.com/output/1024100","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5069634739","display_name":"Graham Hutton","orcid":"https://orcid.org/0000-0001-9584-5150"},"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":"GRAHAM HUTTON","raw_affiliation_strings":["University of Nottingham, Nottingham, UK","University of Nottingham Nottingham UK"],"affiliations":[{"raw_affiliation_string":"University of Nottingham, Nottingham, UK","institution_ids":["https://openalex.org/I142263535"]},{"raw_affiliation_string":"University of Nottingham Nottingham UK","institution_ids":["https://openalex.org/I142263535"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5053775941","display_name":"Erik Meijer","orcid":"https://orcid.org/0000-0001-6779-0295"},"institutions":[{"id":"https://openalex.org/I193662353","display_name":"Utrecht University","ror":"https://ror.org/04pp8hn57","country_code":"NL","type":"education","lineage":["https://openalex.org/I193662353"]}],"countries":["NL"],"is_corresponding":false,"raw_author_name":"ERIK MEIJER","raw_affiliation_strings":["University of Utrecht, Utrecht, The Netherlands","University of Utrecht , Utrecht , the Netherlands"],"affiliations":[{"raw_affiliation_string":"University of Utrecht, Utrecht, The Netherlands","institution_ids":["https://openalex.org/I193662353"]},{"raw_affiliation_string":"University of Utrecht , Utrecht , the Netherlands","institution_ids":["https://openalex.org/I193662353"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5069634739"],"corresponding_institution_ids":["https://openalex.org/I142263535"],"apc_list":null,"apc_paid":null,"fwci":8.5642,"has_fulltext":false,"cited_by_count":181,"citation_normalized_percentile":{"value":0.97768315,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":99},"biblio":{"volume":"8","issue":"4","first_page":"437","last_page":"444"},"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.9998999834060669,"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.9998999834060669,"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/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.9940999746322632,"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.9901999831199646,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.9586474299430847},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8978292346000671},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7684115171432495},{"id":"https://openalex.org/keywords/parsing","display_name":"Parsing","score":0.7454336881637573},{"id":"https://openalex.org/keywords/combinatory-logic","display_name":"Combinatory logic","score":0.7013751864433289},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.575073778629303},{"id":"https://openalex.org/keywords/parser-combinator","display_name":"Parser combinator","score":0.5684850811958313},{"id":"https://openalex.org/keywords/lr-parser","display_name":"LR parser","score":0.5091390013694763}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9586474299430847},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8978292346000671},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7684115171432495},{"id":"https://openalex.org/C186644900","wikidata":"https://www.wikidata.org/wiki/Q194152","display_name":"Parsing","level":2,"score":0.7454336881637573},{"id":"https://openalex.org/C79678938","wikidata":"https://www.wikidata.org/wiki/Q1481571","display_name":"Combinatory logic","level":2,"score":0.7013751864433289},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.575073778629303},{"id":"https://openalex.org/C118364021","wikidata":"https://www.wikidata.org/wiki/Q7139956","display_name":"Parser combinator","level":3,"score":0.5684850811958313},{"id":"https://openalex.org/C35164859","wikidata":"https://www.wikidata.org/wiki/Q1756442","display_name":"LR parser","level":4,"score":0.5091390013694763}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1017/s0956796898003050","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s0956796898003050","pdf_url":null,"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:nottingham-repository.worktribe.com:1024100","is_oa":true,"landing_page_url":"https://nottingham-repository.worktribe.com/output/1024100","pdf_url":null,"source":{"id":"https://openalex.org/S4306402483","display_name":"Repository@Nottingham (University of Nottingham)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I142263535","host_organization_name":"University of Nottingham","host_organization_lineage":["https://openalex.org/I142263535"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"acceptedVersion"}],"best_oa_location":{"id":"pmh:oai:nottingham-repository.worktribe.com:1024100","is_oa":true,"landing_page_url":"https://nottingham-repository.worktribe.com/output/1024100","pdf_url":null,"source":{"id":"https://openalex.org/S4306402483","display_name":"Repository@Nottingham (University of Nottingham)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I142263535","host_organization_name":"University of Nottingham","host_organization_lineage":["https://openalex.org/I142263535"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"acceptedVersion"},"sustainable_development_goals":[{"score":0.49000000953674316,"id":"https://metadata.un.org/sdg/4","display_name":"Quality Education"}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":10,"referenced_works":["https://openalex.org/W655501358","https://openalex.org/W1491178396","https://openalex.org/W1507155521","https://openalex.org/W2037984920","https://openalex.org/W2120348241","https://openalex.org/W2149935768","https://openalex.org/W2166030873","https://openalex.org/W2295914203","https://openalex.org/W2621168830","https://openalex.org/W2911969993"],"related_works":["https://openalex.org/W2163201987","https://openalex.org/W2523702803","https://openalex.org/W2112307192","https://openalex.org/W2135888537","https://openalex.org/W3196010588","https://openalex.org/W2183434207","https://openalex.org/W1490215723","https://openalex.org/W1997644097","https://openalex.org/W4367311114","https://openalex.org/W2151886136"],"abstract_inverted_index":{"This":[0],"paper":[1,20,77],"is":[2,127,148,173],"a":[3,27,122,136],"tutorial":[4],"on":[5],"defining":[6],"recursive":[7,91,124],"descent":[8,92,125],"parsers":[9,35,83,93,102,151],"in":[10,65,87],"Haskell.":[11,88],"In":[12],"the":[13,19,44,57,76,98,144,158,179],"spirit":[14],"of":[15,46,59,100,139,161,178,181],"one-stop":[16],"shopping":[17],",":[18],"combines":[21],"material":[22],"from":[23],"three":[24,31],"areas":[25,32],"into":[26],"single":[28],"source.":[29],"The":[30,171],"are":[33,152],"functional":[34,50,182],"(Burge,":[36],"1975;":[37],"Wadler,":[38],"1985;":[39],"Hutton,":[40],"1992;":[41],"Fokker,":[42],"1995),":[43],"use":[45,58],"monads":[47],"to":[48,80,164],"structure":[49],"programs":[51,64],"(Wadler,":[52],"1990,":[53],"1992a,":[54],"1992b),":[55],"and":[56,114,155],"special":[60,169],"syntax":[61],"for":[62,118,141,168],"monadic":[63,82],"Haskell":[66,162],"(Jones,":[67],"1995;":[68],"Peterson":[69],"et":[70,107],"al":[71,108],".,":[72,109],"1996).":[73],"More":[74],"specifically,":[75],"shows":[78],"how":[79],"define":[81,165],"using":[84],"do":[85],"notation":[86],"Of":[89],"course,":[90],"defined":[94],"by":[95,104],"hand":[96],"lack":[97],"efficiency":[99],"bottom-up":[101],"generated":[103],"machine":[105],"(Aho":[106],"1986;":[110],"Mogensen,":[111],"1993;":[112],"Gill":[113],"Marlow,":[115],"1995).":[116],"However,":[117],"many":[119],"research":[120],"applications,":[121],"simple":[123],"parser":[126,132],"perfectly":[128],"sufficient.":[129],"Moreover,":[130],"while":[131],"generators":[133],"typically":[134],"offer":[135],"fixed":[137],"set":[138],"combinators":[140,167],"describing":[142],"grammars,":[143],"method":[145,172],"described":[146],"here":[147],"completely":[149],"extensible:":[150],"first-class":[153],"values,":[154],"we":[156],"have":[157],"full":[159],"power":[160],"available":[163],"new":[166],"applications.":[170],"also":[174],"an":[175],"excellent":[176],"illustration":[177],"elegance":[180],"programming.":[183]},"counts_by_year":[{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":3},{"year":2023,"cited_by_count":6},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":1},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":3},{"year":2017,"cited_by_count":6},{"year":2016,"cited_by_count":8},{"year":2015,"cited_by_count":8},{"year":2014,"cited_by_count":7},{"year":2013,"cited_by_count":7},{"year":2012,"cited_by_count":6}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
