import os
import mne
import numpy as np
import pandas as pd
from mne_bids import BIDSPath, read_raw_bids, write_raw_bids
from config import DATA_PATH

data_path = DATA_PATH
bids_root = "data_path/CFS/100Hz/"
preproc_bids_root = "data_path/CFS/2channels/"
datatype = "eeg"

all_sub = (
    pd.read_csv(bids_root + "participants.tsv", delimiter="\t", engine="python")[
        "participant_id"
    ]
    .transform(lambda x: x[4:])
    .tolist()
)


def preprocess_and_save(bids_path, preproc_bids_path):
    raw = read_raw_bids(bids_path=bids_path)
    print(raw.ch_names)
    raw.pick_channels(
        ["C3", "C4", "M1", "M2"],
        ordered=True,
    )
    sfreq = raw.info["sfreq"]
    linefreq = raw.info["line_freq"]

    data, times = raw[:]
    C3_A2 = data[0] - data[3]
    C4_A1 = data[1] - data[2]

    info_C3_A2 = mne.create_info(["C3-A2"], sfreq=sfreq, ch_types=datatype)
    info_C3_A2["line_freq"] = linefreq
    raw_C3_A2 = mne.io.RawArray(C3_A2[np.newaxis, :], info_C3_A2)

    info_C4_A1 = mne.create_info(["C4-A1"], sfreq=sfreq, ch_types=datatype)
    info_C4_A1["line_freq"] = linefreq
    raw_C4_A1 = mne.io.RawArray(C4_A1[np.newaxis, :], info_C4_A1)

    raw_final = raw_C3_A2.copy().add_channels(
        [raw_C4_A1]
    )
    raw_final.set_meas_date(raw.info["meas_date"])
    raw_final.set_annotations(raw.annotations)

    # Write new BIDS
    # Set output path

    write_raw_bids(
        raw_final,
        preproc_bids_path,
        overwrite=True,
        allow_preload=True,
        format="BrainVision",
    )


for subject_id in all_sub:
    bids_path = BIDSPath(
        subject=subject_id, root=bids_root, datatype=datatype, task="sleep"
    )
    sessions = os.listdir(f"{bids_path.root}/sub-{bids_path.subject}")
    for session in sessions:
        if not session.startswith("ses-"):
            continue
        bids_path.update(session=session[4:])
        preproc_bids_path = bids_path.copy().update(root=preproc_bids_root)
        preprocess_and_save(
            bids_path, preproc_bids_path,
        )
