import pandas as pd
import numpy as np

# ---------- setup ----------
csv_file = "./data/target_checking_end_positions_dataset_7.csv"
threshold = 1  
out_csv = "threshold_labels.csv"

# ---------- read data ----------
df = pd.read_csv(csv_file)
X = df[["x", "y", "z"]].values
y_true = df["label"].values  

# ---------- read first sample ----------
base_point = X[0]  
distances = np.linalg.norm(X - base_point, axis=1)
y_pred = (distances > threshold).astype(int)

df["cluster_label"] = y_pred

# ---------- acc ----------
accuracy = np.mean(y_true == y_pred)
print(f"Threshold Clustering Accuracy: {accuracy:.4f}")

# ---------- err ----------

FP = np.sum((y_true == 0) & (y_pred == 1))  # 0 -> 1
FN = np.sum((y_true == 1) & (y_pred == 0))  # 1 -> 0
TN = np.sum((y_true == 0) & (y_pred == 0))
TP = np.sum((y_true == 1) & (y_pred == 1))


p_0_to_1 = FP / (FP + TN) if (FP + TN) > 0 else 0
p_1_to_0 = FN / (FN + TP) if (FN + TP) > 0 else 0


print(f"P(1→0): {p_1_to_0:.4f}")
print(f"P(0→1): {p_0_to_1:.4f}")




# ---------- 保存结果 ----------
df.to_csv(out_csv, index=False)
print(f"save as {out_csv}")

