from data_provider.data_loader import (
    Dataset_ETT_hour, 
    Dataset_ETT_minute, 
    Dataset_Custom, 
    Dataset_Pred,
     # ✅ 新增
)
from data_provider.dataset_dlp import Dataset_DLP
from torch.utils.data import DataLoader
from data_provider.dataset_ohio import Dataset_Ohio
# ========================
# 注册所有数据集
# ========================
data_dict = {
    'ETTh1': Dataset_ETT_hour,
    'ETTh2': Dataset_ETT_hour,
    'ETTm1': Dataset_ETT_minute,
    'ETTm2': Dataset_ETT_minute,
    'custom': Dataset_Custom,
    'DLP': Dataset_DLP,   # ✅ 新增条目
    'ohio':Dataset_Ohio
}


def data_provider(args, flag):
    """
    通用数据加载入口，根据 args.data 自动选择对应 Dataset 类
    """
    Data = data_dict[args.data]
    timeenc = 0 if args.embed != 'timeF' else 1

    # ====== 数据加载参数 ======
    if flag == 'test':
        shuffle_flag = False
        drop_last = True
        batch_size = args.batch_size
        freq = args.freq
    elif flag == 'pred':
        shuffle_flag = False
        drop_last = False
        batch_size = 1
        freq = args.freq
        Data = Dataset_Pred
    else:
        shuffle_flag = True
        drop_last = True
        batch_size = args.batch_size
        freq = args.freq

    # ====== 数据集初始化 ======
    data_set = Data(
        root_path=args.root_path,
        data_path=args.data_path,
        flag=flag,
        size=[args.seq_len, args.label_len, args.pred_len],
        features=args.features,
        target=args.target,
        scale=True,
        timeenc=timeenc,
        freq=freq
    )

    print(f"{flag} 集合长度: {len(data_set)}")

    # ====== DataLoader ======
    data_loader = DataLoader(
        data_set,
        batch_size=batch_size,
        shuffle=shuffle_flag,
        num_workers=args.num_workers,
        drop_last=drop_last
    )

    return data_set, data_loader
