{"id":"https://openalex.org/W2026542744","doi":"https://doi.org/10.1145/1836089.1836113","title":"A meta-programming approach to realizing dependently typed logic programming","display_name":"A meta-programming approach to realizing dependently typed logic programming","publication_year":2010,"publication_date":"2010-07-26","ids":{"openalex":"https://openalex.org/W2026542744","doi":"https://doi.org/10.1145/1836089.1836113","mag":"2026542744"},"language":"en","primary_location":{"id":"doi:10.1145/1836089.1836113","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1836089.1836113","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 12th international ACM SIGPLAN symposium on Principles and practice of declarative programming","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/A5080975819","display_name":"Zachary Snow","orcid":null},"institutions":[{"id":"https://openalex.org/I130238516","display_name":"University of Minnesota","ror":"https://ror.org/017zqws13","country_code":"US","type":"education","lineage":["https://openalex.org/I130238516"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Zachary Snow","raw_affiliation_strings":["University of Minnesota, Minneapolis, MN, USA",", University of Minnesota, Minneapolis, MN, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Minnesota, Minneapolis, MN, USA","institution_ids":["https://openalex.org/I130238516"]},{"raw_affiliation_string":", University of Minnesota, Minneapolis, MN, USA","institution_ids":["https://openalex.org/I130238516"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5111431300","display_name":"David Baelde","orcid":null},"institutions":[{"id":"https://openalex.org/I130238516","display_name":"University of Minnesota","ror":"https://ror.org/017zqws13","country_code":"US","type":"education","lineage":["https://openalex.org/I130238516"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"David Baelde","raw_affiliation_strings":["University of Minnesota, Minneapolis, MN, USA",", University of Minnesota, Minneapolis, MN, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Minnesota, Minneapolis, MN, USA","institution_ids":["https://openalex.org/I130238516"]},{"raw_affiliation_string":", University of Minnesota, Minneapolis, MN, USA","institution_ids":["https://openalex.org/I130238516"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5080344559","display_name":"Gopalan Nadathur","orcid":"https://orcid.org/0000-0001-8456-3369"},"institutions":[{"id":"https://openalex.org/I130238516","display_name":"University of Minnesota","ror":"https://ror.org/017zqws13","country_code":"US","type":"education","lineage":["https://openalex.org/I130238516"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Gopalan Nadathur","raw_affiliation_strings":["University of Minnesota, Minneapolis, MN, USA",", University of Minnesota, Minneapolis, MN, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Minnesota, Minneapolis, MN, USA","institution_ids":["https://openalex.org/I130238516"]},{"raw_affiliation_string":", University of Minnesota, Minneapolis, MN, USA","institution_ids":["https://openalex.org/I130238516"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.3307,"has_fulltext":false,"cited_by_count":10,"citation_normalized_percentile":{"value":0.89402214,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"187","last_page":"198"},"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/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.9976000189781189,"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.9958999752998352,"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.7412679195404053},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7341495156288147},{"id":"https://openalex.org/keywords/logic-programming","display_name":"Logic programming","score":0.7286604642868042},{"id":"https://openalex.org/keywords/prolog","display_name":"Prolog","score":0.717675507068634},{"id":"https://openalex.org/keywords/metaprogramming","display_name":"Metaprogramming","score":0.559770941734314},{"id":"https://openalex.org/keywords/horn-clause","display_name":"Horn clause","score":0.5400702357292175},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.4921385645866394},{"id":"https://openalex.org/keywords/encode","display_name":"ENCODE","score":0.4722064137458801},{"id":"https://openalex.org/keywords/interpretation","display_name":"Interpretation (philosophy)","score":0.4415940046310425},{"id":"https://openalex.org/keywords/encoding","display_name":"Encoding (memory)","score":0.4338301420211792},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.4252047538757324},{"id":"https://openalex.org/keywords/functional-logic-programming","display_name":"Functional logic programming","score":0.4140027165412903},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.40887385606765747},{"id":"https://openalex.org/keywords/inductive-programming","display_name":"Inductive programming","score":0.3484961688518524},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.3164222836494446},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.2685988247394562},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.20148822665214539},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.1674444079399109}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7412679195404053},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7341495156288147},{"id":"https://openalex.org/C128838566","wikidata":"https://www.wikidata.org/wiki/Q275603","display_name":"Logic programming","level":2,"score":0.7286604642868042},{"id":"https://openalex.org/C81721847","wikidata":"https://www.wikidata.org/wiki/Q163468","display_name":"Prolog","level":2,"score":0.717675507068634},{"id":"https://openalex.org/C35390924","wikidata":"https://www.wikidata.org/wiki/Q661075","display_name":"Metaprogramming","level":2,"score":0.559770941734314},{"id":"https://openalex.org/C189790780","wikidata":"https://www.wikidata.org/wiki/Q933932","display_name":"Horn clause","level":3,"score":0.5400702357292175},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.4921385645866394},{"id":"https://openalex.org/C66746571","wikidata":"https://www.wikidata.org/wiki/Q1134833","display_name":"ENCODE","level":3,"score":0.4722064137458801},{"id":"https://openalex.org/C527412718","wikidata":"https://www.wikidata.org/wiki/Q855395","display_name":"Interpretation (philosophy)","level":2,"score":0.4415940046310425},{"id":"https://openalex.org/C125411270","wikidata":"https://www.wikidata.org/wiki/Q18653","display_name":"Encoding (memory)","level":2,"score":0.4338301420211792},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.4252047538757324},{"id":"https://openalex.org/C96315309","wikidata":"https://www.wikidata.org/wiki/Q5508829","display_name":"Functional logic programming","level":4,"score":0.4140027165412903},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.40887385606765747},{"id":"https://openalex.org/C50033165","wikidata":"https://www.wikidata.org/wiki/Q15712089","display_name":"Inductive programming","level":3,"score":0.3484961688518524},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.3164222836494446},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.2685988247394562},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.20148822665214539},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.1674444079399109},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0},{"id":"https://openalex.org/C55493867","wikidata":"https://www.wikidata.org/wiki/Q7094","display_name":"Biochemistry","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/C185592680","wikidata":"https://www.wikidata.org/wiki/Q2329","display_name":"Chemistry","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},{"id":"https://openalex.org/C104317684","wikidata":"https://www.wikidata.org/wiki/Q7187","display_name":"Gene","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/1836089.1836113","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1836089.1836113","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 12th international ACM SIGPLAN symposium on Principles and practice of declarative programming","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":22,"referenced_works":["https://openalex.org/W4861723","https://openalex.org/W1502296299","https://openalex.org/W1507932752","https://openalex.org/W1523013478","https://openalex.org/W1537833215","https://openalex.org/W1568176286","https://openalex.org/W1597159378","https://openalex.org/W1727609483","https://openalex.org/W1974190112","https://openalex.org/W1996404651","https://openalex.org/W2032234226","https://openalex.org/W2034711041","https://openalex.org/W2062108951","https://openalex.org/W2075352622","https://openalex.org/W2093111544","https://openalex.org/W2103365302","https://openalex.org/W2107463944","https://openalex.org/W2126773497","https://openalex.org/W2129206752","https://openalex.org/W2137586949","https://openalex.org/W2151581682","https://openalex.org/W6676215324"],"related_works":["https://openalex.org/W574022443","https://openalex.org/W29725558","https://openalex.org/W1969965298","https://openalex.org/W2140587192","https://openalex.org/W2553706208","https://openalex.org/W648195185","https://openalex.org/W4250566046","https://openalex.org/W57122139","https://openalex.org/W53008362","https://openalex.org/W2386072558"],"abstract_inverted_index":{"Dependently":[0],"typed":[1],"\u03bb-calculi":[2],"such":[3,42],"as":[4,147],"the":[5,36,58,86,98,114,117,137,151,171,174],"Logical":[6],"Framework":[7],"(LF)":[8],"can":[9,17,28,56,107],"encode":[10],"relationships":[11],"between":[12,21,97],"terms":[13],"in":[14,85],"types":[15],"and":[16,23,67,95],"naturally":[18],"capture":[19],"correspondences":[20],"formulas":[22,84],"their":[24],"proofs.":[25],"Such":[26],"calculi":[27],"also":[29],"be":[30,108,145],"given":[31],"a":[32,51,61,74,81,132],"logic":[33,53,129],"programming":[34,54],"interpretation:":[35],"Twelf":[37,175],"system":[38,63,176],"is":[39],"based":[40],"on":[41],"an":[43,163],"interpretation":[44],"of":[45,60,83,113,116,154],"LF.":[46],"We":[47,101],"consider":[48],"here":[49],"whether":[50],"conventional":[52],"language":[55],"provide":[57],"benefits":[59],"Twelf-like":[62],"for":[64,166,178],"encoding":[65,106],"type":[66],"proof-and-formula":[68],"dependencies.":[69],"In":[70],"particular,":[71],"we":[72,157],"present":[73],"simple":[75],"mapping":[76],"from":[77],"LF":[78,119,142,168],"specifications":[79,120,143],"to":[80,121,144],"set":[82],"higher-order":[87],"hereditary":[88],"Harrop":[89],"(hohh)":[90],"language,":[91],"that":[92,104,134,159,173],"relates":[93],"derivations":[94],"proof-search":[96],"two":[99],"frameworks.":[100],"then":[102],"show":[103,158],"this":[105],"improved":[109],"by":[110],"exploiting":[111],"knowledge":[112],"well-formedness":[115],"original":[118,138],"elide":[122],"much":[123],"redundant":[124],"type-checking":[125],"information.":[126],"The":[127],"resulting":[128],"program":[130],"has":[131],"structure":[133],"closely":[135],"resembles":[136],"specification,":[139],"thereby":[140],"allowing":[141],"viewed":[146],"hohh":[148],"meta-programs.":[149],"Using":[150],"Teyjus":[152],"implementation":[153],"\u03bb":[155],"Prolog,":[156],"our":[160],"translation":[161],"provides":[162,177],"efficient":[164],"means":[165],"executing":[167],"specifications,":[169],"complementing":[170],"ability":[172],"reasoning":[179],"about":[180],"them.":[181]},"counts_by_year":[{"year":2021,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2014,"cited_by_count":1},{"year":2013,"cited_by_count":5}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
