{"id":"https://openalex.org/W2907069560","doi":"https://doi.org/10.1017/s0956796820000234","title":"Elastic sheet-defined functions: Generalising spreadsheet functions to variable-size input arrays","display_name":"Elastic sheet-defined functions: Generalising spreadsheet functions to variable-size input arrays","publication_year":2020,"publication_date":"2020-01-01","ids":{"openalex":"https://openalex.org/W2907069560","doi":"https://doi.org/10.1017/s0956796820000234","mag":"2907069560"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796820000234","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s0956796820000234","pdf_url":null,"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":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5066642904","display_name":"Matt McCutchen","orcid":"https://orcid.org/0000-0003-4814-5148"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"MATT MCCUTCHEN","raw_affiliation_strings":["Massachusetts Institute of Technology, (e-mail:"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, (e-mail:","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5039015687","display_name":"Judith Borghouts","orcid":"https://orcid.org/0000-0001-9716-0147"},"institutions":[{"id":"https://openalex.org/I204250578","display_name":"University of California, Irvine","ror":"https://ror.org/04gyf1771","country_code":"US","type":"education","lineage":["https://openalex.org/I204250578"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"JUDITH BORGHOUTS","raw_affiliation_strings":["University of California Irvine, (e-mail:"],"affiliations":[{"raw_affiliation_string":"University of California Irvine, (e-mail:","institution_ids":["https://openalex.org/I204250578"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5078684560","display_name":"Andrew D. Gordon","orcid":"https://orcid.org/0000-0002-5809-2484"},"institutions":[{"id":"https://openalex.org/I98677209","display_name":"University of Edinburgh","ror":"https://ror.org/01nrxwf90","country_code":"GB","type":"education","lineage":["https://openalex.org/I98677209"]},{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"ANDREW D. GORDON","raw_affiliation_strings":["Microsoft Research and University of Edinburgh, (e-mail:"],"affiliations":[{"raw_affiliation_string":"Microsoft Research and University of Edinburgh, (e-mail:","institution_ids":["https://openalex.org/I4210164937","https://openalex.org/I98677209"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5027817074","display_name":"Simon Peyton Jones","orcid":"https://orcid.org/0000-0002-6085-1435"},"institutions":[{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"SIMON PEYTON JONES","raw_affiliation_strings":["Microsoft Research, (e-mail:"],"affiliations":[{"raw_affiliation_string":"Microsoft Research, (e-mail:","institution_ids":["https://openalex.org/I4210164937"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5025427198","display_name":"Advait Sarkar","orcid":"https://orcid.org/0000-0002-5401-3478"},"institutions":[{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"ADVAIT SARKAR","raw_affiliation_strings":["Microsoft Research and University of Cambridge, (e-mail:"],"affiliations":[{"raw_affiliation_string":"Microsoft Research and University of Cambridge, (e-mail:","institution_ids":["https://openalex.org/I4210164937"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5066642904"],"corresponding_institution_ids":["https://openalex.org/I63966007"],"apc_list":null,"apc_paid":null,"fwci":2.1268,"has_fulltext":false,"cited_by_count":13,"citation_normalized_percentile":{"value":0.86617827,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":97},"biblio":{"volume":"30","issue":null,"first_page":null,"last_page":null},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T13197","display_name":"Spreadsheets and End-User Computing","score":1.0,"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"}},"topics":[{"id":"https://openalex.org/T13197","display_name":"Spreadsheets and End-User Computing","score":1.0,"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"}},{"id":"https://openalex.org/T11875","display_name":"Statistics Education and Methodologies","score":0.9735000133514404,"subfield":{"id":"https://openalex.org/subfields/2613","display_name":"Statistics and Probability"},"field":{"id":"https://openalex.org/fields/26","display_name":"Mathematics"},"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.7742101550102234},{"id":"https://openalex.org/keywords/reusability","display_name":"Reusability","score":0.593409538269043},{"id":"https://openalex.org/keywords/abstraction","display_name":"Abstraction","score":0.5379716753959656},{"id":"https://openalex.org/keywords/modularity","display_name":"Modularity (biology)","score":0.43505096435546875},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.4312078058719635},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.374180406332016},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.326591432094574},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3041401505470276},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.08541420102119446}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7742101550102234},{"id":"https://openalex.org/C137981799","wikidata":"https://www.wikidata.org/wiki/Q1369184","display_name":"Reusability","level":3,"score":0.593409538269043},{"id":"https://openalex.org/C124304363","wikidata":"https://www.wikidata.org/wiki/Q673661","display_name":"Abstraction","level":2,"score":0.5379716753959656},{"id":"https://openalex.org/C2779478453","wikidata":"https://www.wikidata.org/wiki/Q6889748","display_name":"Modularity (biology)","level":2,"score":0.43505096435546875},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.4312078058719635},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.374180406332016},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.326591432094574},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3041401505470276},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.08541420102119446},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C54355233","wikidata":"https://www.wikidata.org/wiki/Q7162","display_name":"Genetics","level":1,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","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}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1017/s0956796820000234","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s0956796820000234","pdf_url":null,"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"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":26,"referenced_works":["https://openalex.org/W969178593","https://openalex.org/W1481748901","https://openalex.org/W1552210990","https://openalex.org/W1579827372","https://openalex.org/W1996473305","https://openalex.org/W2064189581","https://openalex.org/W2106646204","https://openalex.org/W2119723190","https://openalex.org/W2157289187","https://openalex.org/W2157504474","https://openalex.org/W2249595199","https://openalex.org/W2407300725","https://openalex.org/W2513098074","https://openalex.org/W2538785426","https://openalex.org/W2735925068","https://openalex.org/W2742437839","https://openalex.org/W2791446013","https://openalex.org/W2898211431","https://openalex.org/W2898431302","https://openalex.org/W2976890614","https://openalex.org/W3010368440","https://openalex.org/W4229675450","https://openalex.org/W4255684519","https://openalex.org/W6602279961","https://openalex.org/W6749163934","https://openalex.org/W6774932580"],"related_works":["https://openalex.org/W3160136729","https://openalex.org/W2788308474","https://openalex.org/W1587224678","https://openalex.org/W1502311553","https://openalex.org/W2100295925","https://openalex.org/W4231425278","https://openalex.org/W2135227066","https://openalex.org/W2203405714","https://openalex.org/W965065466","https://openalex.org/W47258078"],"abstract_inverted_index":{"Abstract":[0],"Sheet-defined":[1],"functions":[2,45],"(SDFs)":[3],"bring":[4],"modularity":[5],"and":[6,79],"abstraction":[7],"to":[8,42,46,102],"the":[9,67,94,103,115,130],"world":[10],"of":[11,54,70,97,105,118],"spreadsheets.":[12],"Alas,":[13],"end":[14,30],"users":[15,92],"naturally":[16],"write":[17,33],"SDFs":[18,49,101,120,125],"that":[19,50,59,114],"work":[20,51],"over":[21,52],"fixed-size":[22],"arrays,":[23],"which":[24],"limits":[25],"their":[26],"reusability.":[27],"To":[28],"help":[29],"user":[31,88,111],"programmers":[32],"more":[34],"reusable":[35],"SDFs,":[36],"we":[37],"describe":[38,75],"a":[39,76],"principled":[40],"approach":[41],"generalising":[43],"such":[44],"become":[47],"elastic":[48,85,100,119],"inputs":[53],"arbitrary":[55],"size.":[56],"We":[57,74],"prove":[58],"under":[60],"natural,":[61],"checkable":[62],"conditions,":[63],"our":[64],"algorithm":[65],"returns":[66],"principal":[68],"generalisation":[69],"an":[71],"input":[72],"SDF.":[73],"formal":[77],"semantics":[78],"several":[80],"efficient":[81],"implementation":[82],"strategies":[83],"for":[84,124],"SDFs.":[86],"A":[87],"study":[89,112],"with":[90,99,126],"spreadsheet":[91],"compares":[93],"human":[95],"experience":[96],"programming":[98],"alternative":[104,132],"relying":[106],"on":[107],"array-processing":[108],"combinators.":[109],"Our":[110],"finds":[113],"cognitive":[116],"load":[117],"is":[121],"lower":[122],"than":[123],"map/reduce":[127],"array":[128],"combinators,":[129],"closest":[131],"solution.":[133]},"counts_by_year":[{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":3},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":3},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
