{"id":"https://openalex.org/W2000778709","doi":"https://doi.org/10.1017/s0956796803004921","title":"Dependent types ensure partial correctness of theorem provers","display_name":"Dependent types ensure partial correctness of theorem provers","publication_year":2004,"publication_date":"2004-01-01","ids":{"openalex":"https://openalex.org/W2000778709","doi":"https://doi.org/10.1017/s0956796803004921","mag":"2000778709"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796803004921","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796803004921","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/C968F39F6E1649C722A4572FAB862F0C/S0956796803004921a.pdf/div-class-title-dependent-types-ensure-partial-correctness-of-theorem-provers-div.pdf","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":true,"oa_status":"bronze","oa_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/C968F39F6E1649C722A4572FAB862F0C/S0956796803004921a.pdf/div-class-title-dependent-types-ensure-partial-correctness-of-theorem-provers-div.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5004766305","display_name":"Andrew W. Appel","orcid":"https://orcid.org/0000-0001-6009-0325"},"institutions":[{"id":"https://openalex.org/I20089843","display_name":"Princeton University","ror":"https://ror.org/00hx57361","country_code":"US","type":"education","lineage":["https://openalex.org/I20089843"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"ANDREW W. APPEL","raw_affiliation_strings":["Princeton University, 35 Olden Street, Princeton, NJ 08544, USA (e-mail:","Princeton University, 35 Olden Street, Princeton, NJ 08544, USA (e-mail: appel@princeton.edu)"],"affiliations":[{"raw_affiliation_string":"Princeton University, 35 Olden Street, Princeton, NJ 08544, USA (e-mail:","institution_ids":["https://openalex.org/I20089843"]},{"raw_affiliation_string":"Princeton University, 35 Olden Street, Princeton, NJ 08544, USA (e-mail: appel@princeton.edu)","institution_ids":["https://openalex.org/I20089843"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5090020170","display_name":"Amy Felty","orcid":"https://orcid.org/0000-0001-7195-2613"},"institutions":[{"id":"https://openalex.org/I153718931","display_name":"University of Ottawa","ror":"https://ror.org/03c4mmv16","country_code":"CA","type":"education","lineage":["https://openalex.org/I153718931"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"AMY P. FELTY","raw_affiliation_strings":["University of Ottawa, 800 King Edward Ave., Ottawa, Ontario K1N 6N5, Canada (e-mail:","University of Ottawa, 800 King Edward Ave., Ottawa, Ontario K1N 6N5, Canada (e-mail: afelty@site.uottawa.ca)#TAB#"],"affiliations":[{"raw_affiliation_string":"University of Ottawa, 800 King Edward Ave., Ottawa, Ontario K1N 6N5, Canada (e-mail:","institution_ids":["https://openalex.org/I153718931"]},{"raw_affiliation_string":"University of Ottawa, 800 King Edward Ave., Ottawa, Ontario K1N 6N5, Canada (e-mail: afelty@site.uottawa.ca)#TAB#","institution_ids":["https://openalex.org/I153718931"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5004766305"],"corresponding_institution_ids":["https://openalex.org/I20089843"],"apc_list":null,"apc_paid":null,"fwci":3.2349,"has_fulltext":true,"cited_by_count":17,"citation_normalized_percentile":{"value":0.92019571,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":"14","issue":"1","first_page":"3","last_page":"19"},"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.994700014591217,"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.9944999814033508,"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.8510637283325195},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.844668984413147},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.750339150428772},{"id":"https://openalex.org/keywords/automated-theorem-proving","display_name":"Automated theorem proving","score":0.6717109680175781},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6386401057243347},{"id":"https://openalex.org/keywords/proof-assistant","display_name":"Proof assistant","score":0.48419883847236633},{"id":"https://openalex.org/keywords/gas-meter-prover","display_name":"Gas meter prover","score":0.44796445965766907},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.347215861082077},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.1205369234085083},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.097251296043396}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8510637283325195},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.844668984413147},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.750339150428772},{"id":"https://openalex.org/C206880738","wikidata":"https://www.wikidata.org/wiki/Q431667","display_name":"Automated theorem proving","level":2,"score":0.6717109680175781},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6386401057243347},{"id":"https://openalex.org/C203265346","wikidata":"https://www.wikidata.org/wiki/Q11387554","display_name":"Proof assistant","level":3,"score":0.48419883847236633},{"id":"https://openalex.org/C159718280","wikidata":"https://www.wikidata.org/wiki/Q5526353","display_name":"Gas meter prover","level":3,"score":0.44796445965766907},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.347215861082077},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.1205369234085083},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.097251296043396},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1017/s0956796803004921","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796803004921","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/C968F39F6E1649C722A4572FAB862F0C/S0956796803004921a.pdf/div-class-title-dependent-types-ensure-partial-correctness-of-theorem-provers-div.pdf","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"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.12.343","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.12.343","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.princeton.edu/~appel/papers/prover/prover.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.697.1602","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.697.1602","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.site.uottawa.ca/%7Eafelty/dist/jfp04.pdf","raw_type":"text"}],"best_oa_location":{"id":"doi:10.1017/s0956796803004921","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796803004921","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/C968F39F6E1649C722A4572FAB862F0C/S0956796803004921a.pdf/div-class-title-dependent-types-ensure-partial-correctness-of-theorem-provers-div.pdf","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"},"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/16","score":0.7200000286102295,"display_name":"Peace, Justice and strong institutions"}],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2000778709.pdf","grobid_xml":"https://content.openalex.org/works/W2000778709.grobid-xml"},"referenced_works_count":13,"referenced_works":["https://openalex.org/W1498523273","https://openalex.org/W1521083034","https://openalex.org/W1544097164","https://openalex.org/W1560253649","https://openalex.org/W1564350387","https://openalex.org/W1586167239","https://openalex.org/W1655990431","https://openalex.org/W1727609483","https://openalex.org/W1974190112","https://openalex.org/W1986121459","https://openalex.org/W2076819871","https://openalex.org/W2153297607","https://openalex.org/W2163664272"],"related_works":["https://openalex.org/W2387885153","https://openalex.org/W2797950816","https://openalex.org/W2001092196","https://openalex.org/W2160343832","https://openalex.org/W1538072621","https://openalex.org/W2003315346","https://openalex.org/W1636183340","https://openalex.org/W2626224273","https://openalex.org/W2461166840","https://openalex.org/W1997440650"],"abstract_inverted_index":{"Static":[0],"type":[1,29],"systems":[2,30],"in":[3,31,60,83],"programming":[4,33,63],"languages":[5,36],"allow":[6,41],"many":[7],"errors":[8,46,82],"to":[9,43,68],"be":[10,17,66],"detected":[11,18],"at":[12],"compile":[13],"time":[14],"that":[15,37,57],"wouldn't":[16],"until":[19],"runtime":[20,81],"otherwise.":[21],"Dependent":[22],"types":[23,59],"are":[24],"more":[25,45],"expressive":[26],"than":[27],"the":[28,52,61],"most":[32],"languages,":[34],"so":[35],"have":[38],"them":[39],"should":[40],"programmers":[42],"detect":[44],"earlier.":[47],"In":[48],"this":[49],"paper,":[50],"using":[51],"Twelf":[53],"system,":[54],"we":[55],"show":[56],"dependent":[58],"logic":[62],"setting":[64],"can":[65],"used":[67],"ensure":[69],"partial":[70],"correctness":[71],"of":[72],"programs":[73],"which":[74],"implement":[75],"theorem":[76,96],"provers,":[77],"and":[78,86,98],"thus":[79],"avoid":[80],"proof":[84,87],"search":[85],"construction.":[88],"We":[89],"present":[90],"two":[91],"examples:":[92],"a":[93,99],"tactic-style":[94],"interactive":[95],"prover":[97],"union-find":[100],"decision":[101],"procedure.":[102]},"counts_by_year":[{"year":2015,"cited_by_count":2},{"year":2014,"cited_by_count":2},{"year":2013,"cited_by_count":1}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
