#!/usr/bin/env python3
import os
import numpy as np

# 固定参数（按需改）
SHIFT = 1024000  # 你在 generatenpyy.py 里用的 START

MASK_WINDOW_FIL = "/root/trainbin1/maskfil50000.npy"
MASK_ALIGN_FIL  = "/root/trainbin1/mask_alignedfil.npy"

MASK_WINDOW_RAN = "/root/trainbin1/maskran50000.npy"
MASK_ALIGN_RAN  = "/root/trainbin1/mask_alignedran.npy"

SHOW = 20  # 打印多少个错例

def load_bool(path):
    x = np.load(path, allow_pickle=False)
    if x.dtype != np.bool_:
        x = x.astype(np.bool_)
    return x

def check_pair(win_path, align_path, name):
    if not (os.path.exists(win_path) and os.path.exists(align_path)):
        print(f"skip {name}: file not found -> {win_path if not os.path.exists(win_path) else align_path}")
        return

    win = load_bool(win_path)
    aln = load_bool(align_path)

    local_false = np.flatnonzero(~win)                # 窗口内 False 的局部索引
    expected_global = local_false + SHIFT             # 期望对应到整库的全局索引
    aln_len = aln.shape[0]

    # 只比较不会越界的那部分（若 SHIFT+len(win) > len(aln) 会被裁剪）
    in_range = expected_global < aln_len
    clipped = int((~in_range).sum())
    expected_inrange = expected_global[in_range]
    expected_set = set(int(i) for i in expected_inrange)

    aln_false = np.flatnonzero(~aln)
    aln_set = set(int(i) for i in aln_false)

    missing = sorted(expected_set - aln_set)  # 期望 False 但 align 不是 False
    extra   = sorted(aln_set - expected_set)  # align 多出来的 False

    print("---- Check:", name, "----")
    print(f"window_len={len(win)}, window_false={len(local_false)}")
    print(f"align_len ={aln_len}, align_false ={len(aln_false)}")
    print(f"shift={SHIFT}, expected_inrange_false={len(expected_inrange)}, clipped_out_of_range={clipped}")
    print(f"missing={len(missing)}, extra={len(extra)}")
    if len(missing)==0 and len(extra)==0:
        print("OK: align 的 False 集合等于 mask_window False 集合整体平移 SHIFT 后的集合。")
    else:
        if missing:
            print("missing examples (should be False but not in align):", missing[:SHOW])
        if extra:
            print("extra examples (False in align but not expected):", extra[:SHOW])
    print()

def main():
    check_pair(MASK_WINDOW_FIL, MASK_ALIGN_FIL, "FIL")
    check_pair(MASK_WINDOW_RAN, MASK_ALIGN_RAN, "RAN")

if __name__ == "__main__":
    main()

