rfm.feature.ts
8.87 KB
-
fix(persona): 就诊次数/RFM频次 按诊所本地时区去重(修时区虚增) · 1d2759dc
问题(用户在王振中发现):画像'就诊2次',但病历只1条。查实=时区 bug。 王振中所有事实本地(Asia/Shanghai)都在 2025-09-26:encounter 本地03:09(=UTC 09-25 19:09)、 treatment 本地11:10(=UTC 09-26 03:10)。但 lifecycle/rfm 用 occurredAt.toISOString()(UTC日期) 去重就诊天 → encounter落09-25、treatment落09-26 → 切成两天 → 虚增'就诊2次'(实1次)。 - 新增 visit-day.util.ts:localDayKey(date, tz='Asia/Shanghai') 按诊所本地时区取 YYYY-MM-DD。 - lifecycle-stage + rfm 的就诊天去重改用 localDayKey(原 toISOString UTC)。 (首/末诊用 getTime min/max,时区无关,不动) - 影响:lifecycle 生命周期分期 + RFM 频次F + visitsPerYear,凡有本地凌晨(00-08点=UTC前一天)事件的患者。 - CLINIC_TZ 暂常量(试点全+8);多租户后续从 platform.pullConfig.timezone 接进 feature ctx。 验证(本地 --force 重算):王振中 lifecycle/rfm 均 '就诊2次'→'就诊1次'。 注:算法变更需 recompute-persona --force(数据没变,水位闸会 noop)。 Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
luoqi committed