{"id":"https://openalex.org/W2155480936","doi":"https://doi.org/10.1017/s0956796808007089","title":"Type-safe pattern combinators","display_name":"Type-safe pattern combinators","publication_year":2008,"publication_date":"2008-12-23","ids":{"openalex":"https://openalex.org/W2155480936","doi":"https://doi.org/10.1017/s0956796808007089","mag":"2155480936"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796808007089","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796808007089","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1E3D0890F2ED1B70F80722A732756910/S0956796808007089a.pdf/div-class-title-type-safe-pattern-combinators-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/1E3D0890F2ED1B70F80722A732756910/S0956796808007089a.pdf/div-class-title-type-safe-pattern-combinators-div.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5059142395","display_name":"Morten Rhiger","orcid":"https://orcid.org/0009-0001-0268-0842"},"institutions":[{"id":"https://openalex.org/I83467386","display_name":"IT University of Copenhagen","ror":"https://ror.org/02309jg23","country_code":"DK","type":"education","lineage":["https://openalex.org/I83467386"]}],"countries":["DK"],"is_corresponding":true,"raw_author_name":"MORTEN RHIGER","raw_affiliation_strings":["The IT University of Copenhagen, Copenhagen, Denmark (e-mail:"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"The IT University of Copenhagen, Copenhagen, Denmark (e-mail:","institution_ids":["https://openalex.org/I83467386"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5059142395"],"corresponding_institution_ids":["https://openalex.org/I83467386"],"apc_list":null,"apc_paid":null,"fwci":2.3458,"has_fulltext":true,"cited_by_count":14,"citation_normalized_percentile":{"value":0.90477072,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":"19","issue":"2","first_page":"145","last_page":"156"},"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.9997000098228455,"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.9997000098228455,"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/T10181","display_name":"Natural Language Processing Techniques","score":0.9983999729156494,"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.9943000078201294,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.9766669869422913},{"id":"https://openalex.org/keywords/combinatory-logic","display_name":"Combinatory logic","score":0.9116867780685425},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8869788646697998},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.8148929476737976},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.7003400921821594},{"id":"https://openalex.org/keywords/macro","display_name":"Macro","score":0.5959771871566772},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.4980607032775879},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.47647783160209656},{"id":"https://openalex.org/keywords/lambda-calculus","display_name":"Lambda calculus","score":0.4152209162712097},{"id":"https://openalex.org/keywords/block","display_name":"Block (permutation group theory)","score":0.4140776991844177},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.07182487845420837}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9766669869422913},{"id":"https://openalex.org/C79678938","wikidata":"https://www.wikidata.org/wiki/Q1481571","display_name":"Combinatory logic","level":2,"score":0.9116867780685425},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8869788646697998},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8148929476737976},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.7003400921821594},{"id":"https://openalex.org/C166955791","wikidata":"https://www.wikidata.org/wiki/Q629579","display_name":"Macro","level":2,"score":0.5959771871566772},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.4980607032775879},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.47647783160209656},{"id":"https://openalex.org/C135790938","wikidata":"https://www.wikidata.org/wiki/Q242028","display_name":"Lambda calculus","level":2,"score":0.4152209162712097},{"id":"https://openalex.org/C2777210771","wikidata":"https://www.wikidata.org/wiki/Q4927124","display_name":"Block (permutation group theory)","level":2,"score":0.4140776991844177},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.07182487845420837},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1017/s0956796808007089","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796808007089","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1E3D0890F2ED1B70F80722A732756910/S0956796808007089a.pdf/div-class-title-type-safe-pattern-combinators-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.548.67","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.548.67","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.it-c.dk/people/mir/typesafepatterns.pdf","raw_type":"text"},{"id":"pmh:oai:pure.atira.dk:publications/2ce0c970-5cc7-11de-8664-000ea68e967b","is_oa":false,"landing_page_url":"https://pure.itu.dk/portal/da/publications/2ce0c970-5cc7-11de-8664-000ea68e967b","pdf_url":null,"source":{"id":"https://openalex.org/S4377196680","display_name":"IT University Of Copenhagen (IT University of Copenhagen)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I83467386","host_organization_name":"IT University of Copenhagen","host_organization_lineage":["https://openalex.org/I83467386"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Rhiger, M 2009, 'Type-safe pattern combinators', Journal of Functional Programming, vol. 19, no. 02, pp. 145-156. https://doi.org/10.1017/S0956796808007089","raw_type":"info:eu-repo/semantics/publishedVersion"},{"id":"pmh:oai:pure.atira.dk:publications/cab2b820-1563-11df-9bed-000ea68e967b","is_oa":false,"landing_page_url":"https://forskning.ruc.dk/da/publications/cab2b820-1563-11df-9bed-000ea68e967b","pdf_url":null,"source":{"id":"https://openalex.org/S4306401457","display_name":"RUCforsk (Roskilde University)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I107707843","host_organization_name":"Roskilde University","host_organization_lineage":["https://openalex.org/I107707843"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Rhiger, M 2009, 'Type-safe pattern combinators', Journal of Functional Programming, vol. 19, no. 2, pp. 145156. https://doi.org/10.1017/S0956796808007089","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"doi:10.1017/s0956796808007089","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796808007089","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1E3D0890F2ED1B70F80722A732756910/S0956796808007089a.pdf/div-class-title-type-safe-pattern-combinators-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":[{"id":"https://metadata.un.org/sdg/4","display_name":"Quality Education","score":0.5}],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2155480936.pdf","grobid_xml":"https://content.openalex.org/works/W2155480936.grobid-xml"},"referenced_works_count":10,"referenced_works":["https://openalex.org/W76858040","https://openalex.org/W1567927032","https://openalex.org/W1783167788","https://openalex.org/W2002278483","https://openalex.org/W2078944436","https://openalex.org/W2114980032","https://openalex.org/W2132254891","https://openalex.org/W2147125687","https://openalex.org/W2399951213","https://openalex.org/W2912745181"],"related_works":["https://openalex.org/W1564538666","https://openalex.org/W2526970984","https://openalex.org/W1528956417","https://openalex.org/W1599215552","https://openalex.org/W1919687110","https://openalex.org/W2028779182","https://openalex.org/W1734457603","https://openalex.org/W2521829344","https://openalex.org/W2155480936","https://openalex.org/W2095136535"],"abstract_inverted_index":{"Abstract":[0],"Macros":[1],"still":[2],"haven't":[3],"made":[4],"their":[5],"way":[6],"into":[7],"typed":[8],"higher-order":[9],"programming":[10],"languages":[11],"such":[12],"as":[13],"Haskell":[14,24,84],"and":[15,60,80],"Standard":[16,26],"ML.":[17],"Therefore,":[18],"to":[19],"extend":[20],"the":[21,41],"expressiveness":[22],"of":[23,36,45],"or":[25],"ML,":[27],"one":[28],"must":[29],"express":[30],"new":[31],"linguistic":[32],"features":[33,54],"in":[34,70,83,85],"terms":[35],"functions":[37],"that":[38,55,61],"fit":[39],"within":[40],"static":[42],"type":[43],"systems":[44],"these":[46],"languages.":[47],"This":[48],"is":[49],"particularly":[50],"challenging":[51],"when":[52],"introducing":[53],"span":[56],"across":[57],"multiple":[58],"types":[59],"bind":[62],"variables.":[63],"We":[64],"address":[65],"this":[66],"challenge":[67],"by":[68,73],"developing,":[69],"a":[71,86],"step":[72,74],"manner,":[75],"mechanisms":[76],"for":[77],"encoding":[78],"patterns":[79],"pattern":[81],"matching":[82],"type-safe":[87],"way.":[88]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":2},{"year":2013,"cited_by_count":4}],"updated_date":"2026-04-23T06:14:38.165362","created_date":"2025-10-10T00:00:00"}
