{"record_type":"pith_number_record","schema_url":"https://pith.science/schemas/pith-number/v1.json","pith_number":"pith:2026:3LCNAPOENBX2YNEWXJF4KDAFAP","short_pith_number":"pith:3LCNAPOE","schema_version":"1.0","canonical_sha256":"dac4d03dc4686fac3496ba4bc50c0503dc0bc093f2536a053a579773f2e910bb","source":{"kind":"arxiv","id":"2605.08731","version":2},"attestation_state":"computed","paper":{"title":"Single-Thread JPEG Decoder Benchmarks Mis-Evaluate ML Data Loaders","license":"http://creativecommons.org/licenses/by/4.0/","headline":"Single-thread JPEG decoder benchmarks produce different rankings than measurements inside PyTorch DataLoaders.","cross_cats":["cs.LG"],"primary_cat":"cs.PF","authors_text":"Dmitry Kosarevsky, Vladimir Iglovikov","submitted_at":"2026-05-09T06:34:17Z","abstract_excerpt":"JPEG decode is routine ML infrastructure, but Python decoder choices are often justified by single-process, single-thread microbenchmarks. We audit this evaluation assumption with thirteen Python-accessible JPEG decode paths on five matched 16 vCPU Google Cloud CPUs: Intel Emerald Rapids, AMD Zen 4, AMD Zen 5, ARM Neoverse V2, and ARM Neoverse N1. ImageNet validation is the workload, not a new dataset contribution: each run decodes the full 50,000-image split from memory and reports single-thread throughput for all decoders, PyTorch \\texttt{DataLoader} throughput for eligible decoders at worke"},"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":true},"canonical_record":{"source":{"id":"2605.08731","kind":"arxiv","version":2},"metadata":{"license":"http://creativecommons.org/licenses/by/4.0/","primary_cat":"cs.PF","submitted_at":"2026-05-09T06:34:17Z","cross_cats_sorted":["cs.LG"],"title_canon_sha256":"3964a7ee2c6aac594c3bdb69c1cba526b53084cdf6ed055a8076b4bc281afc9f","abstract_canon_sha256":"cfcc0c5c828564c5913b69324cbb27b3a75362b5faba1f62c407c82cc0ddcb28"},"schema_version":"1.0"},"receipt":{"kind":"pith_receipt","key_id":"pith-v1-2026-05","algorithm":"ed25519","signed_at":"2026-05-21T01:05:20.667344Z","signature_b64":"mYH7bsel0DP/YE0hz1TIJ4HFMPEfmN5MY0KeSSZfXchAYnOuCnLOh62QJynRKY1R3WURwrWEFqNTI7o0X4e8Dw==","signed_message":"canonical_sha256_bytes","builder_version":"pith-number-builder-2026-05-17-v1","receipt_version":"0.3","canonical_sha256":"dac4d03dc4686fac3496ba4bc50c0503dc0bc093f2536a053a579773f2e910bb","last_reissued_at":"2026-05-21T01:05:20.666655Z","signature_status":"signed_v1","first_computed_at":"2026-05-21T01:05:20.666655Z","public_key_fingerprint":"8d4b5ee74e4693bcd1df2446408b0d54"},"graph_snapshot":{"paper":{"title":"Single-Thread JPEG Decoder Benchmarks Mis-Evaluate ML Data Loaders","license":"http://creativecommons.org/licenses/by/4.0/","headline":"Single-thread JPEG decoder benchmarks produce different rankings than measurements inside PyTorch DataLoaders.","cross_cats":["cs.LG"],"primary_cat":"cs.PF","authors_text":"Dmitry Kosarevsky, Vladimir Iglovikov","submitted_at":"2026-05-09T06:34:17Z","abstract_excerpt":"JPEG decode is routine ML infrastructure, but Python decoder choices are often justified by single-process, single-thread microbenchmarks. We audit this evaluation assumption with thirteen Python-accessible JPEG decode paths on five matched 16 vCPU Google Cloud CPUs: Intel Emerald Rapids, AMD Zen 4, AMD Zen 5, ARM Neoverse V2, and ARM Neoverse N1. ImageNet validation is the workload, not a new dataset contribution: each run decodes the full 50,000-image split from memory and reports single-thread throughput for all decoders, PyTorch \\texttt{DataLoader} throughput for eligible decoders at worke"},"claims":{"count":4,"items":[{"kind":"strongest_claim","text":"The evaluation protocol changes the supported conclusion. On Neoverse V2, imageio is ninth in single-thread throughput yet lands in the top DataLoader tier with torchvision; on Zen 4, torchvision rises from seventh single-thread to the top measured DataLoader tier.","source":"verdict.strongest_claim","status":"machine_extracted","claim_id":"C1","attestation":"unclaimed"},{"kind":"weakest_assumption","text":"That the observed ranking changes are driven primarily by the single-thread versus multi-worker protocol rather than by unmeasured interactions between specific decoder implementations, memory hierarchy, or the exact PyTorch DataLoader configuration used.","source":"verdict.weakest_assumption","status":"machine_extracted","claim_id":"C2","attestation":"unclaimed"},{"kind":"one_line_summary","text":"Single-thread JPEG decoder throughput rankings change substantially when measured inside PyTorch DataLoaders across Intel, AMD, and ARM CPUs.","source":"verdict.one_line_summary","status":"machine_extracted","claim_id":"C3","attestation":"unclaimed"},{"kind":"headline","text":"Single-thread JPEG decoder benchmarks produce different rankings than measurements inside PyTorch DataLoaders.","source":"verdict.pith_extraction.headline","status":"machine_extracted","claim_id":"C4","attestation":"unclaimed"}],"snapshot_sha256":"b52859a58679c17dc0d4dee032ce754f2c1531ee1d2e88c096935baee933baf7"},"source":{"id":"2605.08731","kind":"arxiv","version":2},"verdict":{"id":"abe77f03-fcaf-4219-b308-99934f992203","model_set":{"reader":"grok-4.3"},"created_at":"2026-05-12T01:59:52.120853Z","strongest_claim":"The evaluation protocol changes the supported conclusion. On Neoverse V2, imageio is ninth in single-thread throughput yet lands in the top DataLoader tier with torchvision; on Zen 4, torchvision rises from seventh single-thread to the top measured DataLoader tier.","one_line_summary":"Single-thread JPEG decoder throughput rankings change substantially when measured inside PyTorch DataLoaders across Intel, AMD, and ARM CPUs.","pipeline_version":"pith-pipeline@v0.9.0","weakest_assumption":"That the observed ranking changes are driven primarily by the single-thread versus multi-worker protocol rather than by unmeasured interactions between specific decoder implementations, memory hierarchy, or the exact PyTorch DataLoader configuration used.","pith_extraction_headline":"Single-thread JPEG decoder benchmarks produce different rankings than measurements inside PyTorch DataLoaders."},"integrity":{"clean":true,"summary":{"advisory":0,"critical":0,"by_detector":{},"informational":0},"endpoint":"/pith/2605.08731/integrity.json","findings":[],"available":true,"detectors_run":[{"name":"claim_evidence","ran_at":"2026-05-20T09:02:01.945030Z","status":"completed","version":"1.0.0","findings_count":0},{"name":"ai_meta_artifact","ran_at":"2026-05-19T22:35:37.390352Z","status":"completed","version":"1.0.0","findings_count":0},{"name":"doi_title_agreement","ran_at":"2026-05-19T14:31:17.599067Z","status":"completed","version":"1.0.0","findings_count":0},{"name":"doi_compliance","ran_at":"2026-05-19T10:50:49.259097Z","status":"completed","version":"1.0.0","findings_count":0}],"snapshot_sha256":"e09e2dd8adbba46ebd750c01ede7c4f50e02ff06ad2f9cc0907317db7f6e3841"},"references":{"count":0,"sample":[],"resolved_work":0,"snapshot_sha256":"258153158e38e3291e3d48162225fcdb2d5a3ed65a07baac614ab91432fd4f57","internal_anchors":0},"formal_canon":{"evidence_count":2,"snapshot_sha256":"28e720276538ea8acf010d22f30b5ddf6b3ecc96f600cf70c4bd8f9eb5ce7e4d"},"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":"2605.08731","created_at":"2026-05-21T01:05:20.666750+00:00"},{"alias_kind":"arxiv_version","alias_value":"2605.08731v2","created_at":"2026-05-21T01:05:20.666750+00:00"},{"alias_kind":"doi","alias_value":"10.48550/arxiv.2605.08731","created_at":"2026-05-21T01:05:20.666750+00:00"},{"alias_kind":"pith_short_12","alias_value":"3LCNAPOENBX2","created_at":"2026-05-21T01:05:20.666750+00:00"},{"alias_kind":"pith_short_16","alias_value":"3LCNAPOENBX2YNEW","created_at":"2026-05-21T01:05:20.666750+00:00"},{"alias_kind":"pith_short_8","alias_value":"3LCNAPOE","created_at":"2026-05-21T01:05:20.666750+00:00"}],"events":[],"event_summary":{},"paper_claims":[],"inbound_citations":{"count":0,"internal_anchor_count":0,"sample":[]},"formal_canon":{"evidence_count":2,"sample":[],"anchors":[]},"links":{"html":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP","json":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP.json","graph_json":"https://pith.science/api/pith-number/3LCNAPOENBX2YNEWXJF4KDAFAP/graph.json","events_json":"https://pith.science/api/pith-number/3LCNAPOENBX2YNEWXJF4KDAFAP/events.json","paper":"https://pith.science/paper/3LCNAPOE"},"agent_actions":{"view_html":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP","download_json":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP.json","view_paper":"https://pith.science/paper/3LCNAPOE","resolve_alias":"https://pith.science/api/pith-number/resolve?arxiv=2605.08731&json=true","fetch_graph":"https://pith.science/api/pith-number/3LCNAPOENBX2YNEWXJF4KDAFAP/graph.json","fetch_events":"https://pith.science/api/pith-number/3LCNAPOENBX2YNEWXJF4KDAFAP/events.json","actions":{"anchor_timestamp":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP/action/timestamp_anchor","attest_storage":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP/action/storage_attestation","attest_author":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP/action/author_attestation","sign_citation":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP/action/citation_signature","submit_replication":"https://pith.science/pith/3LCNAPOENBX2YNEWXJF4KDAFAP/action/replication_record"}},"created_at":"2026-05-21T01:05:20.666750+00:00","updated_at":"2026-05-21T01:05:20.666750+00:00"}