{"bundle_type":"pith_open_graph_bundle","bundle_version":"1.0","pith_number":"pith:2014:BWJ2MFTTYDV6OV4HARY5P7MUY3","short_pith_number":"pith:BWJ2MFTT","canonical_record":{"source":{"id":"1407.4378","kind":"arxiv","version":1},"metadata":{"license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","primary_cat":"cs.PL","submitted_at":"2014-07-15T03:13:00Z","cross_cats_sorted":["q-bio.QM"],"title_canon_sha256":"8e6c528c5b82c04687c2be5c864e07404aed449c4f9b79c32fa76a521db99550","abstract_canon_sha256":"a4ecce8013832082cb1d88191a0c2eebcc3d904303e3d6d9467cddf3dfce2275"},"schema_version":"1.0"},"canonical_sha256":"0d93a61673c0ebe757870471d7fd94c6d00af8be7a5da832cde95bf346600842","source":{"kind":"arxiv","id":"1407.4378","version":1},"source_aliases":[{"alias_kind":"arxiv","alias_value":"1407.4378","created_at":"2026-05-18T02:47:30Z"},{"alias_kind":"arxiv_version","alias_value":"1407.4378v1","created_at":"2026-05-18T02:47:30Z"},{"alias_kind":"doi","alias_value":"10.48550/arxiv.1407.4378","created_at":"2026-05-18T02:47:30Z"},{"alias_kind":"pith_short_12","alias_value":"BWJ2MFTTYDV6","created_at":"2026-05-18T12:28:22Z"},{"alias_kind":"pith_short_16","alias_value":"BWJ2MFTTYDV6OV4H","created_at":"2026-05-18T12:28:22Z"},{"alias_kind":"pith_short_8","alias_value":"BWJ2MFTT","created_at":"2026-05-18T12:28:22Z"}],"events":[{"event_type":"record_created","subject_pith_number":"pith:2014:BWJ2MFTTYDV6OV4HARY5P7MUY3","target":"record","payload":{"canonical_record":{"source":{"id":"1407.4378","kind":"arxiv","version":1},"metadata":{"license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","primary_cat":"cs.PL","submitted_at":"2014-07-15T03:13:00Z","cross_cats_sorted":["q-bio.QM"],"title_canon_sha256":"8e6c528c5b82c04687c2be5c864e07404aed449c4f9b79c32fa76a521db99550","abstract_canon_sha256":"a4ecce8013832082cb1d88191a0c2eebcc3d904303e3d6d9467cddf3dfce2275"},"schema_version":"1.0"},"canonical_sha256":"0d93a61673c0ebe757870471d7fd94c6d00af8be7a5da832cde95bf346600842","receipt":{"kind":"pith_receipt","key_id":"pith-v1-2026-05","algorithm":"ed25519","signed_at":"2026-05-18T02:47:30.573290Z","signature_b64":"fCRmAoJiqpD98upbxxqNfzGtMgokZ5tCv3DKCL2R+GAksYRWvBjxU7mMwHSVf6yeEb2e8m3nxS2FHkSY3qp3Dg==","signed_message":"canonical_sha256_bytes","builder_version":"pith-number-builder-2026-05-17-v1","receipt_version":"0.3","canonical_sha256":"0d93a61673c0ebe757870471d7fd94c6d00af8be7a5da832cde95bf346600842","last_reissued_at":"2026-05-18T02:47:30.572922Z","signature_status":"signed_v1","first_computed_at":"2026-05-18T02:47:30.572922Z","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"source_kind":"arxiv","source_id":"1407.4378","source_version":1,"attestation_state":"computed"},"signer":{"signer_id":"pith.science","signer_type":"pith_registry","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"created_at":"2026-05-18T02:47:30Z","supersedes":[],"prev_event":null,"signature":{"signature_status":"signed_v1","algorithm":"ed25519","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signature_b64":"fYnNnT117CqtJLyIi9VhrQGf0/NI87xBTm1+py29z2cvNZ/69wDbiaGu38Y3ws9atA1oPHv51fkOxe6GBwqiBQ==","signed_message":"open_graph_event_sha256_bytes","signed_at":"2026-06-21T22:27:58.924999Z"},"content_sha256":"94c49701d135528626cc6a8c1602c34f4ca52902fea75d504e562e378453c362","schema_version":"1.0","event_id":"sha256:94c49701d135528626cc6a8c1602c34f4ca52902fea75d504e562e378453c362"},{"event_type":"graph_snapshot","subject_pith_number":"pith:2014:BWJ2MFTTYDV6OV4HARY5P7MUY3","target":"graph","payload":{"graph_snapshot":{"paper":{"title":"PaPy: Parallel and Distributed Data-processing Pipelines in Python","license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","headline":"","cross_cats":["q-bio.QM"],"primary_cat":"cs.PL","authors_text":"Cameron Mura, Marcin Cieslik","submitted_at":"2014-07-15T03:13:00Z","abstract_excerpt":"PaPy, which stands for parallel pipelines in Python, is a highly flexible framework that enables the construction of robust, scalable workflows for either generating or processing voluminous datasets. A workflow is created from user-written Python functions (nodes) connected by 'pipes' (edges) into a directed acyclic graph. These functions are arbitrarily definable, and can make use of any Python modules or external binaries. Given a user-defined topology and collection of input data, functions are composed into nested higher-order maps, which are transparently and robustly evaluated in parall"},"claims":{"count":0,"items":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"source":{"id":"1407.4378","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"},"verdict_id":null},"signer":{"signer_id":"pith.science","signer_type":"pith_registry","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"created_at":"2026-05-18T02:47:30Z","supersedes":[],"prev_event":null,"signature":{"signature_status":"signed_v1","algorithm":"ed25519","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signature_b64":"jJO61nvtOmmC8WjPACDkhMNKNnLw73dHunp+RUsBeqR45afrNZZw1reo493cCGj+CHojYLlhKfJn9wYe1i8bBw==","signed_message":"open_graph_event_sha256_bytes","signed_at":"2026-06-21T22:27:58.925352Z"},"content_sha256":"fb1fcbb6f354de595e055dc0763a5d0fc554c986736adb6023874a2311378e15","schema_version":"1.0","event_id":"sha256:fb1fcbb6f354de595e055dc0763a5d0fc554c986736adb6023874a2311378e15"}],"timestamp_proofs":[],"mirror_hints":[{"mirror_type":"https","name":"Pith Resolver","base_url":"https://pith.science","bundle_url":"https://pith.science/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3/bundle.json","state_url":"https://pith.science/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3/state.json","well_known_bundle_url":"https://pith.science/.well-known/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3/bundle.json","status":"primary"}],"public_keys":[{"key_id":"pith-v1-2026-05","algorithm":"ed25519","format":"raw","public_key_b64":"stVStoiQhXFxp4s2pdzPNoqVNBMojDU/fJ2db5S3CbM=","public_key_hex":"b2d552b68890857171a78b36a5dccf368a953413288c353f7c9d9d6f94b709b3","fingerprint_sha256_b32_first128bits":"RVFV5Z2OI2J3ZUO7ERDEBCYNKS","fingerprint_sha256_hex":"8d4b5ee74e4693bcd1df2446408b0d54","rotates_at":null,"url":"https://pith.science/pith-signing-key.json","notes":"Pith uses this Ed25519 key to sign canonical record SHA-256 digests. Verify with: ed25519_verify(public_key, message=canonical_sha256_bytes, signature=base64decode(signature_b64))."}],"merge_version":"pith-open-graph-merge-v1","built_at":"2026-06-21T22:27:58Z","links":{"resolver":"https://pith.science/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3","bundle":"https://pith.science/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3/bundle.json","state":"https://pith.science/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3/state.json","well_known_bundle":"https://pith.science/.well-known/pith/BWJ2MFTTYDV6OV4HARY5P7MUY3/bundle.json"},"state":{"state_type":"pith_open_graph_state","state_version":"1.0","pith_number":"pith:2014:BWJ2MFTTYDV6OV4HARY5P7MUY3","merge_version":"pith-open-graph-merge-v1","event_count":2,"valid_event_count":2,"invalid_event_count":0,"equivocation_count":0,"current":{"canonical_record":{"metadata":{"abstract_canon_sha256":"a4ecce8013832082cb1d88191a0c2eebcc3d904303e3d6d9467cddf3dfce2275","cross_cats_sorted":["q-bio.QM"],"license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","primary_cat":"cs.PL","submitted_at":"2014-07-15T03:13:00Z","title_canon_sha256":"8e6c528c5b82c04687c2be5c864e07404aed449c4f9b79c32fa76a521db99550"},"schema_version":"1.0","source":{"id":"1407.4378","kind":"arxiv","version":1}},"source_aliases":[{"alias_kind":"arxiv","alias_value":"1407.4378","created_at":"2026-05-18T02:47:30Z"},{"alias_kind":"arxiv_version","alias_value":"1407.4378v1","created_at":"2026-05-18T02:47:30Z"},{"alias_kind":"doi","alias_value":"10.48550/arxiv.1407.4378","created_at":"2026-05-18T02:47:30Z"},{"alias_kind":"pith_short_12","alias_value":"BWJ2MFTTYDV6","created_at":"2026-05-18T12:28:22Z"},{"alias_kind":"pith_short_16","alias_value":"BWJ2MFTTYDV6OV4H","created_at":"2026-05-18T12:28:22Z"},{"alias_kind":"pith_short_8","alias_value":"BWJ2MFTT","created_at":"2026-05-18T12:28:22Z"}],"graph_snapshots":[{"event_id":"sha256:fb1fcbb6f354de595e055dc0763a5d0fc554c986736adb6023874a2311378e15","target":"graph","created_at":"2026-05-18T02:47:30Z","signer":{"key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signer_id":"pith.science","signer_type":"pith_registry"},"payload":{"graph_snapshot":{"author_claims":{"count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57","strong_count":0},"builder_version":"pith-number-builder-2026-05-17-v1","claims":{"count":0,"items":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"formal_canon":{"evidence_count":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"paper":{"abstract_excerpt":"PaPy, which stands for parallel pipelines in Python, is a highly flexible framework that enables the construction of robust, scalable workflows for either generating or processing voluminous datasets. A workflow is created from user-written Python functions (nodes) connected by 'pipes' (edges) into a directed acyclic graph. These functions are arbitrarily definable, and can make use of any Python modules or external binaries. Given a user-defined topology and collection of input data, functions are composed into nested higher-order maps, which are transparently and robustly evaluated in parall","authors_text":"Cameron Mura, Marcin Cieslik","cross_cats":["q-bio.QM"],"headline":"","license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","primary_cat":"cs.PL","submitted_at":"2014-07-15T03:13:00Z","title":"PaPy: Parallel and Distributed Data-processing Pipelines in Python"},"references":{"count":0,"internal_anchors":0,"resolved_work":0,"sample":[],"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57"},"source":{"id":"1407.4378","kind":"arxiv","version":1},"verdict":{"created_at":null,"id":null,"model_set":{},"one_line_summary":"","pipeline_version":null,"pith_extraction_headline":"","strongest_claim":"","weakest_assumption":""}},"verdict_id":null}}],"author_attestations":[],"timestamp_anchors":[],"storage_attestations":[],"citation_signatures":[],"replication_records":[],"corrections":[],"mirror_hints":[],"record_created":{"event_id":"sha256:94c49701d135528626cc6a8c1602c34f4ca52902fea75d504e562e378453c362","target":"record","created_at":"2026-05-18T02:47:30Z","signer":{"key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signer_id":"pith.science","signer_type":"pith_registry"},"payload":{"attestation_state":"computed","canonical_record":{"metadata":{"abstract_canon_sha256":"a4ecce8013832082cb1d88191a0c2eebcc3d904303e3d6d9467cddf3dfce2275","cross_cats_sorted":["q-bio.QM"],"license":"http://arxiv.org/licenses/nonexclusive-distrib/1.0/","primary_cat":"cs.PL","submitted_at":"2014-07-15T03:13:00Z","title_canon_sha256":"8e6c528c5b82c04687c2be5c864e07404aed449c4f9b79c32fa76a521db99550"},"schema_version":"1.0","source":{"id":"1407.4378","kind":"arxiv","version":1}},"canonical_sha256":"0d93a61673c0ebe757870471d7fd94c6d00af8be7a5da832cde95bf346600842","receipt":{"algorithm":"ed25519","builder_version":"pith-number-builder-2026-05-17-v1","canonical_sha256":"0d93a61673c0ebe757870471d7fd94c6d00af8be7a5da832cde95bf346600842","first_computed_at":"2026-05-18T02:47:30.572922Z","key_id":"pith-v1-2026-05","kind":"pith_receipt","last_reissued_at":"2026-05-18T02:47:30.572922Z","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","receipt_version":"0.3","signature_b64":"fCRmAoJiqpD98upbxxqNfzGtMgokZ5tCv3DKCL2R+GAksYRWvBjxU7mMwHSVf6yeEb2e8m3nxS2FHkSY3qp3Dg==","signature_status":"signed_v1","signed_at":"2026-05-18T02:47:30.573290Z","signed_message":"canonical_sha256_bytes"},"source_id":"1407.4378","source_kind":"arxiv","source_version":1}}},"equivocations":[],"invalid_events":[],"applied_event_ids":["sha256:94c49701d135528626cc6a8c1602c34f4ca52902fea75d504e562e378453c362","sha256:fb1fcbb6f354de595e055dc0763a5d0fc554c986736adb6023874a2311378e15"],"state_sha256":"ba9b162b2aab5c3f20f88b4b352f3785342d810124ef16cb2419decb307c8dd8"},"bundle_signature":{"signature_status":"signed_v1","algorithm":"ed25519","key_id":"pith-v1-2026-05","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54","signature_b64":"ri3mvTbT/gp0d0x9u6Av735BsRwsjihUmyT1cBZt1qnJTwas8VKRpDk0nxdFQNhyAzdq2PrGNTZ8M56WSAbJAQ==","signed_message":"bundle_sha256_bytes","signed_at":"2026-06-21T22:27:58.927268Z","bundle_sha256":"da9db2c55e0c15e93ec5a95424db9c34cd88a554116bd2ab30fcb831ee4d0533"}}