{"id":"https://openalex.org/W3215948348","doi":"https://doi.org/10.1145/3486609.3487209","title":"Type-safe generation of modules in applicative and generative styles","display_name":"Type-safe generation of modules in applicative and generative styles","publication_year":2021,"publication_date":"2021-10-17","ids":{"openalex":"https://openalex.org/W3215948348","doi":"https://doi.org/10.1145/3486609.3487209","mag":"3215948348"},"language":"en","primary_location":{"id":"doi:10.1145/3486609.3487209","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3486609.3487209","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th ACM SIGPLAN International Conference on Generative Programming: Concepts and Experiences","raw_type":"proceedings-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/A5113914916","display_name":"Yuhi Sato","orcid":null},"institutions":[{"id":"https://openalex.org/I146399215","display_name":"University of Tsukuba","ror":"https://ror.org/02956yf07","country_code":"JP","type":"education","lineage":["https://openalex.org/I146399215"]}],"countries":["JP"],"is_corresponding":true,"raw_author_name":"Yuhi Sato","raw_affiliation_strings":["University of Tsukuba, Japan"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Tsukuba, Japan","institution_ids":["https://openalex.org/I146399215"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5052312242","display_name":"Yukiyoshi Kameyama","orcid":"https://orcid.org/0000-0002-2693-5133"},"institutions":[{"id":"https://openalex.org/I146399215","display_name":"University of Tsukuba","ror":"https://ror.org/02956yf07","country_code":"JP","type":"education","lineage":["https://openalex.org/I146399215"]}],"countries":["JP"],"is_corresponding":false,"raw_author_name":"Yukiyoshi Kameyama","raw_affiliation_strings":["University of Tsukuba, Japan"],"raw_orcid":"https://orcid.org/0000-0002-2693-5133","affiliations":[{"raw_affiliation_string":"University of Tsukuba, Japan","institution_ids":["https://openalex.org/I146399215"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5113914916"],"corresponding_institution_ids":["https://openalex.org/I146399215"],"apc_list":null,"apc_paid":null,"fwci":0.5695,"has_fulltext":false,"cited_by_count":2,"citation_normalized_percentile":{"value":0.75331581,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":null,"issue":null,"first_page":"184","last_page":"196"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9987000226974487,"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"}},"topics":[{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9987000226974487,"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"}},{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9984999895095825,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9980000257492065,"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/programming-language","display_name":"Programming language","score":0.8096171021461487},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.804092288017273},{"id":"https://openalex.org/keywords/scope","display_name":"Scope (computer science)","score":0.7348944544792175},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.6488451957702637},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.49895334243774414},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.461119145154953},{"id":"https://openalex.org/keywords/type-safety","display_name":"Type safety","score":0.4509555399417877},{"id":"https://openalex.org/keywords/generative-grammar","display_name":"Generative grammar","score":0.44879427552223206},{"id":"https://openalex.org/keywords/scale","display_name":"Scale (ratio)","score":0.43429774045944214},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.32638609409332275},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.2038266956806183},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.17324435710906982},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.10356301069259644},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.06222259998321533}],"concepts":[{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8096171021461487},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.804092288017273},{"id":"https://openalex.org/C2778012447","wikidata":"https://www.wikidata.org/wiki/Q1034415","display_name":"Scope (computer science)","level":2,"score":0.7348944544792175},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.6488451957702637},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.49895334243774414},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.461119145154953},{"id":"https://openalex.org/C44779574","wikidata":"https://www.wikidata.org/wiki/Q736866","display_name":"Type safety","level":2,"score":0.4509555399417877},{"id":"https://openalex.org/C39890363","wikidata":"https://www.wikidata.org/wiki/Q36108","display_name":"Generative grammar","level":2,"score":0.44879427552223206},{"id":"https://openalex.org/C2778755073","wikidata":"https://www.wikidata.org/wiki/Q10858537","display_name":"Scale (ratio)","level":2,"score":0.43429774045944214},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.32638609409332275},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.2038266956806183},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.17324435710906982},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.10356301069259644},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.06222259998321533},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"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.1145/3486609.3487209","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3486609.3487209","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th ACM SIGPLAN International Conference on Generative Programming: Concepts and Experiences","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":18,"referenced_works":["https://openalex.org/W1488857024","https://openalex.org/W1584169136","https://openalex.org/W1650987719","https://openalex.org/W1941632313","https://openalex.org/W2006119589","https://openalex.org/W2123092976","https://openalex.org/W2126328048","https://openalex.org/W2134291411","https://openalex.org/W2167017930","https://openalex.org/W2238944434","https://openalex.org/W2239389360","https://openalex.org/W2247694024","https://openalex.org/W2601778681","https://openalex.org/W2764337128","https://openalex.org/W2780684764","https://openalex.org/W2994726342","https://openalex.org/W3108544736","https://openalex.org/W4252279595"],"related_works":["https://openalex.org/W283806354","https://openalex.org/W2160620982","https://openalex.org/W3006199460","https://openalex.org/W2519339279","https://openalex.org/W2084957735","https://openalex.org/W2763815264","https://openalex.org/W1565501066","https://openalex.org/W2797934247","https://openalex.org/W4320814215","https://openalex.org/W2044422526"],"abstract_inverted_index":{"The":[0],"MetaML":[1],"approach":[2],"for":[3,16],"multi-stage":[4],"programming":[5],"provides":[6],"the":[7,21,60],"static":[8,24],"guarantee":[9],"of":[10,20,23,62],"type":[11],"safety":[12,15],"and":[13,67],"scope":[14],"generated":[17],"code,":[18],"regardless":[19],"values":[22],"parameters.":[25],"Modules":[26],"are":[27],"indispensable":[28],"to":[29,52],"build":[30],"large-scale":[31],"programs":[32],"in":[33],"ML-like":[34],"languages,":[35],"however,":[36],"they":[37],"have":[38],"a":[39],"performance":[40],"problem.":[41],"To":[42],"solve":[43],"this":[44],"problem,":[45],"several":[46],"languages":[47,58],"proposed":[48],"recently":[49],"allow":[50],"one":[51],"generate":[53],"ML-style":[54],"modules.":[55],"Unfortunately,":[56],"those":[57],"had":[59],"problems":[61],"limited":[63],"expressiveness,":[64],"incomplete":[65],"proofs,":[66],"code":[68],"explosion.":[69]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2023,"cited_by_count":1}],"updated_date":"2026-02-07T06:11:34.122080","created_date":"2025-10-10T00:00:00"}
