import numpy as np
from simulator import RIRGenSimulator, ANSTISIGNAL_ERROR, NOISE_ERROR



def support_boundary_calc(t60, simulator_rir, thresh=-45, sciencific_notation=False):
	"""
	Calculate the average right-hand bound for the given T60 value.
	Args:
        t60 (float): The T60 value for the simulation.
        simulator_rir (RIRGenSimulator): The RIR generator simulator.
        thresh (float): The threshold in dB for the support calculation.
        sciencific_notation (bool): If True, return the bound in scientific notation.
    Returns:
        bound (float): The calculated bound.
        bound_dB (float): The bound in dB.
        primary_path (numpy.ndarray): The primary path impulse response.
        primary_path_fft (numpy.ndarray): The FFT of the primary path.
        magnitude_p (numpy.ndarray): The magnitude of the primary path in dB.
    """

	bins = 512

	# Generate primary and secondary paths
	primary_path = simulator_rir.rirs[(t60, NOISE_ERROR)].view(-1).cpu().numpy()
	secondary_path = simulator_rir.rirs[(t60, ANSTISIGNAL_ERROR)].view(-1).cpu().numpy()

	# FFT paths
	primary_path_fft = np.fft.fft(primary_path, n=bins)
	secondary_path_fft = np.fft.fft(secondary_path, n=bins)

	# magnitude
	epsilon = 1e-10
	magnitude_p = 20 * np.log10(np.abs(primary_path_fft) + epsilon)
	magnitude_s = 20 * np.log10(np.abs(secondary_path_fft) + epsilon)

	# Supports calculation
	sup_index_p = np.where(magnitude_p > thresh)[0]  # Support primary path indices
	comp_sup_index_s = np.where(magnitude_s < thresh)[0]  # Complementary support secondary path indices

	# Intersection between sup_index_p and comp_sup_index_s
	intersec = np.intersect1d(sup_index_p, comp_sup_index_s)

	bound = (len(intersec) + epsilon) / (len(sup_index_p) + epsilon)
	bound_dB = 10 * np.log10(bound + epsilon)

	if sciencific_notation:
		bound = "{:.2e}".format(bound)
		bound_dB = round(bound_dB, 2)

	return bound, bound_dB
