import numpy as np
import matplotlib
matplotlib.use('TkAgg')
import matplotlib.pyplot as plt
import torch
import sys

import argparse

from scipy.stats import norm



#isi0_fineoff_snr30 = [0.0, 0.0, 0.0, 1.5e-05, 0.000534, 0.004869, 0.021989, 0.061285, 0.123915, 0.201292]
#isi0_fineoff_snr28 = [0.0, 0.0, 4e-06, 5.9e-05, 0.000863, 0.006289, 0.024776, 0.064927, 0.12643, 0.20409]
#isi0_fineoff_snr26 = [0.0, 0.0, 2e-06, 4.4e-05, 0.000695, 0.00546, 0.02347, 0.063851, 0.126255, 0.203733]
#isi0_fineoff_snr24 = [0.0, 0.0, 0.0, 1.3e-05, 0.000328, 0.003952, 0.019907, 0.059156, 0.12303, 0.201513]
#isi0_fineoff_snr22 = [0.0, 0.0, 0.0, 4e-06, 0.000192, 0.002717, 0.016703, 0.056079, 0.120465, 0.199728]
#isi0_fineoff_snr20 = [0.0, 0.0, 0.0, 2e-06, 8.2e-05, 0.001583, 0.013361, 0.050463, 0.116982, 0.198376]
#isi0_fineoff_snr18 = [0.0, 0.0, 0.0, 0.0, 5e-05, 0.001432, 0.012839, 0.04885, 0.114678, 0.195968]
#isi0_fineoff_snr16 = [0.0, 0.0, 0.0, 0.0, 6.5e-05, 0.001476, 0.012762, 0.048522, 0.113475, 0.19385]
#isi0_fineoff_snr14 = [0.0, 0.0, 0.0, 1e-06, 0.0001, 0.002, 0.014041, 0.050061, 0.112437, 0.192041]
#isi0_fineoff_snr12 = [0.0, 0.0, 0.0, 1.1e-05, 0.000274, 0.003348, 0.017717, 0.053652, 0.114809, 0.191195]

#isi0_fineoff_snr30 = [0.0, 0.0, 1.5e-05, 0.00023, 0.001624, 0.008699, 0.028906, 0.070148, 0.132814, 0.208734]
#isi0_fineoff_snr28 = [0.0, 0.0, 1e-06, 9.3e-05, 0.001079, 0.006575, 0.025617, 0.065754, 0.128362, 0.205717]
#isi0_fineoff_snr26 = [2e-06, 2e-06, 1.3e-05, 0.000215, 0.001538, 0.008045, 0.027397, 0.068252, 0.130496, 0.207335]
#isi0_fineoff_snr24 = [0.0, 0.0, 0.0, 3.7e-05, 0.000525, 0.004564, 0.021302, 0.062045, 0.126358, 0.20455]
#isi0_fineoff_snr22 = [0.0, 0.0, 0.0, 2e-06, 0.000196, 0.002798, 0.017208, 0.05658, 0.121888, 0.20183]
#isi0_fineoff_snr20 = [0.0, 0.0, 0.0, 1e-06, 5.4e-05, 0.001483, 0.013098, 0.051073, 0.117192, 0.198995]
#isi0_fineoff_snr18 = [0.0, 0.0, 0.0, 0.0, 4.2e-05, 0.001515, 0.012693, 0.049875, 0.115868, 0.198185]
#isi0_fineoff_snr16 = [0.0, 0.0, 0.0, 0.0, 4.7e-05, 0.00143, 0.012195, 0.049225, 0.114897, 0.196076]
#isi0_fineoff_snr14 = [0.0, 0.0, 0.0, 0.0, 8.3e-05, 0.001888, 0.013941, 0.05045, 0.11376, 0.194004]
#isi0_fineoff_snr12 = [0.0, 0.0, 0.0, 3e-06, 0.000258, 0.003324, 0.017489, 0.054834, 0.115767, 0.193396]


isi0_fineoff_snr30 = [0.0, 1.1e-06, 1.89e-05, 0.0002199, 0.00175, 0.0086146, 0.0289578, 0.0701704, 0.1327806, 0.2092908]
isi0_fineoff_snr28 = [0.0, 1e-07, 3.8e-06, 8.79e-05, 0.0010441, 0.0065965, 0.0254643, 0.0656817, 0.1284916, 0.2054988]
isi0_fineoff_snr26 = [3e-07, 2.3e-06, 1.87e-05, 0.0002044, 0.001522, 0.0078838, 0.0274405, 0.068157, 0.1304157, 0.2070099]
isi0_fineoff_snr24 = [0.0, 2e-07, 8e-07, 3.19e-05, 0.0005495, 0.0046507, 0.0214631, 0.0616236, 0.1259496, 0.204396]
isi0_fineoff_snr22 = [0.0, 0.0, 0.0, 2.4e-06, 0.0001726, 0.0027482, 0.0171811, 0.0563537, 0.1217453, 0.2013264]
isi0_fineoff_snr20 = [0.0, 0.0, 0.0, 6e-07, 5.48e-05, 0.0015311, 0.0130358, 0.0508505, 0.1177599, 0.1992667]
isi0_fineoff_snr18 = [0.0, 0.0, 0.0, 3e-07, 4.91e-05, 0.001374, 0.0124825, 0.0495593, 0.1164273, 0.1981808]
isi0_fineoff_snr16 = [0.0, 0.0, 0.0, 2e-07, 4.73e-05, 0.0014009, 0.0124198, 0.048875, 0.1148453, 0.1957924]
isi0_fineoff_snr14 = [0.0, 0.0, 0.0, 7e-07, 8.62e-05, 0.0019016, 0.0140225, 0.0501874, 0.1140995, 0.1938145]
isi0_fineoff_snr12 = [0.0, 0.0, 0.0, 7.4e-06, 0.0002764, 0.0033446, 0.017791, 0.0544809, 0.1158004, 0.1929413]


snr30_12 = np.arange(30,10,-2)
plt.figure("finetune off")
plt.xlabel('SNR (dB)',fontsize=13)
plt.xticks(fontsize=13)
plt.ylabel('BER ',fontsize=13)
#plt.ylim([0.8,10])
plt.yscale('log')
plt.grid(True)
	
plt.plot(snr30_12, isi0_fineoff_snr30, label=30)
plt.plot(snr30_12, isi0_fineoff_snr28, label=28)
plt.plot(snr30_12, isi0_fineoff_snr26, label=26)
plt.plot(snr30_12, isi0_fineoff_snr24, label=24)
plt.plot(snr30_12, isi0_fineoff_snr22, label=22)
plt.plot(snr30_12, isi0_fineoff_snr20, label=20)
plt.plot(snr30_12, isi0_fineoff_snr18, label=18)
plt.plot(snr30_12, isi0_fineoff_snr16, label=16)
plt.plot(snr30_12, isi0_fineoff_snr14, label=14)
plt.plot(snr30_12, isi0_fineoff_snr12, label=12)

plt.legend(loc='best')


#isi0_fineon_snr30 = [0.0, 0.0, 0.0, 4.2e-05, 0.000373, 0.002729, 0.015932, 0.052194, 0.114357, 0.191209]
#isi0_fineon_snr28 = [0.0, 0.0, 1e-06, 3e-05, 0.000341, 0.00254, 0.015525, 0.051576, 0.113514, 0.19183]
#isi0_fineon_snr26 = [0.0, 0.0, 0.0, 1.6e-05, 0.000305, 0.002625, 0.015566, 0.051603, 0.11385, 0.190967]
#isi0_fineon_snr24 = [0.0, 0.0, 0.0, 1.3e-05, 0.000188, 0.002579, 0.015703, 0.052158, 0.114683, 0.192233]
#isi0_fineon_snr22 = [0.0, 0.0, 0.0, 6e-06, 0.00018, 0.00237, 0.014355, 0.050195, 0.113665, 0.191327]
#isi0_fineon_snr20 = [0.0, 0.0, 0.0, 2.2e-05, 0.000183, 0.002061, 0.013807, 0.049958, 0.113522, 0.191991]
#isi0_fineon_snr18 = [0.0, 0.0, 2e-06, 4.1e-05, 0.000194, 0.002215, 0.013649, 0.04978, 0.112807, 0.191846]
#isi0_fineon_snr16 = [0.0, 0.0, 3e-06, 5e-06, 0.000104, 0.001759, 0.012955, 0.049056, 0.112773, 0.190735]
#isi0_fineon_snr14 = [0.0, 0.0, 0.0, 4e-06, 0.000192, 0.001945, 0.013008, 0.049018, 0.113487, 0.19205]
#isi0_fineon_snr12 = [0.0, 0.0, 0.0, 5e-06, 0.000177, 0.00239, 0.013907, 0.049463, 0.113218, 0.191224]
#
#snr30_12 = np.arange(30,10,-2)
#plt.figure("finetune on")
#plt.xlabel('SNR (dB)',fontsize=13)
#plt.xticks(fontsize=13)
#plt.ylabel('BER ',fontsize=13)
##plt.ylim([0.8,10])
#plt.yscale('log')
#plt.grid(True)
#	
#plt.plot(snr30_12, isi0_fineon_snr30, label=30)
#plt.plot(snr30_12, isi0_fineon_snr28, label=28)
#plt.plot(snr30_12, isi0_fineon_snr26, label=26)
#plt.plot(snr30_12, isi0_fineon_snr24, label=24)
#plt.plot(snr30_12, isi0_fineon_snr22, label=22)
#plt.plot(snr30_12, isi0_fineon_snr20, label=20)
#plt.plot(snr30_12, isi0_fineon_snr18, label=18)
#plt.plot(snr30_12, isi0_fineon_snr16, label=16)
#plt.plot(snr30_12, isi0_fineon_snr14, label=14)
#plt.plot(snr30_12, isi0_fineon_snr12, label=12)
#
#plt.legend(loc='best')
#
#
#
#
isiorg_fineoff_snr30 = [0.0, 0.0, 0.0, 1.16e-05, 0.0003998, 0.0041992, 0.0201588, 0.0583038, 0.1202465, 0.1974035]
isiorg_fineoff_snr28 = [0.0, 0.0, 7e-07, 4.76e-05, 0.0007662, 0.0056542, 0.023047, 0.0617411, 0.1231862, 0.1997727]
isiorg_fineoff_snr26 = [0.0, 0.0, 0.0, 1.49e-05, 0.0003755, 0.0038267, 0.0187961, 0.0560676, 0.1179404, 0.1957954]
isiorg_fineoff_snr24 = [0.0, 0.0, 0.0, 1.5e-06, 0.0001683, 0.0026366, 0.0161805, 0.0534736, 0.1173707, 0.1966839]
isiorg_fineoff_snr22 = [0.0, 0.0, 0.0, 8e-07, 5.86e-05, 0.0015173, 0.012424, 0.0478174, 0.112381, 0.1931736]
isiorg_fineoff_snr20 = [0.0, 0.0, 0.0, 2e-07, 2.97e-05, 0.0010691, 0.0105485, 0.0450078, 0.1101233, 0.1914734]
isiorg_fineoff_snr18 = [0.0, 0.0, 0.0, 2e-07, 3.07e-05, 0.001031, 0.010262, 0.0441832, 0.1090212, 0.1904799]
isiorg_fineoff_snr16 = [0.0, 0.0, 0.0, 2e-07, 3.23e-05, 0.0010715, 0.010403, 0.0438471, 0.1075571, 0.1882407]
isiorg_fineoff_snr14 = [0.0, 0.0, 0.0, 2e-07, 4.7e-05, 0.0013147, 0.011327, 0.044623, 0.1065806, 0.1858955]
isiorg_fineoff_snr12 = [0.0, 0.0, 0.0, 1.7e-06, 0.0001542, 0.0023349, 0.0145159, 0.0485968, 0.1083566, 0.1853488]


snr30_12 = np.arange(30,10,-2)
plt.figure("isiorg finetune off")
plt.xlabel('SNR (dB)',fontsize=13)
plt.xticks(fontsize=13)
plt.ylabel('BER ',fontsize=13)
#plt.ylim([0.8,10])
plt.yscale('log')
plt.grid(True)
	
plt.plot(snr30_12, isiorg_fineoff_snr30, label=30)
plt.plot(snr30_12, isiorg_fineoff_snr28, label=28)
plt.plot(snr30_12, isiorg_fineoff_snr26, label=26)
plt.plot(snr30_12, isiorg_fineoff_snr24, label=24)
plt.plot(snr30_12, isiorg_fineoff_snr22, label=22)
plt.plot(snr30_12, isiorg_fineoff_snr20, label=20)
plt.plot(snr30_12, isiorg_fineoff_snr18, label=18)
plt.plot(snr30_12, isiorg_fineoff_snr16, label=16)
plt.plot(snr30_12, isiorg_fineoff_snr14, label=14)
plt.plot(snr30_12, isiorg_fineoff_snr12, label=12)

plt.legend(loc='best')


plt.show()
