{"id":"https://openalex.org/W2061383381","doi":"https://doi.org/10.1145/2804302.2804315","title":"Modular reifiable matching: a list-of-functors approach to two-level types","display_name":"Modular reifiable matching: a list-of-functors approach to two-level types","publication_year":2015,"publication_date":"2015-08-24","ids":{"openalex":"https://openalex.org/W2061383381","doi":"https://doi.org/10.1145/2804302.2804315","mag":"2061383381"},"language":"en","primary_location":{"id":"doi:10.1145/2804302.2804315","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804315","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","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/A5049714036","display_name":"Bruno C. d. S. Oliveira","orcid":"https://orcid.org/0000-0002-1846-7210"},"institutions":[{"id":"https://openalex.org/I889458895","display_name":"University of Hong Kong","ror":"https://ror.org/02zhqgq86","country_code":"HK","type":"education","lineage":["https://openalex.org/I889458895"]}],"countries":["HK"],"is_corresponding":true,"raw_author_name":"Bruno C. d. S. Oliveira","raw_affiliation_strings":["University of Hong Kong, China"],"affiliations":[{"raw_affiliation_string":"University of Hong Kong, China","institution_ids":["https://openalex.org/I889458895"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5002724938","display_name":"Shin-Cheng Mu","orcid":"https://orcid.org/0000-0002-4755-601X"},"institutions":[{"id":"https://openalex.org/I84653119","display_name":"Academia Sinica","ror":"https://ror.org/05bxb3784","country_code":"TW","type":"facility","lineage":["https://openalex.org/I84653119"]}],"countries":["TW"],"is_corresponding":false,"raw_author_name":"Shin-Cheng Mu","raw_affiliation_strings":["Academia Sinica, Taiwan"],"affiliations":[{"raw_affiliation_string":"Academia Sinica, Taiwan","institution_ids":["https://openalex.org/I84653119"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5108714692","display_name":"Shu-Hung You","orcid":"https://orcid.org/0009-0003-0003-3945"},"institutions":[{"id":"https://openalex.org/I16733864","display_name":"National Taiwan University","ror":"https://ror.org/05bqach95","country_code":"TW","type":"education","lineage":["https://openalex.org/I16733864"]}],"countries":["TW"],"is_corresponding":false,"raw_author_name":"Shu-Hung You","raw_affiliation_strings":["National Taiwan University, Taiwan"],"affiliations":[{"raw_affiliation_string":"National Taiwan University, Taiwan","institution_ids":["https://openalex.org/I16733864"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5049714036"],"corresponding_institution_ids":["https://openalex.org/I889458895"],"apc_list":null,"apc_paid":null,"fwci":1.7804,"has_fulltext":false,"cited_by_count":11,"citation_normalized_percentile":{"value":0.88658793,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"82","last_page":"93"},"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.9994000196456909,"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.9994000196456909,"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/T10317","display_name":"Advanced Database Systems and Queries","score":0.9991000294685364,"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"}},{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9944000244140625,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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.8672358989715576},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7926970720291138},{"id":"https://openalex.org/keywords/functor","display_name":"Functor","score":0.6378517746925354},{"id":"https://openalex.org/keywords/extensibility","display_name":"Extensibility","score":0.6281715631484985},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5951554775238037},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.5681425333023071},{"id":"https://openalex.org/keywords/modularity","display_name":"Modularity (biology)","score":0.5356004238128662},{"id":"https://openalex.org/keywords/matching","display_name":"Matching (statistics)","score":0.5237831473350525},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.4387356638908386},{"id":"https://openalex.org/keywords/pattern-matching","display_name":"Pattern matching","score":0.4231172204017639},{"id":"https://openalex.org/keywords/reuse","display_name":"Reuse","score":0.41832858324050903},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.382889986038208},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.27307283878326416},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.1922227144241333},{"id":"https://openalex.org/keywords/statistics","display_name":"Statistics","score":0.07501083612442017}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.8672358989715576},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7926970720291138},{"id":"https://openalex.org/C156772000","wikidata":"https://www.wikidata.org/wiki/Q864475","display_name":"Functor","level":2,"score":0.6378517746925354},{"id":"https://openalex.org/C32833848","wikidata":"https://www.wikidata.org/wiki/Q4115054","display_name":"Extensibility","level":2,"score":0.6281715631484985},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5951554775238037},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.5681425333023071},{"id":"https://openalex.org/C2779478453","wikidata":"https://www.wikidata.org/wiki/Q6889748","display_name":"Modularity (biology)","level":2,"score":0.5356004238128662},{"id":"https://openalex.org/C165064840","wikidata":"https://www.wikidata.org/wiki/Q1321061","display_name":"Matching (statistics)","level":2,"score":0.5237831473350525},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.4387356638908386},{"id":"https://openalex.org/C68859911","wikidata":"https://www.wikidata.org/wiki/Q1503724","display_name":"Pattern matching","level":2,"score":0.4231172204017639},{"id":"https://openalex.org/C206588197","wikidata":"https://www.wikidata.org/wiki/Q846574","display_name":"Reuse","level":2,"score":0.41832858324050903},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.382889986038208},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.27307283878326416},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.1922227144241333},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.07501083612442017},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","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},{"id":"https://openalex.org/C54355233","wikidata":"https://www.wikidata.org/wiki/Q7162","display_name":"Genetics","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/2804302.2804315","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804315","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.719.6178","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.719.6178","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://i.cs.hku.hk/%7Ebruno/papers/MRM.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4","score":0.41999998688697815}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":36,"referenced_works":["https://openalex.org/W60733025","https://openalex.org/W1485257692","https://openalex.org/W1552977104","https://openalex.org/W1587758675","https://openalex.org/W1830421783","https://openalex.org/W1980827618","https://openalex.org/W1986044902","https://openalex.org/W2015617966","https://openalex.org/W2016301134","https://openalex.org/W2027132261","https://openalex.org/W2046671194","https://openalex.org/W2048365843","https://openalex.org/W2059895047","https://openalex.org/W2082765113","https://openalex.org/W2084115964","https://openalex.org/W2091470061","https://openalex.org/W2093896470","https://openalex.org/W2099741881","https://openalex.org/W2112474400","https://openalex.org/W2124866283","https://openalex.org/W2126234902","https://openalex.org/W2128448167","https://openalex.org/W2129777450","https://openalex.org/W2143823533","https://openalex.org/W2155480936","https://openalex.org/W2155863409","https://openalex.org/W2163552400","https://openalex.org/W2164777241","https://openalex.org/W2296677810","https://openalex.org/W3141297582","https://openalex.org/W4212957569","https://openalex.org/W4244792373","https://openalex.org/W4250126356","https://openalex.org/W4285719527","https://openalex.org/W4299423755","https://openalex.org/W6628874697"],"related_works":["https://openalex.org/W2139568978","https://openalex.org/W1822411953","https://openalex.org/W1551275920","https://openalex.org/W2145326977","https://openalex.org/W1688372159","https://openalex.org/W137792605","https://openalex.org/W1599215552","https://openalex.org/W2318681340","https://openalex.org/W1528956417","https://openalex.org/W2536586774"],"abstract_inverted_index":{"This":[0,59,89],"paper":[1],"presents":[2],"Modular":[3],"Reifiable":[4],"Matching":[5],"(MRM):":[6],"a":[7,15,33,41,51,81,146],"new":[8],"approach":[9,55,60],"to":[10,36,56,96,103,113,136],"two":[11],"level":[12],"types":[13],"using":[14,32,80],"fixpoint":[16,52],"of":[17,25,53,68,83,124],"list-of-functors":[18,54],"representation.":[19],"MRM":[20,49,142],"allows":[21,90],"the":[22,37,119,160],"modular":[23,74],"definition":[24],"datatypes":[26],"and":[27,71,100,133,149,152],"functions":[28],"by":[29],"pattern":[30,75,93],"matching,":[31],"style":[34],"similar":[35],"widely":[38],"popular":[39],"Datatypes":[40],"la":[42],"Carte":[43],"(DTC)":[44],"approach.":[45],"However,":[46],"unlike":[47],"DTC,":[48],"uses":[50],"two-level":[57],"types.":[58],"has":[61],"advantages":[62],"that":[63,85],"help":[64],"with":[65],"various":[66,157],"aspects":[67],"extensibility,":[69],"modularity":[70],"reuse.":[72],"Firstly,":[73],"matching":[76,94],"definitions":[77,95],"are":[78,154],"collected":[79],"list":[82],"matches":[84,102],"is":[86,108,126,134,143],"fully":[87],"reifiable.":[88],"for":[91],"extensible":[92,115],"be":[97,104],"easily":[98],"reused/inherited,":[99],"particular":[101],"overridden.":[105],"Such":[106],"flexibility":[107],"used,":[109],"among":[110],"other":[111],"things,":[112],"implement":[114],"generic":[116],"traversals.":[117],"Secondly,":[118],"subtyping":[120],"relation":[121],"between":[122],"lists":[123],"functors":[125],"quite":[127],"simple,":[128],"does":[129],"not":[130],"require":[131],"backtracking,":[132],"easy":[135],"model":[137],"in":[138,159],"languages":[139],"like":[140],"Haskell.":[141],"implemented":[144],"as":[145],"Haskell":[147],"library,":[148],"its":[150],"use":[151],"applicability":[153],"illustrated":[155],"through":[156],"examples":[158],"paper.":[161]},"counts_by_year":[{"year":2022,"cited_by_count":1},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":4},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":1}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
