{"id":"https://openalex.org/W4407925525","doi":"https://doi.org/10.1017/s0956796825000012","title":"How much is in a square? Calculating functional programs with squares","display_name":"How much is in a square? Calculating functional programs with squares","publication_year":2025,"publication_date":"2025-01-01","ids":{"openalex":"https://openalex.org/W4407925525","doi":"https://doi.org/10.1017/s0956796825000012"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796825000012","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796825000012","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/F48258008F47DC9F53AA2E61B4E511A7/S0956796825000012a.pdf/div-class-title-how-much-is-in-a-square-calculating-functional-programs-with-squares-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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","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":"hybrid","oa_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/F48258008F47DC9F53AA2E61B4E511A7/S0956796825000012a.pdf/div-class-title-how-much-is-in-a-square-calculating-functional-programs-with-squares-div.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","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/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":true,"raw_author_name":"JOSE NUNO OLIVEIRA","raw_affiliation_strings":["HASLab - INESC TEC, University of Minho, Gualtar Campus, Building E7, Braga, Portugal (e-mail:"],"affiliations":[{"raw_affiliation_string":"HASLab - INESC TEC, University of Minho, Gualtar Campus, Building E7, Braga, Portugal (e-mail:","institution_ids":["https://openalex.org/I99682543"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5070407243"],"corresponding_institution_ids":["https://openalex.org/I99682543"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.01293863,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"35","issue":null,"first_page":null,"last_page":null},"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.9993000030517578,"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.9993000030517578,"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/T10142","display_name":"Formal Methods in Verification","score":0.9916999936103821,"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.9648000001907349,"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.832266628742218},{"id":"https://openalex.org/keywords/square","display_name":"Square (algebra)","score":0.6213102340698242},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3501448631286621},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.12916022539138794}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.832266628742218},{"id":"https://openalex.org/C135692309","wikidata":"https://www.wikidata.org/wiki/Q111124","display_name":"Square (algebra)","level":2,"score":0.6213102340698242},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3501448631286621},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.12916022539138794},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1017/s0956796825000012","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796825000012","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/F48258008F47DC9F53AA2E61B4E511A7/S0956796825000012a.pdf/div-class-title-how-much-is-in-a-square-calculating-functional-programs-with-squares-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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1017/s0956796825000012","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796825000012","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/F48258008F47DC9F53AA2E61B4E511A7/S0956796825000012a.pdf/div-class-title-how-much-is-in-a-square-calculating-functional-programs-with-squares-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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G6299983296","display_name":null,"funder_award_id":"PTDC/","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"},{"id":"https://openalex.org/G7872908177","display_name":null,"funder_award_id":"PTDC/CCI-COM/4280/2021","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"},{"id":"https://openalex.org/G943999617","display_name":null,"funder_award_id":"Technology","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"}],"funders":[{"id":"https://openalex.org/F4320334779","display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia","ror":"https://ror.org/00snfqn58"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4407925525.pdf","grobid_xml":"https://content.openalex.org/works/W4407925525.grobid-xml"},"referenced_works_count":32,"referenced_works":["https://openalex.org/W141098975","https://openalex.org/W326743114","https://openalex.org/W1601959129","https://openalex.org/W1967838552","https://openalex.org/W1997143185","https://openalex.org/W2014143852","https://openalex.org/W2020382964","https://openalex.org/W2024951218","https://openalex.org/W2042631106","https://openalex.org/W2047925852","https://openalex.org/W2057292961","https://openalex.org/W2101565274","https://openalex.org/W2105287078","https://openalex.org/W2115926421","https://openalex.org/W2131993807","https://openalex.org/W2158258981","https://openalex.org/W2159085467","https://openalex.org/W2162422586","https://openalex.org/W2186501980","https://openalex.org/W2295914203","https://openalex.org/W2896505116","https://openalex.org/W2904215295","https://openalex.org/W2911549291","https://openalex.org/W2913948868","https://openalex.org/W3037857375","https://openalex.org/W3204266961","https://openalex.org/W4235410435","https://openalex.org/W4320732558","https://openalex.org/W4387842751","https://openalex.org/W6611235410","https://openalex.org/W6660851263","https://openalex.org/W6675908530"],"related_works":["https://openalex.org/W4391375266","https://openalex.org/W2899084033","https://openalex.org/W2748952813","https://openalex.org/W2051487156","https://openalex.org/W2073681303","https://openalex.org/W2390279801","https://openalex.org/W4391913857","https://openalex.org/W2358668433","https://openalex.org/W4396701345","https://openalex.org/W2376932109"],"abstract_inverted_index":{"Abstract":[0],"Experience":[1],"in":[2,25,51,62,102,139],"teaching":[3],"functional":[4],"programming":[5],"(FP)":[6],"on":[7,17,60],"a":[8,18,27,80,93,122,128],"relational":[9],"basis":[10],"has":[11],"led":[12],"the":[13,31,36,41,76,103],"author":[14],"to":[15,114],"focus":[16],"graphical":[19],"style":[20],"of":[21,68,82,95,125],"expression":[22],"and":[23,58,75,91,118,134],"reasoning":[24],"which":[26],"geometric":[28],"construct":[29],"shines:":[30],"(semi)":[32],"commutative":[33],"square.":[34],"In":[35],"classroom":[37],"this":[38],"is":[39,79,136],"termed":[40],"\u201cmagic":[42],"square\u201d":[43],"(MS),":[44],"since":[45],"virtually":[46],"everything":[47],"that":[48,141],"we":[49],"do":[50],"logic,":[52],"FP,":[53],"database":[54],"modeling,":[55],"formal":[56],"semantics":[57],"so":[59],"fits":[61],"some":[63],"MS":[64],"geometry.":[65],"The":[66],"sides":[67],"each":[69,85],"magic":[70],"square":[71,77],"are":[72,112],"binary":[73],"relations":[74],"itself":[78],"comparison":[81],"two":[83,87],"paths,":[84],"involving":[86],"sides.":[88],"MSs":[89,111],"compose":[90],"have":[92],"number":[94],"useful":[96],"properties.":[97],"Among":[98],"several":[99],"examples":[100],"given":[101],"paper":[104],"ranging":[105],"over":[106],"different":[107],"application":[108],"domains,":[109],"free-theorem":[110],"shown":[113],"be":[115],"particularly":[116],"elegant":[117],"productive.":[119],"Helped":[120],"by":[121],"little":[123],"bit":[124],"Galois":[126],"connections,":[127],"generic,":[129],"induction-free":[130],"theory":[131],"for":[132],"${\\mathsf{foldr}}$":[133],"$\\mathsf{foldl}$":[135],"given,":[137],"showing":[138],"particular":[140],"${\\mathsf{foldl}":[142],"\\,":[143],"{{s}}{}\\mathrel{=}\\mathsf{foldr}{({flip}":[144],"\\unicode{x005F}{s})}{}}$":[145],"holds":[146],"under":[147],"conditions":[148],"milder":[149],"than":[150],"usually":[151],"advocated.":[152]},"counts_by_year":[],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
