{"id":"https://openalex.org/W2156830909","doi":"https://doi.org/10.1145/2500365.2500575","title":"Typed syntactic meta-programming","display_name":"Typed syntactic meta-programming","publication_year":2013,"publication_date":"2013-09-25","ids":{"openalex":"https://openalex.org/W2156830909","doi":"https://doi.org/10.1145/2500365.2500575","mag":"2156830909"},"language":"en","primary_location":{"id":"doi:10.1145/2500365.2500575","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2500365.2500575","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 18th ACM SIGPLAN international conference on Functional programming","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"http://doi.acm.org/10.1145/2544174.2500575","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5011654888","display_name":"Dominique Devriese","orcid":"https://orcid.org/0000-0002-3862-6856"},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]},{"id":"https://openalex.org/I39327780","display_name":"iMinds","ror":"https://ror.org/03baec336","country_code":"BE","type":"nonprofit","lineage":["https://openalex.org/I39327780"]}],"countries":["BE"],"is_corresponding":true,"raw_author_name":"Dominique Devriese","raw_affiliation_strings":["iMinds -- DistriNet, KU Leuven, Leuven, Belgium"],"affiliations":[{"raw_affiliation_string":"iMinds -- DistriNet, KU Leuven, Leuven, Belgium","institution_ids":["https://openalex.org/I39327780","https://openalex.org/I99464096"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5008329832","display_name":"Frank Piessens","orcid":"https://orcid.org/0000-0001-5438-153X"},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]},{"id":"https://openalex.org/I39327780","display_name":"iMinds","ror":"https://ror.org/03baec336","country_code":"BE","type":"nonprofit","lineage":["https://openalex.org/I39327780"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Frank Piessens","raw_affiliation_strings":["iMinds -- DistriNet, KU Leuven, Leuven, Belgium"],"affiliations":[{"raw_affiliation_string":"iMinds -- DistriNet, KU Leuven, Leuven, Belgium","institution_ids":["https://openalex.org/I39327780","https://openalex.org/I99464096"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5011654888"],"corresponding_institution_ids":["https://openalex.org/I39327780","https://openalex.org/I99464096"],"apc_list":null,"apc_paid":null,"fwci":5.4368,"has_fulltext":false,"cited_by_count":15,"citation_normalized_percentile":{"value":0.95640362,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"73","last_page":"86"},"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.9998000264167786,"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.9998000264167786,"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/T10260","display_name":"Software Engineering Research","score":0.9965000152587891,"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/T10142","display_name":"Formal Methods in Verification","score":0.9940000176429749,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8622187972068787},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.8541465997695923},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.760267436504364},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.6816735863685608},{"id":"https://openalex.org/keywords/metaprogramming","display_name":"Metaprogramming","score":0.6292599439620972},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.5339352488517761},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.47373950481414795},{"id":"https://openalex.org/keywords/type-safety","display_name":"Type safety","score":0.4657842218875885},{"id":"https://openalex.org/keywords/functional-logic-programming","display_name":"Functional logic programming","score":0.46048957109451294},{"id":"https://openalex.org/keywords/programming-language-specification","display_name":"Programming language specification","score":0.4428372085094452},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.437957763671875},{"id":"https://openalex.org/keywords/completeness","display_name":"Completeness (order theory)","score":0.4369739592075348},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.43681231141090393},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.43636614084243774},{"id":"https://openalex.org/keywords/extension","display_name":"Extension (predicate logic)","score":0.41857945919036865},{"id":"https://openalex.org/keywords/inductive-programming","display_name":"Inductive programming","score":0.38032621145248413},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.35448259115219116},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.2832012176513672},{"id":"https://openalex.org/keywords/programming-domain","display_name":"Programming domain","score":0.24509313702583313},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.19659066200256348},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.08220264315605164}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8622187972068787},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8541465997695923},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.760267436504364},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.6816735863685608},{"id":"https://openalex.org/C35390924","wikidata":"https://www.wikidata.org/wiki/Q661075","display_name":"Metaprogramming","level":2,"score":0.6292599439620972},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.5339352488517761},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.47373950481414795},{"id":"https://openalex.org/C44779574","wikidata":"https://www.wikidata.org/wiki/Q736866","display_name":"Type safety","level":2,"score":0.4657842218875885},{"id":"https://openalex.org/C96315309","wikidata":"https://www.wikidata.org/wiki/Q5508829","display_name":"Functional logic programming","level":4,"score":0.46048957109451294},{"id":"https://openalex.org/C15077461","wikidata":"https://www.wikidata.org/wiki/Q7248507","display_name":"Programming language specification","level":5,"score":0.4428372085094452},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.437957763671875},{"id":"https://openalex.org/C17231256","wikidata":"https://www.wikidata.org/wiki/Q5156540","display_name":"Completeness (order theory)","level":2,"score":0.4369739592075348},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.43681231141090393},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.43636614084243774},{"id":"https://openalex.org/C2778029271","wikidata":"https://www.wikidata.org/wiki/Q5421931","display_name":"Extension (predicate logic)","level":2,"score":0.41857945919036865},{"id":"https://openalex.org/C50033165","wikidata":"https://www.wikidata.org/wiki/Q15712089","display_name":"Inductive programming","level":3,"score":0.38032621145248413},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.35448259115219116},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.2832012176513672},{"id":"https://openalex.org/C119263510","wikidata":"https://www.wikidata.org/wiki/Q7248501","display_name":"Programming domain","level":4,"score":0.24509313702583313},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.19659066200256348},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.08220264315605164},{"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},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/2500365.2500575","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2500365.2500575","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 18th ACM SIGPLAN international conference on Functional programming","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.729.680","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.729.680","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"https://lirias.kuleuven.be/bitstream/123456789/404549/1/icfp002-devriese-authorversion.pdf","raw_type":"text"},{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/438905","is_oa":true,"landing_page_url":"http://doi.acm.org/10.1145/2544174.2500575","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Acm Sigplan Notices, vol. 48 (9), (73-85)","raw_type":"info:eu-repo/semantics/publishedVersion"},{"id":"pmh:oai:vubissmart:VUBISSMART:2000:120080","is_oa":false,"landing_page_url":"https://biblio.vub.ac.be/vubir/typed-syntactic-metaprogramming(0a5fdba0-b5a3-421a-9d0d-a788caf03d40).html","pdf_url":null,"source":{"id":"https://openalex.org/S4306402573","display_name":"VUBIR (Vrije Universiteit Brussel)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I13469542","host_organization_name":"Vrije Universiteit Brussel","host_organization_lineage":["https://openalex.org/I13469542"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"article"}],"best_oa_location":{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/438905","is_oa":true,"landing_page_url":"http://doi.acm.org/10.1145/2544174.2500575","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Acm Sigplan Notices, vol. 48 (9), (73-85)","raw_type":"info:eu-repo/semantics/publishedVersion"},"sustainable_development_goals":[{"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4","score":0.4300000071525574}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":56,"referenced_works":["https://openalex.org/W70764853","https://openalex.org/W1488210308","https://openalex.org/W1515341800","https://openalex.org/W1528415032","https://openalex.org/W1529227536","https://openalex.org/W1539303361","https://openalex.org/W1548537769","https://openalex.org/W1554667392","https://openalex.org/W1572387991","https://openalex.org/W1575675278","https://openalex.org/W1577719850","https://openalex.org/W1578113853","https://openalex.org/W1598340254","https://openalex.org/W1607231186","https://openalex.org/W1777693579","https://openalex.org/W1968024460","https://openalex.org/W1969204136","https://openalex.org/W1975335792","https://openalex.org/W1978871081","https://openalex.org/W1979039632","https://openalex.org/W1990401544","https://openalex.org/W1996060755","https://openalex.org/W2007492338","https://openalex.org/W2009775190","https://openalex.org/W2011757033","https://openalex.org/W2012619465","https://openalex.org/W2014805020","https://openalex.org/W2018951244","https://openalex.org/W2047497632","https://openalex.org/W2051302691","https://openalex.org/W2074802267","https://openalex.org/W2086201554","https://openalex.org/W2093896470","https://openalex.org/W2094455839","https://openalex.org/W2096189519","https://openalex.org/W2101718506","https://openalex.org/W2109650208","https://openalex.org/W2113232207","https://openalex.org/W2114804254","https://openalex.org/W2120146214","https://openalex.org/W2137076681","https://openalex.org/W2147137665","https://openalex.org/W2147289514","https://openalex.org/W2160930653","https://openalex.org/W2167268698","https://openalex.org/W2182283312","https://openalex.org/W2561675875","https://openalex.org/W3104826616","https://openalex.org/W4213279211","https://openalex.org/W4214826241","https://openalex.org/W4235903093","https://openalex.org/W4246086292","https://openalex.org/W4253681328","https://openalex.org/W4256369010","https://openalex.org/W6631615477","https://openalex.org/W6683414556"],"related_works":["https://openalex.org/W2048147817","https://openalex.org/W2088006200","https://openalex.org/W2140774049","https://openalex.org/W2001858025","https://openalex.org/W126504055","https://openalex.org/W2964853020","https://openalex.org/W2072956890","https://openalex.org/W2979520889","https://openalex.org/W2048536148","https://openalex.org/W2156830909"],"abstract_inverted_index":{"We":[0,65],"present":[1],"a":[2,11],"novel":[3],"set":[4],"of":[5,17,38,76,81,85,92],"meta-programming":[6,69],"primitives":[7],"for":[8],"use":[9,58],"in":[10,50,89],"dependently-typed":[12],"functional":[13,62],"language.":[14],"The":[15],"types":[16,40],"our":[18],"meta-programs":[19],"provide":[20,79],"strong":[21],"and":[22,29,36,41,57,78,95],"precise":[23],"guarantees":[24],"about":[25],"their":[26],"termination,":[27],"correctness":[28],"completeness.":[30],"Our":[31],"system":[32],"supports":[33],"type-safe":[34],"construction":[35],"analysis":[37],"terms,":[39],"typing":[42],"contexts.":[43],"Unlike":[44],"alternative":[45],"approaches,":[46],"they":[47],"are":[48],"written":[49],"the":[51,59,67,90],"same":[52],"style":[53],"as":[54,73],"normal":[55],"programs":[56],"language's":[60],"standard":[61],"computational":[63],"model.":[64],"formalise":[66],"new":[68],"primitives,":[70],"implement":[71],"them":[72],"an":[74],"extension":[75],"Agda,":[77],"evidence":[80],"usefulness":[82],"by":[83],"means":[84],"two":[86],"compelling":[87],"applications":[88],"fields":[91],"datatype-generic":[93],"programming":[94],"proof":[96],"tactics.":[97]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":1},{"year":2016,"cited_by_count":5},{"year":2015,"cited_by_count":5},{"year":2013,"cited_by_count":1}],"updated_date":"2026-04-22T08:38:42.863108","created_date":"2025-10-10T00:00:00"}
