{"id":"https://openalex.org/W2096280839","doi":"https://doi.org/10.1017/s0956796807006557","title":"Boxes go bananas: Encoding higher-order abstract syntax with parametric polymorphism","display_name":"Boxes go bananas: Encoding higher-order abstract syntax with parametric polymorphism","publication_year":2007,"publication_date":"2007-08-22","ids":{"openalex":"https://openalex.org/W2096280839","doi":"https://doi.org/10.1017/s0956796807006557","mag":"2096280839"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796807006557","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796807006557","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/06272FA70BF929DF103CF92700200CB7/S0956796807006557a.pdf/div-class-title-boxes-go-bananas-encoding-higher-order-abstract-syntax-with-parametric-polymorphism-a-href-fn1-ref-type-fn-a-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/06272FA70BF929DF103CF92700200CB7/S0956796807006557a.pdf/div-class-title-boxes-go-bananas-encoding-higher-order-abstract-syntax-with-parametric-polymorphism-a-href-fn1-ref-type-fn-a-div.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5032324538","display_name":"Geoffrey Washburn","orcid":null},"institutions":[{"id":"https://openalex.org/I79576946","display_name":"University of Pennsylvania","ror":"https://ror.org/00b30xv10","country_code":"US","type":"education","lineage":["https://openalex.org/I79576946"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"GEOFFREY WASHBURN","raw_affiliation_strings":["Department of Computer and Information Science, University of Pennsylvania, Philadelphia, Pennsylvania 19104, USA","Department of computer and information science, university of pennsylvania, philadelphia, pennsylvania 19104, usa (email: geoffw@cis.upenn.edu, sweirich@cis.upenn.edu)#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Department of Computer and Information Science, University of Pennsylvania, Philadelphia, Pennsylvania 19104, USA","institution_ids":["https://openalex.org/I79576946"]},{"raw_affiliation_string":"Department of computer and information science, university of pennsylvania, philadelphia, pennsylvania 19104, usa (email: geoffw@cis.upenn.edu, sweirich@cis.upenn.edu)#TAB#","institution_ids":["https://openalex.org/I79576946"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5049220962","display_name":"Stephanie Weirich","orcid":"https://orcid.org/0000-0002-6756-9168"},"institutions":[{"id":"https://openalex.org/I79576946","display_name":"University of Pennsylvania","ror":"https://ror.org/00b30xv10","country_code":"US","type":"education","lineage":["https://openalex.org/I79576946"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"STEPHANIE WEIRICH","raw_affiliation_strings":["Department of Computer and Information Science, University of Pennsylvania, Philadelphia, Pennsylvania 19104, USA","Department of computer and information science, university of pennsylvania, philadelphia, pennsylvania 19104, usa (email: geoffw@cis.upenn.edu, sweirich@cis.upenn.edu)#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Department of Computer and Information Science, University of Pennsylvania, Philadelphia, Pennsylvania 19104, USA","institution_ids":["https://openalex.org/I79576946"]},{"raw_affiliation_string":"Department of computer and information science, university of pennsylvania, philadelphia, pennsylvania 19104, usa (email: geoffw@cis.upenn.edu, sweirich@cis.upenn.edu)#TAB#","institution_ids":["https://openalex.org/I79576946"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5032324538"],"corresponding_institution_ids":["https://openalex.org/I79576946"],"apc_list":null,"apc_paid":null,"fwci":8.7074,"has_fulltext":true,"cited_by_count":36,"citation_normalized_percentile":{"value":0.9752353,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":"18","issue":"1","first_page":"87","last_page":"140"},"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/T10142","display_name":"Formal Methods in Verification","score":0.9965999722480774,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9952999949455261,"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/computer-science","display_name":"Computer science","score":0.8467135429382324},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7093336582183838},{"id":"https://openalex.org/keywords/syntax","display_name":"Syntax","score":0.645004153251648},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.508489727973938},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.5032197833061218},{"id":"https://openalex.org/keywords/abstract-syntax","display_name":"Abstract syntax","score":0.4962199330329895},{"id":"https://openalex.org/keywords/coding","display_name":"Coding (social sciences)","score":0.4590756595134735},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.45349299907684326},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.41123855113983154},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.3963896334171295},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.33477210998535156},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.2525761127471924},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.2230679988861084},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.11283153295516968}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8467135429382324},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7093336582183838},{"id":"https://openalex.org/C60048249","wikidata":"https://www.wikidata.org/wiki/Q37437","display_name":"Syntax","level":2,"score":0.645004153251648},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.508489727973938},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.5032197833061218},{"id":"https://openalex.org/C114408938","wikidata":"https://www.wikidata.org/wiki/Q333373","display_name":"Abstract syntax","level":3,"score":0.4962199330329895},{"id":"https://openalex.org/C179518139","wikidata":"https://www.wikidata.org/wiki/Q5140297","display_name":"Coding (social sciences)","level":2,"score":0.4590756595134735},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.45349299907684326},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.41123855113983154},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.3963896334171295},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.33477210998535156},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.2525761127471924},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.2230679988861084},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.11283153295516968},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0}],"mesh":[],"locations_count":6,"locations":[{"id":"doi:10.1017/s0956796807006557","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796807006557","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/06272FA70BF929DF103CF92700200CB7/S0956796807006557a.pdf/div-class-title-boxes-go-bananas-encoding-higher-order-abstract-syntax-with-parametric-polymorphism-a-href-fn1-ref-type-fn-a-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.473.8510","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.473.8510","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.696.5886","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.696.5886","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://repository.upenn.edu/cgi/viewcontent.cgi?article%3D1031%26context%3Dcis_reports","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.80.2219","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.80.2219","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.seas.upenn.edu/~sweirich/papers/itabox/MS-CIS-03-26.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.82.618","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.82.618","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cis.upenn.edu/~geoffw/research/papers/MS-CIS-03-26.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.96.4420","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.96.4420","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cis.upenn.edu/departmental/reports/documents/MS-CIS-03-26.pdf","raw_type":"text"}],"best_oa_location":{"id":"doi:10.1017/s0956796807006557","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796807006557","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/06272FA70BF929DF103CF92700200CB7/S0956796807006557a.pdf/div-class-title-boxes-go-bananas-encoding-higher-order-abstract-syntax-with-parametric-polymorphism-a-href-fn1-ref-type-fn-a-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":[],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2096280839.pdf","grobid_xml":"https://content.openalex.org/works/W2096280839.grobid-xml"},"referenced_works_count":50,"referenced_works":["https://openalex.org/W326743114","https://openalex.org/W1486010533","https://openalex.org/W1506948396","https://openalex.org/W1513579486","https://openalex.org/W1532420827","https://openalex.org/W1555705349","https://openalex.org/W1556536463","https://openalex.org/W1567853881","https://openalex.org/W1573333946","https://openalex.org/W1586302513","https://openalex.org/W1588934256","https://openalex.org/W1594279870","https://openalex.org/W1608714802","https://openalex.org/W1634581701","https://openalex.org/W1727609483","https://openalex.org/W1748927325","https://openalex.org/W1762966635","https://openalex.org/W1847080621","https://openalex.org/W1905449393","https://openalex.org/W1975957807","https://openalex.org/W1984514567","https://openalex.org/W1988824860","https://openalex.org/W1996404651","https://openalex.org/W1999336811","https://openalex.org/W2009464583","https://openalex.org/W2021447352","https://openalex.org/W2029408547","https://openalex.org/W2032234226","https://openalex.org/W2033185534","https://openalex.org/W2037021191","https://openalex.org/W2041562780","https://openalex.org/W2042372913","https://openalex.org/W2046645050","https://openalex.org/W2057292961","https://openalex.org/W2078944436","https://openalex.org/W2109649240","https://openalex.org/W2116286972","https://openalex.org/W2120348241","https://openalex.org/W2131828631","https://openalex.org/W2131916293","https://openalex.org/W2155581733","https://openalex.org/W2158542561","https://openalex.org/W2211325406","https://openalex.org/W2294191420","https://openalex.org/W2317488767","https://openalex.org/W2569668233","https://openalex.org/W2914249599","https://openalex.org/W3100508087","https://openalex.org/W4232327280","https://openalex.org/W4232595573"],"related_works":["https://openalex.org/W4246531319","https://openalex.org/W2140443934","https://openalex.org/W2531621405","https://openalex.org/W4312309273","https://openalex.org/W1587224678","https://openalex.org/W2514398768","https://openalex.org/W2203405714","https://openalex.org/W2112150205","https://openalex.org/W2952185493","https://openalex.org/W2169148161"],"abstract_inverted_index":{"Abstract":[0],"Higher-order":[1],"abstract":[2,75,128],"syntax":[3],"is":[4,55,61],"a":[5,81,135,195,211],"simple":[6],"technique":[7,52],"for":[8,73,214],"implementing":[9,35],"languages":[10],"with":[11,41],"functional":[12,153],"programming.":[13],"Object":[14],"variables":[15,21],"and":[16,22,37,177,197],"binders":[17,23],"are":[18,106],"implemented":[19],"by":[20,189],"in":[24,102,126,219],"the":[25,49,103,121,160,174],"host":[26],"language.":[27],"By":[28],"using":[29,190],"this":[30,51,109,131,146,167,191],"technique,":[31],"one":[32,84],"can":[33,116,208],"avoid":[34],"common":[36],"tricky":[38],"routines":[39],"dealing":[40],"variables,":[42],"such":[43,80],"as":[44,69,210],"capture-avoiding":[45],"substitution.":[46],"However,":[47],"despite":[48],"advantages":[50],"provides,":[53],"it":[54,60],"not":[56,94],"commonly":[57],"used":[58,118],"because":[59],"difficult":[62],"to":[63,119,157,173,193],"write":[64],"sound":[65,196],"elimination":[66],"forms":[67],"(such":[68],"folds":[70],"or":[71,96],"catamorphisms)":[72],"higher-order":[74,127,217],"syntax.":[76,129],"To":[77],"fold":[78],"over":[79,140],"data":[82,104,141],"type,":[83],"must":[85],"either":[86],"simultaneously":[87],"define":[88],"an":[89],"inverse":[90],"operation":[91],"(which":[92],"may":[93,155],"exist)":[95],"show":[97,112,165],"that":[98,152],"all":[99],"functions":[100,124],"embedded":[101,125],"type":[105],"parametric.":[107],"In":[108],"paper,":[110],"we":[111,133,148,164],"how":[113,166],"first-class":[114],"polymorphism":[115,171],"be":[117],"guarantee":[120],"parametricity":[122,182],"of":[123,137,169,180,200],"With":[130],"restriction,":[132],"implement":[134],"library":[136,192],"iteration":[138,161],"operators":[139],"structures":[142,218],"containing":[143],"functionals.":[144],"From":[145],"implementation,":[147],"derive":[149],"\u201cfusion":[150],"laws\u201d":[151],"programmers":[154],"use":[156,168],"reason":[158],"about":[159,216],"operator.":[162],"Finally,":[163],"parametric":[170],"corresponds":[172],"Sch\u00fcrmann,":[175],"Despeyroux":[176],"Pfenning":[178],"method":[179],"enforcing":[181],"through":[183],"modal":[184],"types.":[185],"We":[186],"do":[187],"so":[188],"give":[194],"complete":[198],"encoding":[199,207],"their":[201],"calculus":[202],"into":[203],"System":[204],".":[205],"This":[206],"serve":[209],"starting":[212],"point":[213],"reasoning":[215],"polymorphic":[220],"languages.":[221]},"counts_by_year":[{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":1},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":1},{"year":2014,"cited_by_count":1},{"year":2013,"cited_by_count":2},{"year":2012,"cited_by_count":5}],"updated_date":"2026-04-23T06:14:38.165362","created_date":"2025-10-10T00:00:00"}
