{"id":"https://openalex.org/W2613262409","doi":"https://doi.org/10.29007/cfdq","title":"Functional Pearl: the Proof Search Monad","display_name":"Functional Pearl: the Proof Search Monad","publication_year":2018,"publication_date":"2018-01-23","ids":{"openalex":"https://openalex.org/W2613262409","doi":"https://doi.org/10.29007/cfdq","mag":"2613262409"},"language":"en","primary_location":{"id":"doi:10.29007/cfdq","is_oa":true,"landing_page_url":"https://doi.org/10.29007/cfdq","pdf_url":"https://easychair.org/publications/open/HzFg","source":{"id":"https://openalex.org/S4220651395","display_name":"EPiC series in computing","issn_l":"2398-7340","issn":["2398-7340"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"EPiC Series in Computing","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://easychair.org/publications/open/HzFg","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5055019834","display_name":"Jonathan Protzenko","orcid":"https://orcid.org/0000-0001-7347-3050"},"institutions":[{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB"],"is_corresponding":true,"raw_author_name":"Jonathan Protzenko","raw_affiliation_strings":["Microsoft Research"],"affiliations":[{"raw_affiliation_string":"Microsoft Research","institution_ids":["https://openalex.org/I4210164937"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5055019834"],"corresponding_institution_ids":["https://openalex.org/I4210164937"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.00453748,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"40","issue":null,"first_page":"91","last_page":"75"},"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.9997000098228455,"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.9997000098228455,"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/T13523","display_name":"Mathematics, Computing, and Information Processing","score":0.987500011920929,"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"}},{"id":"https://openalex.org/T10317","display_name":"Advanced Database Systems and Queries","score":0.986299991607666,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/monad","display_name":"Monad (category theory)","score":0.8470491170883179},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7484842538833618},{"id":"https://openalex.org/keywords/premise","display_name":"Premise","score":0.7191507816314697},{"id":"https://openalex.org/keywords/pearl","display_name":"Pearl","score":0.6888307332992554},{"id":"https://openalex.org/keywords/proof-assistant","display_name":"Proof assistant","score":0.6138579249382019},{"id":"https://openalex.org/keywords/combinatory-logic","display_name":"Combinatory logic","score":0.5779145956039429},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.5204244256019592},{"id":"https://openalex.org/keywords/tree","display_name":"Tree (set theory)","score":0.4807007908821106},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.47661104798316956},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.47427210211753845},{"id":"https://openalex.org/keywords/proof-of-concept","display_name":"Proof of concept","score":0.4397936463356018},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3857020437717438},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.25092604756355286},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.21586266160011292},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.2143000066280365},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.1383475959300995},{"id":"https://openalex.org/keywords/combinatorics","display_name":"Combinatorics","score":0.07556372880935669}],"concepts":[{"id":"https://openalex.org/C33959348","wikidata":"https://www.wikidata.org/wiki/Q1630568","display_name":"Monad (category theory)","level":3,"score":0.8470491170883179},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7484842538833618},{"id":"https://openalex.org/C2778023277","wikidata":"https://www.wikidata.org/wiki/Q321703","display_name":"Premise","level":2,"score":0.7191507816314697},{"id":"https://openalex.org/C2779251273","wikidata":"https://www.wikidata.org/wiki/Q43436","display_name":"Pearl","level":2,"score":0.6888307332992554},{"id":"https://openalex.org/C203265346","wikidata":"https://www.wikidata.org/wiki/Q11387554","display_name":"Proof assistant","level":3,"score":0.6138579249382019},{"id":"https://openalex.org/C79678938","wikidata":"https://www.wikidata.org/wiki/Q1481571","display_name":"Combinatory logic","level":2,"score":0.5779145956039429},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.5204244256019592},{"id":"https://openalex.org/C113174947","wikidata":"https://www.wikidata.org/wiki/Q2859736","display_name":"Tree (set theory)","level":2,"score":0.4807007908821106},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.47661104798316956},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.47427210211753845},{"id":"https://openalex.org/C124978682","wikidata":"https://www.wikidata.org/wiki/Q1201019","display_name":"Proof of concept","level":2,"score":0.4397936463356018},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3857020437717438},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.25092604756355286},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.21586266160011292},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.2143000066280365},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.1383475959300995},{"id":"https://openalex.org/C114614502","wikidata":"https://www.wikidata.org/wiki/Q76592","display_name":"Combinatorics","level":1,"score":0.07556372880935669},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C27206212","wikidata":"https://www.wikidata.org/wiki/Q34178","display_name":"Theology","level":1,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C156772000","wikidata":"https://www.wikidata.org/wiki/Q864475","display_name":"Functor","level":2,"score":0.0},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.0},{"id":"https://openalex.org/C41895202","wikidata":"https://www.wikidata.org/wiki/Q8162","display_name":"Linguistics","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.29007/cfdq","is_oa":true,"landing_page_url":"https://doi.org/10.29007/cfdq","pdf_url":"https://easychair.org/publications/open/HzFg","source":{"id":"https://openalex.org/S4220651395","display_name":"EPiC series in computing","issn_l":"2398-7340","issn":["2398-7340"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"EPiC Series in Computing","raw_type":"proceedings-article"}],"best_oa_location":{"id":"doi:10.29007/cfdq","is_oa":true,"landing_page_url":"https://doi.org/10.29007/cfdq","pdf_url":"https://easychair.org/publications/open/HzFg","source":{"id":"https://openalex.org/S4220651395","display_name":"EPiC series in computing","issn_l":"2398-7340","issn":["2398-7340"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"EPiC Series in Computing","raw_type":"proceedings-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2613262409.pdf","grobid_xml":"https://content.openalex.org/works/W2613262409.grobid-xml"},"referenced_works_count":17,"referenced_works":["https://openalex.org/W833263066","https://openalex.org/W1492124994","https://openalex.org/W1507039213","https://openalex.org/W1643700551","https://openalex.org/W1970782371","https://openalex.org/W1985818808","https://openalex.org/W1986022261","https://openalex.org/W2037984920","https://openalex.org/W2039430744","https://openalex.org/W2074233181","https://openalex.org/W2138051462","https://openalex.org/W2160230109","https://openalex.org/W2277214925","https://openalex.org/W2295914203","https://openalex.org/W2752885492","https://openalex.org/W4239999910","https://openalex.org/W4246219036"],"related_works":["https://openalex.org/W2063393078","https://openalex.org/W2754859507","https://openalex.org/W1911419940","https://openalex.org/W2741344200","https://openalex.org/W1556401754","https://openalex.org/W2373472360","https://openalex.org/W2319624920","https://openalex.org/W2155480936","https://openalex.org/W2965966430","https://openalex.org/W2913635267"],"abstract_inverted_index":{"We":[0],"present":[1],"the":[2,24,38,61,64],"proof":[3,16,73],"search":[4,17,49],"monad,":[5],"a":[6,15,20,45,57,79],"set":[7],"of":[8,43],"combinators":[9],"that":[10,22],"allows":[11],"one":[12],"to":[13],"write":[14],"engine":[18],"in":[19,52],"style":[21,54],"resembles":[23],"formal":[25],"rules":[26],"closely.":[27],"The":[28],"user":[29],"calls":[30],"functions":[31],"such":[32],"as":[33],"premise,":[34],"prove":[35],"or":[36],"choice;":[37],"library":[39],"then":[40],"takes":[41],"care":[42],"generating":[44],"derivation":[46,65],"tree.":[47],"Proof":[48],"engines":[50],"written":[51],"this":[53],"enjoy:":[55],"first,":[56],"one-to-one":[58],"correspondence":[59],"between":[60],"implementation":[62],"and":[63],"rules,":[66],"which":[67,77],"makes":[68,78],"manual":[69],"inspection":[70],"easier;":[71],"second,":[72],"witnesses":[74],"\u201cfor":[75],"free\u201d,":[76],"verified,":[80],"independent":[81],"validation":[82],"approach":[83],"easier":[84],"too.":[85]},"counts_by_year":[],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
