import torch
import torch.nn as nn
from torch.utils.data import DataLoader, TensorDataset
from torch.nn.utils.rnn import pad_sequence
import torch.nn.functional as F
import numpy as np
import pandas as pd
import time
import gc
import random
from torch.utils.data import WeightedRandomSampler
import platform
from statistics import mean, stdev



pd_Tests_Data.iloc[:, 10:13],  # regular softmax
pd_Tests_Data.iloc[:, 50]     # regular softmax mean





import pandas as pd, matplotlib.pyplot as plt, seaborn as sns, numpy as np, time

# ---------------- 1. Load ----------------------------------------------------
df = pd.read_csv(r"C:/research.csv",header=None, engine="c")
# • column 0  = correctness   (1 = correct, 0 = error)
# • column 10 = soft-max      (y-axis)
# • column 50 = median logit  (x-axis)
df["correct"] = df.iloc[:, 0]
df["softmax"] = df.iloc[:, 10]
df["median"]  = df.iloc[:, 51]




# ---------------- 2. Min–max scale median (for plotting only) ----------------
med_min, med_max = df["median"].min(), df["median"].max()
df["median_norm"] = (df["median"] - med_min) / (med_max - med_min + 1e-9)

# Optional tiny jitter if values are very discrete
# rng = np.random.default_rng(int(time.time()))
# df["median_norm"] += rng.uniform(-0.003, 0.003, size=len(df))
# df["median_norm"] = df["median_norm"].clip(0, 1)

# ---------------- 3. Scatter plot -------------------------------------------
palette = {1: "tab:green", 0: "tab:red"}     # 1 = correct, 0 = wrong

plt.figure(figsize=(4.6, 3.3))
plt.scatter(df["median_norm"], df["softmax"],
            c=df["correct"].map(palette), s=20, alpha=0.65, linewidths=0)

plt.xlabel("Median $p$-norm logit (min–max scaled)")
plt.ylabel("Top-1 soft-max")
plt.xlim(0, 1); plt.ylim(0, 1)
plt.title("Stanford Cars — soft-max vs. scaled median logit")
sns.despine()
plt.tight_layout()
plt.savefig("cars_scatter_plain.pdf", dpi=300)
plt.show()






















