from scipy.linalg import null_space
from scipy.interpolate import make_interp_spline

import numpy as np
import matplotlib.pyplot as plt
from matplotlib.cm import get_cmap

def plot_accuracy_with_error_bars(accuracy_dict, label, color, errorbar=False):

    # Extract x values and corresponding accuracy lists
    x_values = np.array(list(accuracy_dict.keys()))
    accuracy_lists = list(accuracy_dict.values())

    # Calculate mean and standard deviation of accuracy lists
    means = np.array([np.mean(acc_list) for acc_list in accuracy_lists])
    stds = np.array([np.std(acc_list) for acc_list in accuracy_lists])

    # Smooth the line
    x_smooth = np.linspace(x_values.min(), x_values.max(), 300)
    spl = make_interp_spline(x_values, means, k=1)
    means_smooth = spl(x_smooth)

    # Smooth the standard deviation
    spl_std = make_interp_spline(x_values, stds, k=1)
    stds_smooth = spl_std(x_smooth)

    # Plot mean as smooth line
    plt.plot(x_smooth, means_smooth, label=label, color=color)

    if(errorbar):
        # Plot standard deviation as light color band
        plt.fill_between(x_smooth, means_smooth - stds_smooth, means_smooth + stds_smooth, color=color, alpha=0.2)
