{"id":"https://openalex.org/W2930634101","doi":"https://doi.org/10.1145/3314221.3314630","title":"Type-level computations for Ruby libraries","display_name":"Type-level computations for Ruby libraries","publication_year":2019,"publication_date":"2019-06-07","ids":{"openalex":"https://openalex.org/W2930634101","doi":"https://doi.org/10.1145/3314221.3314630","mag":"2930634101"},"language":"en","primary_location":{"id":"doi:10.1145/3314221.3314630","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3314221.3314630","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314630","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},"type":"preprint","indexed_in":["arxiv","crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"gold","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314630","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5031013753","display_name":"Milod Kazerounian","orcid":null},"institutions":[{"id":"https://openalex.org/I66946132","display_name":"University of Maryland, College Park","ror":"https://ror.org/047s2c258","country_code":"US","type":"education","lineage":["https://openalex.org/I66946132"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Milod Kazerounian","raw_affiliation_strings":["University of Maryland at College Park, USA","University of Maryland - College Park"],"affiliations":[{"raw_affiliation_string":"University of Maryland at College Park, USA","institution_ids":["https://openalex.org/I66946132"]},{"raw_affiliation_string":"University of Maryland - College Park","institution_ids":["https://openalex.org/I66946132"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5083857944","display_name":"Sankha Narayan Guria","orcid":"https://orcid.org/0000-0002-5155-0964"},"institutions":[{"id":"https://openalex.org/I66946132","display_name":"University of Maryland, College Park","ror":"https://ror.org/047s2c258","country_code":"US","type":"education","lineage":["https://openalex.org/I66946132"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Sankha Narayan Guria","raw_affiliation_strings":["University of Maryland at College Park, USA","University of Maryland - College Park"],"affiliations":[{"raw_affiliation_string":"University of Maryland at College Park, USA","institution_ids":["https://openalex.org/I66946132"]},{"raw_affiliation_string":"University of Maryland - College Park","institution_ids":["https://openalex.org/I66946132"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5078144924","display_name":"Niki Vazou","orcid":"https://orcid.org/0000-0003-0732-5476"},"institutions":[{"id":"https://openalex.org/I4210143378","display_name":"IMDEA Food","ror":"https://ror.org/04g4ezh90","country_code":"ES","type":"facility","lineage":["https://openalex.org/I105140100","https://openalex.org/I4210143378"]},{"id":"https://openalex.org/I4210162154","display_name":"IMDEA Software","ror":"https://ror.org/04xvfkh51","country_code":"ES","type":"facility","lineage":["https://openalex.org/I105140100","https://openalex.org/I4210162154"]}],"countries":["ES"],"is_corresponding":false,"raw_author_name":"Niki Vazou","raw_affiliation_strings":["IMDEA Software Institute, Spain","Imdea"],"affiliations":[{"raw_affiliation_string":"IMDEA Software Institute, Spain","institution_ids":["https://openalex.org/I4210162154"]},{"raw_affiliation_string":"Imdea","institution_ids":["https://openalex.org/I4210143378"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5038702707","display_name":"Jeffrey S. Foster","orcid":"https://orcid.org/0000-0001-8043-1166"},"institutions":[{"id":"https://openalex.org/I121934306","display_name":"Tufts University","ror":"https://ror.org/05wvpxv85","country_code":"US","type":"education","lineage":["https://openalex.org/I121934306"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jeffrey S. Foster","raw_affiliation_strings":["Tufts University, USA","Tufts University"],"affiliations":[{"raw_affiliation_string":"Tufts University, USA","institution_ids":["https://openalex.org/I121934306"]},{"raw_affiliation_string":"Tufts University","institution_ids":["https://openalex.org/I121934306"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5091183810","display_name":"David Van Horn","orcid":"https://orcid.org/0000-0002-9201-6864"},"institutions":[{"id":"https://openalex.org/I66946132","display_name":"University of Maryland, College Park","ror":"https://ror.org/047s2c258","country_code":"US","type":"education","lineage":["https://openalex.org/I66946132"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"David Van Horn","raw_affiliation_strings":["University of Maryland at College Park, USA","University of Maryland - College Park"],"affiliations":[{"raw_affiliation_string":"University of Maryland at College Park, USA","institution_ids":["https://openalex.org/I66946132"]},{"raw_affiliation_string":"University of Maryland - College Park","institution_ids":["https://openalex.org/I66946132"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5031013753"],"corresponding_institution_ids":["https://openalex.org/I66946132"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.02629986,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":null,"issue":null,"first_page":"966","last_page":"979"},"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.9991000294685364,"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.9991000294685364,"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/T11424","display_name":"Security and Verification in Computing","score":0.9907000064849854,"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/T12479","display_name":"Web Application Security Vulnerabilities","score":0.9904999732971191,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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.7841647863388062},{"id":"https://openalex.org/keywords/column","display_name":"Column (typography)","score":0.6139519214630127},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.4973004162311554},{"id":"https://openalex.org/keywords/hash-table","display_name":"Hash table","score":0.48956021666526794},{"id":"https://openalex.org/keywords/computation","display_name":"Computation","score":0.48038703203201294},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.4490372836589813},{"id":"https://openalex.org/keywords/table","display_name":"Table (database)","score":0.4249211251735687},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.3672128915786743},{"id":"https://openalex.org/keywords/hash-function","display_name":"Hash function","score":0.36042529344558716},{"id":"https://openalex.org/keywords/information-retrieval","display_name":"Information retrieval","score":0.35732463002204895},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.2881009876728058}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7841647863388062},{"id":"https://openalex.org/C2780551164","wikidata":"https://www.wikidata.org/wiki/Q2306599","display_name":"Column (typography)","level":3,"score":0.6139519214630127},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.4973004162311554},{"id":"https://openalex.org/C67388219","wikidata":"https://www.wikidata.org/wiki/Q207440","display_name":"Hash table","level":3,"score":0.48956021666526794},{"id":"https://openalex.org/C45374587","wikidata":"https://www.wikidata.org/wiki/Q12525525","display_name":"Computation","level":2,"score":0.48038703203201294},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.4490372836589813},{"id":"https://openalex.org/C45235069","wikidata":"https://www.wikidata.org/wiki/Q278425","display_name":"Table (database)","level":2,"score":0.4249211251735687},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.3672128915786743},{"id":"https://openalex.org/C99138194","wikidata":"https://www.wikidata.org/wiki/Q183427","display_name":"Hash function","level":2,"score":0.36042529344558716},{"id":"https://openalex.org/C23123220","wikidata":"https://www.wikidata.org/wiki/Q816826","display_name":"Information retrieval","level":1,"score":0.35732463002204895},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.2881009876728058},{"id":"https://openalex.org/C126042441","wikidata":"https://www.wikidata.org/wiki/Q1324888","display_name":"Frame (networking)","level":2,"score":0.0},{"id":"https://openalex.org/C76155785","wikidata":"https://www.wikidata.org/wiki/Q418","display_name":"Telecommunications","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/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/3314221.3314630","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3314221.3314630","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314630","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},{"id":"pmh:oai:arXiv.org:1904.03521","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1904.03521","pdf_url":"https://arxiv.org/pdf/1904.03521","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"text"},{"id":"doi:10.48550/arxiv.1904.03521","is_oa":true,"landing_page_url":"https://doi.org/10.48550/arxiv.1904.03521","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article"},{"id":"mag:2930634101","is_oa":false,"landing_page_url":null,"pdf_url":null,"source":null,"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":null}],"best_oa_location":{"id":"doi:10.1145/3314221.3314630","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3314221.3314630","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314630","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},"sustainable_development_goals":[{"score":0.800000011920929,"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4"}],"awards":[{"id":"https://openalex.org/G1484089042","display_name":null,"funder_award_id":"CCF-1518844, CCF-1846350, DGE-1322106","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G1493363207","display_name":null,"funder_award_id":"/TCS-","funder_id":"https://openalex.org/F4320313831","funder_display_name":"Comunidad de Madrid"},{"id":"https://openalex.org/G3776007233","display_name":"B-cell development and gene regulation in three dimensions","funder_award_id":"322106","funder_id":"https://openalex.org/F4320320300","funder_display_name":"European Commission"},{"id":"https://openalex.org/G387917957","display_name":null,"funder_award_id":"S2018/TCS-4339","funder_id":"https://openalex.org/F4320320300","funder_display_name":"European Commission"},{"id":"https://openalex.org/G3996520613","display_name":null,"funder_award_id":"S2018/TCS-4339 (BLOQUES-CM)","funder_id":"https://openalex.org/F4320320300","funder_display_name":"European Commission"},{"id":"https://openalex.org/G467724132","display_name":"CAREER: Gradual Verification: From Scripting to Proving","funder_award_id":"1846350","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G5040290019","display_name":null,"funder_award_id":"S2018/TCS-4339","funder_id":"https://openalex.org/F4320313831","funder_display_name":"Comunidad de Madrid"},{"id":"https://openalex.org/G6123502051","display_name":null,"funder_award_id":"1322106","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G640085854","display_name":null,"funder_award_id":"S2018/TCS-4339 (BLOQUES-CM)","funder_id":"https://openalex.org/F4320325116","funder_display_name":"Consejer\u00eda de Educaci\u00f3n, Juventud y Deporte, Comunidad de Madrid"},{"id":"https://openalex.org/G6537961175","display_name":null,"funder_award_id":"1518844","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G7924197546","display_name":null,"funder_award_id":"CCF-1518844","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G979732938","display_name":null,"funder_award_id":"S2018/TCS-4339 (BLOQUES-CM)","funder_id":"https://openalex.org/F4320313831","funder_display_name":"Comunidad de Madrid"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320313831","display_name":"Comunidad de Madrid","ror":null},{"id":"https://openalex.org/F4320320300","display_name":"European Commission","ror":"https://ror.org/00k4n6c32"},{"id":"https://openalex.org/F4320325116","display_name":"Consejer\u00eda de Educaci\u00f3n, Juventud y Deporte, Comunidad de Madrid","ror":"https://ror.org/038tahs86"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2930634101.pdf","grobid_xml":"https://content.openalex.org/works/W2930634101.grobid-xml"},"referenced_works_count":38,"referenced_works":["https://openalex.org/W180405853","https://openalex.org/W1502282368","https://openalex.org/W1973186567","https://openalex.org/W1982209843","https://openalex.org/W1984352745","https://openalex.org/W1998709841","https://openalex.org/W2047497632","https://openalex.org/W2052973434","https://openalex.org/W2088675571","https://openalex.org/W2101085206","https://openalex.org/W2121038016","https://openalex.org/W2128886249","https://openalex.org/W2134879104","https://openalex.org/W2135536553","https://openalex.org/W2136327713","https://openalex.org/W2141210774","https://openalex.org/W2145287505","https://openalex.org/W2148535470","https://openalex.org/W2149469095","https://openalex.org/W2152419799","https://openalex.org/W2156249516","https://openalex.org/W2156285626","https://openalex.org/W2156351739","https://openalex.org/W2168938117","https://openalex.org/W2218092420","https://openalex.org/W2267469130","https://openalex.org/W2273111921","https://openalex.org/W2289066165","https://openalex.org/W2340618214","https://openalex.org/W2341286426","https://openalex.org/W2564970793","https://openalex.org/W2567080712","https://openalex.org/W3004785238","https://openalex.org/W3005614952","https://openalex.org/W3041252015","https://openalex.org/W3137596000","https://openalex.org/W4243993752","https://openalex.org/W4300939985"],"related_works":["https://openalex.org/W2963384924","https://openalex.org/W2756021059","https://openalex.org/W2535174441","https://openalex.org/W615361093","https://openalex.org/W2551714020","https://openalex.org/W2403900172","https://openalex.org/W129940593","https://openalex.org/W1042906801","https://openalex.org/W2111556049","https://openalex.org/W1760484232","https://openalex.org/W3193089433","https://openalex.org/W2260815988","https://openalex.org/W2073603361","https://openalex.org/W2767124493","https://openalex.org/W1580261468","https://openalex.org/W3193725769","https://openalex.org/W2475602767","https://openalex.org/W1485262574","https://openalex.org/W1486902566","https://openalex.org/W48057338"],"abstract_inverted_index":{"Many":[0],"researchers":[1],"have":[2],"explored":[3],"ways":[4],"to":[5,9,13,76,109,167,199,239,288],"bring":[6],"static":[7,285],"typing":[8],"dynamic":[10,289],"languages.":[11,290],"However,":[12],"date,":[14],"such":[15],"systems":[16],"are":[17],"not":[18],"precise":[19,112,284],"enough":[20],"when":[21,29],"types":[22,82,88,95,116],"depend":[23],"on":[24,45,48,209],"values,":[25],"which":[26],"often":[27],"arises":[28],"using":[30],"certain":[31],"Ruby":[32,44,69,187,204,208],"libraries.":[33],"For":[34],"example,":[35],"the":[36,49,56,130,148,215,232,256,271],"type":[37,66,74,102,113,133,141,146,200,223,261,286],"safety":[38],"of":[39,150,234],"a":[40,65,106,264],"database":[41,99,191],"query":[42,100,192],"in":[43,55,282],"Rails":[46,210],"depends":[47],"table":[50,90],"and":[51,91,120,127,138,190,206,220,263],"column":[52,92],"names":[53],"used":[54,196],"query.":[57],"To":[58],"address":[59],"this":[60],"issue,":[61],"we":[62,258,274],"introduce":[63],"CompRDL,":[64],"system":[67,142],"for":[68,83,89,117,132,185],"that":[70,104,267],"allows":[71],"library":[72,151,169],"method":[73],"signatures":[75,103],"include":[77,158],"type-level":[78,183,235,253],"computations":[79,184,236],"(or":[80],"comp":[81,94,154],"short).":[84],"Combined":[85],"with":[86,153,182,244],"singleton":[87],"names,":[93],"let":[96],"us":[97,238],"give":[98],"methods":[101,152,156,170,226],"compute":[105],"table\u2019s":[107],"schema":[108],"yield":[110],"very":[111],"information.":[114],"Comp":[115],"hash,":[118],"array,":[119],"string":[121],"libraries":[122,189,205],"can":[123],"also":[124],"increase":[125],"precision":[126],"thereby":[128],"reduce":[129],"need":[131],"casts.":[134],"We":[135,176,194,213],"formalize":[136],"CompRDL":[137,178,276],"prove":[139],"its":[140],"sound.":[143],"Rather":[144],"than":[145,249],"check":[147,201,224,240],"bodies":[149],"types\u2014those":[155],"may":[157],"native":[159],"code":[160],"or":[161],"be":[162],"complex\u2014CompRDL":[163],"inserts":[164],"run-time":[165],"checks":[166],"ensure":[168],"abide":[171],"by":[172,179,270],"their":[173],"computed":[174],"types.":[175],"evaluated":[177],"writing":[180],"annotations":[181,198,216],"several":[186],"core":[188],"APIs.":[193],"then":[195],"those":[197],"two":[202,260],"popular":[203],"four":[207],"web":[211],"apps.":[212],"found":[214,259],"were":[217,268],"relatively":[218],"compact":[219],"could":[221],"successfully":[222],"132":[225],"across":[227],"our":[228],"subject":[229],"programs.":[230],"Moreover,":[231],"use":[233],"allowed":[237],"more":[241],"expressive":[242],"properties,":[243],"fewer":[245],"manually":[246],"inserted":[247],"casts,":[248],"was":[250],"possible":[251],"without":[252],"computations.":[254],"In":[255],"process,":[257],"errors":[262],"documentation":[265],"error":[266],"confirmed":[269],"developers.":[272],"Thus,":[273],"believe":[275],"is":[277],"an":[278],"important":[279],"step":[280],"forward":[281],"bringing":[283],"checking":[287]},"counts_by_year":[],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
