Back to MRF Run #34
Export PDF

Unknown Payer

s3://talon-storage-private/mrf-feed-uploads/2026-01/2026-01-01_mc_2_in-network-rates.json
File date: N/A Run: 2026-04-24 14:12 EDT v1.0.0
51.0
Not Usable
score capped at 59.0 — 1 native JSON parse error(s) require payer re-export; CMS official schema validation failed (see meta for details)
Generated At
2026-04-24 14:12 EDT
Elapsed
20.70s
Tool Version
1.0.0
Parse Errors / Crashes
1 / 1
File (raw compressed)
Size:  0 B (0 bytes)
MD5:  d41d8cd98f00b204e9800998ecf8427e
talon-storage-private/mrf-feed-uploads/2026-01/2026-01_plan_ref_e7cd5f5c82c1c63f41b07fb716400106_index.json
Midlands Choice — Third Party
Canonical: s3://talon-storage-private/mrf-feed-uploads/2026-01/2026-01-01_mc_2_in-network-rates.json
1 plan(s) in TOC
Plan Name Plan ID Issuer Market
MidlandsChoice2 2 (EIN) group
score capped at 59.0 — 1 native JSON parse error(s) require payer re-export; CMS official schema validation failed (see meta for details)
Raw JSON Parse Errors (1)
IncompleteJSONError parse error: premature EOF
Context
(right here) ------^
Full Message
parse error: premature EOF
                                       
                     (right here) ------^
CMS Official Schema Validation FAILED (exit 1)
Validator output
error Data file does not contain version information. Please run again using the --schema-version option to specify a version.
Schema Integrity
70.0
Provider Mapping
100.0
Code Coverage
100.0
Pricing Sanity
0.0
Provider Geographic Coverage Loading…
Analysing provider locations…
Errors (5)
required_header_fields
Missing required header fields: ['reporting_entity_type', 'last_updated_on', 'reporting_entity_name', 'version']
cms_schema_validation
CMS official schema validator FAILED (exit code 1). File does not conform to the TIC in-network-rates schema.
raw_json_error
Native JSON parse error detected in unpatched source file: parse error: premature EOF. Scoring below reflects auto-patched data only. File must be re-exported by the payer to fully resolve.
(right here) ------^ IncompleteJSONError
parse_crash
single pass crash after 0 items: parse error: premature EOF (right here) ------^
no_rates
No negotiated rates found in file
Recommended Actions
  1. 1.
    overall
    Score below minimum threshold — do not use for pricing without remediation.
    P0
  2. 2.
    schema required_header_fields
    Missing required header fields: ['reporting_entity_type', 'last_updated_on', 'reporting_entity_name', 'version']
    P1
  3. 3.
    schema cms_schema_validation
    CMS official schema validator FAILED (exit code 1). File does not conform to the TIC in-network-rates schema.
    P1
  4. 4.
    schema raw_json_error
    Native JSON parse error detected in unpatched source file: parse error: premature EOF. Scoring below reflects auto-patched data only. File must be re-exported by the payer to fully resolve.
    P1
  5. 5.
    schema parse_crash
    single pass crash after 0 items: parse error: premature EOF (right here) ------^
    P1
  6. 6.
    pricing no_rates
    No negotiated rates found in file
    P1
Metrics

header_missing_fields reporting_entity_type, last_updated_on, reporting_entity_name, version
header_conditional_issues
file_age_days None
items_total 0
items_missing_required_pct 0
items_empty_rates 0
prices_total 0
prices_missing_required_pct 0
prices_missing_field_breakdown
prices_missing_service_code 0
prices_invalid_billing_class 0
rates_without_providers 0
negotiation_arrangements
billing_code_types
expired_prices 0
invalid_expiration_format 0

provider_references_in_file 0
provider_group_ids_referenced 0
unresolved_references 0
resolution_rate_pct 100.0
npis_validated 0
invalid_npi_count 0
npi_validity_rate_pct None
invalid_npi_examples
eins_validated 0
invalid_ein_count 0
ein_validity_rate_pct None
invalid_ein_examples
empty_npi_groups 0
groups_without_tin 0
npis_in_multiple_groups 0
unique_npis

unique_codes_total 0
duplicate_codes 0
duplicate_pct 0
by_code_type
unknown_code_types
format_invalid_by_type
codes_not_in_reference reference_not_loaded
most_frequent_codes
Type Code Occurrences

total_prices_checked 0
total_rates 0
per_diem_rates 0
percentage_rates 0
negative_rates 0
zero_rates 0
extreme_high_rates 0
extreme_low_rates 0
rate_distribution
sample_n 0
sample_k 0
confidence low
p5 None
p25 None
p50 None
p75 None
p95 None
p99 None
by_billing_class
Class / Type Count Median p25 p75 p95 Confidence
negotiated_types
unique_rate_contexts 0
rate_key_dimension_validity
invalid_negotiated_type 0
invalid_negotiated_types_seen {}
invalid_setting 0
invalid_settings_seen {}
invalid_severity_of_illness 0
severity_on_non_apr_drg 0
institutional_with_service_codes 0
invalid_service_code_format 0
billing_code_modifier_too_long 0
Scoring Methodology embedded in this report at generation time

Weighted sum of four structural dimensions, normalized to a 0–100 scale.

Normalized Weights
Schema Integrity 30%
Provider Mapping 15%
Code Coverage 15%
Pricing Sanity 40%
Confidence Bands
High ≥90
Usable With Caution ≥75
Limited Reliability ≥60
Not Usable <60
Score Caps
ConditionCapReason
Raw Json Errors Only 74.0 Native JSON syntax errors in the unpatched source file. File must be re-exported by the payer; scoring reflects auto-patched data only.
Cms Validation Failure Only 65.0 CMS official schema validator reports the file does not conform to the TIC spec.
Both Raw Json Errors And Cms Failure 59.0 Both native JSON syntax errors and CMS schema validation failure present.
Rate Context Key — 14-Tuple Field Coverage

Every rate in a CMS TIC MRF file is described by a 14-field tuple. Fields 1–10 form the rate-context key used to group and compare rates across the system. Fields 11–12 (provider, expiration date) are validated separately and excluded from the grouping key for analytical reasons. Each of the four scoring dimensions validates a distinct slice of this tuple — together they cover all 14 fields.

FieldValidated by
1 billing_code_type Schema (required field) + Code Coverage (enum + format validation)
2 billing_code_type_version Schema (required field)
3 billing_code Schema (required field) + Code Coverage (format, duplicates, reference lookup)
4 billing_code_modifier Pricing (modifier length, key normalization)
5 service_code Pricing (POS format, normalization, institutional-class check)
6 negotiated_type Pricing (CMS TIC enum validation)
7 billing_class Schema (CMS TIC enum validation) + Pricing (spread thresholds)
8 negotiation_arrangement Schema (CMS TIC enum validation) + Pricing (FFS vs bundle/capitation gating)
9 severity_of_illness Pricing (APR-DRG only, valid values 1–4)
10 setting Pricing (CMS TIC enum validation)
11 provider (NPI/EIN) Provider Mapping (Luhn checksum, IRS prefix, group resolution) — excluded from grouping key
12 expiration_date Schema (date validity, far-future sanity) — excluded from grouping key
13 additional_generic_notes not validated (free-text)
14 negotiated_rate Pricing (negative/zero/extreme-value checks, spread analysis)
  • Fields 1–10 are the grouping key. Each unique combination is a distinct rate context — rates with different modifiers, POS codes, or arrangements land in separate buckets and are never compared against each other.
  • Provider (field 11) is excluded from the key: the spread check is cross-provider by design. Partitioning by provider produces singleton buckets and eliminates the spread signal.
  • Expiration date (field 12) is excluded because it is a contract lifecycle attribute, not a clinical context. Rates for the same service should be comparable regardless of when they expire.
  • service_code (field 5) arrays are flattened and normalized before keying: '1' → '01', and a rate with ['11','22'] contributes to both the '11' and '22' buckets so rates are compared apples-to-apples by place of service.

Validates required fields, enum values, conditional requirements, and date validity per the CMS TIC in-network-rates schema. Also checks file freshness and expiration date sanity.

Scoring Method
Penalty-based deductions from 100, capped per category.
Penalty / ComponentFormula
per_missing_required_header_field 5
per_header_conditional_issue 2
freshness_warn 5
freshness_error 10
item_missing_fields_pct ×5 (cap 30)
empty_rates_pct ×0.5 (cap 5)
price_missing_fields_pct ×10 (cap 30)
rates_without_providers_rate ×200 (cap 20)
expired_prices_pct ×0.5 (cap 5)
Thresholds
file freshness warn days 45
file freshness error days 90
expiry far future years 3

Verifies that all provider_group_id references in in_network items resolve to an entry in the provider_references array. Validates NPI integrity via Luhn checksum and EIN integrity via IRS-issued 2-digit prefix.

Scoring Method
Weighted component sum (not purely penalty-based).
ComponentFormula
provider_resolution (60%) resolution_rate% × 0.60
npi_validity (30%) (100 − invalid_npi_pct × 5) × 0.30
ein_validity (10%) 10 − (invalid_ein_pct × 0.1) [0% invalid → 10 pts, 100% invalid → 0 pts, linear]
Checks
provider_group_resolution Ratio of provider_group_id references that resolve to a known provider group. Unresolved references mean rates cannot be attributed to any provider.
npi_validity Luhn checksum applied to every NPI value in the file.
ein_validity IRS-issued 2-digit prefix validation on EIN values.
empty_npi_groups Provider groups with an empty npi list.
missing_tin Provider groups with no TIN (type + value pair).
duplicate_npis Informational: NPIs appearing in more than one provider group.

Tracks every (billing_code_type, billing_code) pair and flags unrecognized CMS TIC code types, format violations for CPT/HCPCS/NDC, and duplicates (same code appearing in multiple in_network items).

Scoring Method
Penalty-based deductions from 100.
Penalty / ComponentFormula
per_unknown_code_type 3 pts each (cap 20)
format_invalid_pct × 0.5 (cap 10)
duplicate_code_pct × 2 (cap 20)
codes_not_in_reference_pct × 0.5 (cap 30) — only when reference set is loaded
Recognized Code Types
AP-DRG, APC, APR-DRG, APS-DRG, CDT, CPT, CSTM-ALL, EAPG, HCPCS, HIPPS, ICD, LOCAL, MS-DRG, NDC, R-DRG, RC, S-DRG

Detects invalid rates (negative, zero, extreme-value) and distribution anomalies (per-class P95/P50 spread, per-code max/min ratio, flat-rate distributions). Exact counts are used for all validity checks (negative, zero, extreme, dimension validity). Percentile-based checks (spread, IQR) use reservoir sampling — k=5 000 global, k=1 000 per (billing_class, negotiated_type) bucket — so memory stays bounded on large files. Per-code max/min spread is exact (all rates seen, no sampling).

Scoring Method
Penalty-based deductions from 100.
Penalty / ComponentFormula
negative_rate_pct × 5 (cap 20)
zero_rate_pct × 3 (cap 15)
extreme_rate_pct × 5 (cap 25) — ffs only
class_spread_excess (spread − threshold) × 2, max across (billing_class, negotiated_type) buckets (cap 15)
per_code_high_spread_count × 0.1 (cap 15)
invalid_negotiated_type_pct × 3 (cap 10) — rates silently dropped
invalid_setting_pct × 1 (cap 5) — silently defaults to wildcard
invalid_severity_pct × 1 (cap 5) — silently normalised to ''
institutional_with_service_codes_pct × 1 (cap 5) — extra key variation
invalid_service_code_pct × 2 (cap 5) — encode raises ValueError
Thresholds
extreme high by billing class professional: 25000.0institutional: 2000000.0both: 2000000.0default: 500000.0
extreme low 0.01
spread warn p95 over p50 by class professional: 5institutional: 10both: 10default: 5
per rate context max min ratio professional_codes: 20facility_drg_codes: 50
flat rate iqr p75 threshold pct 5.0
flat rate min rates to check 100
spread min n to flag 50
per code min n to flag 3
Notes
  • per diem and percentage rates are not dollar amounts and are excluded from all spread and distribution analysis.
  • Zero rates are treated as errors per CMS schema (exclusiveMinimum: 0).
  • Extreme-value flags (negative, zero, extreme high/low) are only applied to ffs negotiation_arrangement rates — bundle and capitation rates have different magnitude ranges and lack calibrated thresholds.
  • P95/P50 spread and flat-rate IQR checks are keyed by (billing_class, negotiated_type) so fee schedule and negotiated distributions are evaluated independently.
  • flat_rate_distribution is suppressed for negotiated_type='fee schedule' buckets — a flat distribution is correct behaviour for a fee schedule, not a defect.

The dashboard assigns a persistent mrf_key to each MRF. All validation runs of the same MRF share the same key so the score-history chart reflects how a file has changed over time — even if the payer re-exports it at a new URL. This key is not stored in the report JSON; it is computed at ingest time.

Key derivation (priority order)
TierWhen usedInput string
1 Both reporting_entity_name and plan_id present plan|<entity>|<plan_id_type>|<plan_id>
2 plan_id absent — falls back to URL (entity name alone is not safe: a payer publishes multiple distinct plans under the same entity) <file_location URL>

The key is a 16-character MD5 hex digest of the input string (case-insensitive, whitespace-stripped). Tier 1 is stable across monthly file re-exports because the plan identity in the MRF header does not change when the payer fixes a bug and re-publishes. Tier 3 is URL-dependent and will produce a new key if the file path changes.

This run:
mrf_key24784283559c3712
Entity
Key tier Tier 2 URL hash

Geographic analysis is a supplemental feature computed on demand after scoring completes. It does not affect any scoring dimension — it is an observational overlay to help assess the breadth and distribution of in-network providers.

Data Sources
NPPES CMS National Plan and Provider Enumeration System — monthly full-replacement CSV. Maps each NPI to its primary registered ZIP code.
ZCTA centroids GeoNames US postal code file. Maps each 5-digit ZIP to a (latitude, longitude) centroid for map placement.
Process
  1. Extract all NPIs from the MRF file (npi and npi_numbers fields).
  2. Resolve each NPI to its primary practice ZIP via NPPES lookup.
  3. Aggregate provider count per ZIP code.
  4. Map each ZIP to a (lat, lon) centroid via ZCTA table.
  5. Render as a weighted heatmap — intensity proportional to provider count per ZIP.
Limitations
  • NPIs not found in NPPES (recently issued, test NPIs, EINs used as NPIs) are excluded from the map and reduce the geocoding match rate.
  • Location reflects the provider's NPPES-registered primary address, not necessarily where they accept this specific plan.
  • Map viewport auto-fits to the bounding box of ZIP codes covering 90% of total provider count, dropping sparse geographic outliers.