{"record_type":"pith_number_record","schema_url":"https://pith.science/schemas/pith-number/v1.json","pith_number":"pith:2018:INIZ36AS3KE57XJAC3HW4ACZNO","short_pith_number":"pith:INIZ36AS","schema_version":"1.0","canonical_sha256":"43519df812da89dfdd2016cf6e00596b8809006a847ec27eabc84c8ba1a786e2","source":{"kind":"arxiv","id":"1808.05789","version":1},"attestation_state":"computed","paper":{"title":"Proving Type Class Laws for Haskell","license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","headline":"","cross_cats":[],"primary_cat":"cs.PL","authors_text":"Andreas Arvidsson, Moa Johansson, Robin Touche","submitted_at":"2018-08-17T08:19:37Z","abstract_excerpt":"Type classes in Haskell are used to implement ad-hoc polymorphism, i.e. a way to ensure both to the programmer and the compiler that a set of functions are defined for a specific data type. All instances of such type classes are expected to behave in a certain way and satisfy laws associated with the respective class. These are however typically just stated in comments and as such, there is no real way to enforce that they hold. In this paper we describe a system which allows the user to write down type class laws which are then automatically instantiated and sent to an inductive theorem prove"},"verification_status":{"content_addressed":true,"pith_receipt":true,"author_attested":false,"weak_author_claims":0,"strong_author_claims":0,"externally_anchored":false,"storage_verified":false,"citation_signatures":0,"replication_records":0,"graph_snapshot":true,"references_resolved":false,"formal_links_present":false},"canonical_record":{"source":{"id":"1808.05789","kind":"arxiv","version":1},"metadata":{"license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","primary_cat":"cs.PL","submitted_at":"2018-08-17T08:19:37Z","cross_cats_sorted":[],"title_canon_sha256":"cb69fedc8bfbd9b784aba4013faa5228227b2a41396e7e838661a8ab8fbd35a4","abstract_canon_sha256":"d67beeeab57ed37d609c2422ed0f020467545010f0cf3da09934fa517b2b032a"},"schema_version":"1.0"},"receipt":{"kind":"pith_receipt","key_id":"pith-v1-2026-05","algorithm":"ed25519","signed_at":"2026-05-18T00:07:52.128551Z","signature_b64":"96jUS89dbcy0rnOkckCurLQOvHTbnQjHyz+zs7VexdHVbSESIQIMDcx9RNj3z5HCEp1cavWn+WFiLPicGJcyCA==","signed_message":"canonical_sha256_bytes","builder_version":"pith-number-builder-2026-05-17-v1","receipt_version":"0.3","canonical_sha256":"43519df812da89dfdd2016cf6e00596b8809006a847ec27eabc84c8ba1a786e2","last_reissued_at":"2026-05-18T00:07:52.127831Z","signature_status":"signed_v1","first_computed_at":"2026-05-18T00:07:52.127831Z","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"graph_snapshot":{"paper":{"title":"Proving Type Class Laws for Haskell","license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","headline":"","cross_cats":[],"primary_cat":"cs.PL","authors_text":"Andreas Arvidsson, Moa Johansson, Robin Touche","submitted_at":"2018-08-17T08:19:37Z","abstract_excerpt":"Type classes in Haskell are used to implement ad-hoc polymorphism, i.e. a way to ensure both to the programmer and the compiler that a set of functions are defined for a specific data type. All instances of such type classes are expected to behave in a certain way and satisfy laws associated with the respective class. These are however typically just stated in comments and as such, there is no real way to enforce that they hold. In this paper we describe a system which allows the user to write down type class laws which are then automatically instantiated and sent to an inductive theorem prove"},"claims":{"count":0,"items":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"source":{"id":"1808.05789","kind":"arxiv","version":1},"verdict":{"id":null,"model_set":{},"created_at":null,"strongest_claim":"","one_line_summary":"","pipeline_version":null,"weakest_assumption":"","pith_extraction_headline":""},"references":{"count":0,"sample":[],"resolved_work":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57","internal_anchors":0},"formal_canon":{"evidence_count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"author_claims":{"count":0,"strong_count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"builder_version":"pith-number-builder-2026-05-17-v1"},"aliases":[{"alias_kind":"arxiv","alias_value":"1808.05789","created_at":"2026-05-18T00:07:52.127958+00:00"},{"alias_kind":"arxiv_version","alias_value":"1808.05789v1","created_at":"2026-05-18T00:07:52.127958+00:00"},{"alias_kind":"doi","alias_value":"10.48550/arxiv.1808.05789","created_at":"2026-05-18T00:07:52.127958+00:00"},{"alias_kind":"pith_short_12","alias_value":"INIZ36AS3KE5","created_at":"2026-05-18T12:32:31.084164+00:00"},{"alias_kind":"pith_short_16","alias_value":"INIZ36AS3KE57XJA","created_at":"2026-05-18T12:32:31.084164+00:00"},{"alias_kind":"pith_short_8","alias_value":"INIZ36AS","created_at":"2026-05-18T12:32:31.084164+00:00"}],"events":[],"event_summary":{},"paper_claims":[],"inbound_citations":{"count":0,"internal_anchor_count":0,"sample":[]},"formal_canon":{"evidence_count":0,"sample":[],"anchors":[]},"links":{"html":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO","json":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO.json","graph_json":"https://pith.science/api/pith-number/INIZ36AS3KE57XJAC3HW4ACZNO/graph.json","events_json":"https://pith.science/api/pith-number/INIZ36AS3KE57XJAC3HW4ACZNO/events.json","paper":"https://pith.science/paper/INIZ36AS"},"agent_actions":{"view_html":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO","download_json":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO.json","view_paper":"https://pith.science/paper/INIZ36AS","resolve_alias":"https://pith.science/api/pith-number/resolve?arxiv=1808.05789&json=true","fetch_graph":"https://pith.science/api/pith-number/INIZ36AS3KE57XJAC3HW4ACZNO/graph.json","fetch_events":"https://pith.science/api/pith-number/INIZ36AS3KE57XJAC3HW4ACZNO/events.json","actions":{"anchor_timestamp":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO/action/timestamp_anchor","attest_storage":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO/action/storage_attestation","attest_author":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO/action/author_attestation","sign_citation":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO/action/citation_signature","submit_replication":"https://pith.science/pith/INIZ36AS3KE57XJAC3HW4ACZNO/action/replication_record"}},"created_at":"2026-05-18T00:07:52.127958+00:00","updated_at":"2026-05-18T00:07:52.127958+00:00"}