{"id":"https://openalex.org/W3046362536","doi":"https://doi.org/10.1145/3406088.3409019","title":"Type your matrices for great good: a Haskell library of typed matrices and applications (functional pearl)","display_name":"Type your matrices for great good: a Haskell library of typed matrices and applications (functional pearl)","publication_year":2020,"publication_date":"2020-07-31","ids":{"openalex":"https://openalex.org/W3046362536","doi":"https://doi.org/10.1145/3406088.3409019","mag":"3046362536"},"language":"en","primary_location":{"id":"doi:10.1145/3406088.3409019","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3406088.3409019","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 13th ACM SIGPLAN International Symposium on Haskell","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"http://repositorio.inesctec.pt/handle/123456789/11775","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5087906513","display_name":"Armando Santos","orcid":null},"institutions":[{"id":"https://openalex.org/I4210166615","display_name":"INESC TEC","ror":"https://ror.org/05fa8ka61","country_code":"PT","type":"nonprofit","lineage":["https://openalex.org/I4210125590","https://openalex.org/I4210166615"]},{"id":"https://openalex.org/I99682543","display_name":"University of Minho","ror":"https://ror.org/037wpkx04","country_code":"PT","type":"education","lineage":["https://openalex.org/I99682543"]}],"countries":["PT"],"is_corresponding":false,"raw_author_name":"Armando Santos","raw_affiliation_strings":["University of Minho, Portugal / INESC TEC, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Minho, Portugal / INESC TEC, Portugal","institution_ids":["https://openalex.org/I4210166615","https://openalex.org/I99682543"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5070407243","display_name":"Jos\u00e9 N. Oliveira","orcid":"https://orcid.org/0000-0002-0196-4229"},"institutions":[{"id":"https://openalex.org/I4210166615","display_name":"INESC TEC","ror":"https://ror.org/05fa8ka61","country_code":"PT","type":"nonprofit","lineage":["https://openalex.org/I4210125590","https://openalex.org/I4210166615"]},{"id":"https://openalex.org/I99682543","display_name":"University of Minho","ror":"https://ror.org/037wpkx04","country_code":"PT","type":"education","lineage":["https://openalex.org/I99682543"]}],"countries":["PT"],"is_corresponding":false,"raw_author_name":"Jos\u00e9 N. Oliveira","raw_affiliation_strings":["University of Minho, Portugal / INESC TEC, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Minho, Portugal / INESC TEC, Portugal","institution_ids":["https://openalex.org/I4210166615","https://openalex.org/I99682543"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.4062,"has_fulltext":false,"cited_by_count":4,"citation_normalized_percentile":{"value":0.69612332,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"54","last_page":"66"},"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/T11596","display_name":"Constraint Satisfaction and Optimization","score":0.9947999715805054,"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/T11450","display_name":"Model-Driven Software Engineering Techniques","score":0.9843999743461609,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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.9630634784698486},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7627512216567993},{"id":"https://openalex.org/keywords/pearl","display_name":"Pearl","score":0.7162195444107056},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.6517001986503601},{"id":"https://openalex.org/keywords/search-engine-indexing","display_name":"Search engine indexing","score":0.6230944991111755},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.5789929628372192},{"id":"https://openalex.org/keywords/simplicity","display_name":"Simplicity","score":0.5307633280754089},{"id":"https://openalex.org/keywords/matrix","display_name":"Matrix (chemical analysis)","score":0.4894312918186188},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.47476911544799805},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.4638836979866028},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.46233412623405457},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3532004952430725},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.348017156124115},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.2770388126373291}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9630634784698486},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7627512216567993},{"id":"https://openalex.org/C2779251273","wikidata":"https://www.wikidata.org/wiki/Q43436","display_name":"Pearl","level":2,"score":0.7162195444107056},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.6517001986503601},{"id":"https://openalex.org/C75165309","wikidata":"https://www.wikidata.org/wiki/Q2258979","display_name":"Search engine indexing","level":2,"score":0.6230944991111755},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.5789929628372192},{"id":"https://openalex.org/C2776372474","wikidata":"https://www.wikidata.org/wiki/Q508291","display_name":"Simplicity","level":2,"score":0.5307633280754089},{"id":"https://openalex.org/C106487976","wikidata":"https://www.wikidata.org/wiki/Q685816","display_name":"Matrix (chemical analysis)","level":2,"score":0.4894312918186188},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.47476911544799805},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.4638836979866028},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.46233412623405457},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3532004952430725},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.348017156124115},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.2770388126373291},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C159985019","wikidata":"https://www.wikidata.org/wiki/Q181790","display_name":"Composite material","level":1,"score":0.0},{"id":"https://openalex.org/C192562407","wikidata":"https://www.wikidata.org/wiki/Q228736","display_name":"Materials science","level":0,"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/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C27206212","wikidata":"https://www.wikidata.org/wiki/Q34178","display_name":"Theology","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/3406088.3409019","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3406088.3409019","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 13th ACM SIGPLAN International Symposium on Haskell","raw_type":"proceedings-article"},{"id":"pmh:oai:repositorio.inesctec.pt:123456789/11775","is_oa":true,"landing_page_url":"http://repositorio.inesctec.pt/handle/123456789/11775","pdf_url":null,"source":{"id":"https://openalex.org/S4306402433","display_name":"Portuguese National Funding Agency for Science, Research and Technology (RCAAP Project by FCT)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"other"},{"id":"pmh:oai:repositorium.sdum.uminho.pt:1822/90405","is_oa":false,"landing_page_url":"https://hdl.handle.net/1822/90405","pdf_url":null,"source":{"id":"https://openalex.org/S4306400354","display_name":"Reposit\u00f3riUM (Universidade do Minho)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99682543","host_organization_name":"University of Minho","host_organization_lineage":["https://openalex.org/I99682543"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":null}],"best_oa_location":{"id":"pmh:oai:repositorio.inesctec.pt:123456789/11775","is_oa":true,"landing_page_url":"http://repositorio.inesctec.pt/handle/123456789/11775","pdf_url":null,"source":{"id":"https://openalex.org/S4306402433","display_name":"Portuguese National Funding Agency for Science, Research and Technology (RCAAP Project by FCT)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"other"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":23,"referenced_works":["https://openalex.org/W84930537","https://openalex.org/W1480928214","https://openalex.org/W1558175043","https://openalex.org/W1566363341","https://openalex.org/W1989483469","https://openalex.org/W1999128250","https://openalex.org/W2020073275","https://openalex.org/W2050576295","https://openalex.org/W2095136535","https://openalex.org/W2095875205","https://openalex.org/W2105287078","https://openalex.org/W2109932450","https://openalex.org/W2140647971","https://openalex.org/W2145108549","https://openalex.org/W2509331697","https://openalex.org/W2574983198","https://openalex.org/W2751199924","https://openalex.org/W2914196042","https://openalex.org/W2958869096","https://openalex.org/W2965969309","https://openalex.org/W3141650078","https://openalex.org/W4251772834","https://openalex.org/W6821157571"],"related_works":["https://openalex.org/W2112263414","https://openalex.org/W1602185604","https://openalex.org/W3004782279","https://openalex.org/W2028779182","https://openalex.org/W4242678340","https://openalex.org/W2140654465","https://openalex.org/W2129253059","https://openalex.org/W4296274916","https://openalex.org/W1504459189","https://openalex.org/W3006157134"],"abstract_inverted_index":{"We":[0,74],"study":[1],"a":[2,40],"simple":[3],"inductive":[4],"data":[5,80],"type":[6,81],"for":[7],"representing":[8],"correct-by-construction":[9],"matrices.":[10],"Despite":[11],"its":[12],"simplicity,":[13],"it":[14,52],"can":[15],"be":[16],"used":[17],"to":[18,54,88],"implement":[19],"matrix-manipulation":[20],"algorithms":[21,36,59],"efficiently":[22],"and":[23,42,56,85],"safely,":[24],"performing":[25],"in":[26,39,91],"some":[27],"cases":[28],"faster":[29],"than":[30],"existing":[31],"alternatives":[32],"even":[33],"though":[34],"the":[35,64,76,79],"are":[37],"written":[38],"direct":[41],"purely":[43],"functional":[44],"style.":[45],"A":[46],"rich":[47],"collection":[48],"of":[49,78],"laws":[50],"makes":[51],"possible":[53],"derive":[55],"optimise":[57],"these":[58],"using":[60],"equational":[61],"reasoning,":[62],"avoiding":[63],"notorious":[65],"off-by-one":[66],"indexing":[67],"errors":[68],"when":[69],"fiddling":[70],"with":[71],"matrix":[72],"dimensions.":[73],"demonstrate":[75],"usefulness":[77],"on":[82],"several":[83],"examples,":[84],"highlight":[86],"connections":[87],"related":[89],"topics":[90],"category":[92],"theory.":[93]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2022,"cited_by_count":2},{"year":2020,"cited_by_count":1}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
