

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


import argparse



parser = argparse.ArgumentParser()
parser.add_argument('--num', nargs = '+', default=1,type=int, required=False,
		help = 'List # you want to plot')

args = parser.parse_args()
make_plot = args.num

snr = np.arange(15,-5,-1)





if 1:
	plt.figure(0)
	plt.title('MOD:NRZ, Layer:10x32x2')
	#plt.xlabel('Block size',fontsize=13)
	#plt.ylabel('BER ',fontsize=13)
	plt.ylim([1e-3,1e-2])
	plt.yscale('log')
	#plt.xscale('log')
	plt.grid(True)
	xticks_str=['train1e4','train1e5','train1e6']

	nrz_fir = [0.004097020485102426]*4
	nrz_dfe = [0.0023140115700578502]*4
	nrz_fwdBwd = [0.001068010680106801]*4
	nrz_simp_mse_fc0 	= [3.351000e-03,2.641000e-03,2.552000e-03,]
	nrz_simp_mce_fc0 	= [3.487000e-03,3.524000e-03,1.525000e-03,]
	nrz_simp_ce_fc0 	= [3.375000e-03,3.455000e-03,1.566000e-03,]
	nrz_fb_mse_fc0  	= [3.069000e-03,3.038000e-03,2.789000e-03,]
	nrz_fb_mce_fc0   	= [3.476000e-03,3.411000e-03,1.504000e-03,]
	nrz_fb_ce_fc0   	= [3.507000e-03,3.466000e-03,1.540000e-03,]
	plt.plot(xticks_str,nrz_simp_mse_fc0, '-x', label = 'simp MSE FC0')
	plt.plot(xticks_str,nrz_simp_mce_fc0, '-x', label = 'simp MCE FC0')
	plt.plot(xticks_str,nrz_simp_ce_fc0, '-x', label = 'simp CE FC0')
	plt.plot(xticks_str,nrz_fb_mse_fc0, '-o', label = 'fb MSE FC0')
	plt.plot(xticks_str,nrz_fb_mce_fc0, '-o', label = 'fb MCE FC0')
	plt.plot(xticks_str,nrz_fb_ce_fc0, '-o', label = 'fb CE FC0')
	plt.plot(xticks_str,nrz_fir[:3],'--', label = 'FIR')
	plt.plot(xticks_str,nrz_dfe[:3],'--', label = 'DFE')
	plt.plot(xticks_str,nrz_fwdBwd[:3],'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2)
	plt.tight_layout(rect=[0,0,1,1])



	plt.figure(1)
	plt.title('MOD:NRZ, Layer:10x32x32x2')
	#plt.title('BER VS. VITERBI BLOCK SIZE')
	#plt.xlabel('Block size',fontsize=13)
	#plt.ylabel('BER ',fontsize=13)
	#plt.ylim([0.8,10])
	plt.ylim([1e-3,1e-2])
	plt.yscale('log')
	#plt.xscale('log')
	plt.grid(True)
	xticks_str=['train1e4','train1e5','train1e6']
	xticks_str2=['train1e4','train1e5','train1e6','train1e7']
	xticks_str3=['train1e4','train1e5','train1e6','train1e7','train1e8']


	nrz_simp_mse_fc1 	= [3.537000e-03,3.221000e-03,1.533000e-03,1.344000e-03,]
	nrz_simp_mce_fc1 	= [4.352000e-03,3.158000e-03,1.432000e-03,1.132000e-03,]
	nrz_simp_ce_fc1 	= [4.706000e-03,3.481000e-03,1.439000e-03,1.196000e-03,]
	nrz_fb_mse_fc1   	= [3.507000e-03,2.970000e-03,1.384000e-03,1.307000e-03,]
	nrz_fb_mce_fc1   	= [3.861000e-03,2.907000e-03,1.323000e-03,1.072000e-03,]
	nrz_fb_ce_fc1   	= [4.493000e-03,3.341000e-03,1.373000e-03,1.113000e-03,]
	plt.plot(xticks_str2,nrz_simp_mse_fc1, '-x', label = 'simp MSE FC1')
	plt.plot(xticks_str2,nrz_simp_mce_fc1, '-x', label = 'simp MCE FC1')
	plt.plot(xticks_str2,nrz_simp_ce_fc1, '-x', label = 'simp CE FC1')
	plt.plot(xticks_str2,nrz_fb_mse_fc1, '-o', label = 'fb MSE FC1')
	plt.plot(xticks_str2,nrz_fb_mce_fc1, '-o', label = 'fb MCE FC1')
	plt.plot(xticks_str2,nrz_fb_ce_fc1, '-o', label = 'fb CE FC1')
	plt.plot(xticks_str2,nrz_fir,'--', label = 'FIR')
	plt.plot(xticks_str2,nrz_dfe,'--', label = 'DFE')
	plt.plot(xticks_str2,nrz_fwdBwd,'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2) 
	plt.tight_layout(rect=[0,0,1,1])

	plt.figure(12)
	plt.title('MOD:NRZ, Layer:10x32x32x32x2')
	#plt.title('BER VS. VITERBI BLOCK SIZE')
	#plt.xlabel('Block size',fontsize=13)
	#plt.ylabel('BER ',fontsize=13)
	#plt.ylim([0.8,10])
	plt.ylim([1e-3,1e-2])
	plt.yscale('log')
	#plt.xscale('log')
	plt.grid(True)
	xticks_str=['train1e4','train1e5','train1e6']


	nrz_simp_mse_fc2 	= [4.674000e-03,2.795000e-03,1.443000e-03,1.277000e-03,]
	nrz_simp_mce_fc2 	= [5.211000e-03,2.789000e-03,1.376000e-03,1.308000e-03,]
	nrz_simp_ce_fc2 	= [5.625000e-03,2.592000e-03,1.406000e-03,1.187000e-03,]
	nrz_fb_mse_fc2   	= [5.128000e-03,2.233000e-03,1.326000e-03,1.176000e-03,]
	nrz_fb_mce_fc2   	= [4.849000e-03,2.596000e-03,1.293000e-03,1.102000e-03,]
	nrz_fb_ce_fc2   	= [4.811000e-03,2.582000e-03,1.419000e-03,1.249000e-03,]
	plt.plot(xticks_str2,nrz_simp_mse_fc2, '-x', label = 'simp MSE FC2')
	plt.plot(xticks_str2,nrz_simp_mce_fc2, '-x', label = 'simp MCE FC2')
	plt.plot(xticks_str2,nrz_simp_ce_fc2, '-x', label = 'simp CE FC2')
	plt.plot(xticks_str2,nrz_fb_mse_fc2, '-o', label = 'fb MSE FC2')
	plt.plot(xticks_str2,nrz_fb_mce_fc2, '-o', label = 'fb MCE FC2')
	plt.plot(xticks_str2,nrz_fb_ce_fc2, '-o', label = 'fb CE FC2')
	plt.plot(xticks_str2,nrz_fir,'--', label = 'FIR')
	plt.plot(xticks_str2,nrz_dfe,'--', label = 'DFE')
	plt.plot(xticks_str2,nrz_fwdBwd,'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2) 
	plt.tight_layout(rect=[0,0,1,1])


	plt.figure(13)
	plt.title('MOD:NRZ, Layer:10x32x32x32x32x2')
	#plt.title('BER VS. VITERBI BLOCK SIZE')
	#plt.xlabel('Block size',fontsize=13)
	#plt.ylabel('BER ',fontsize=13)
	#plt.ylim([0.8,10])
	plt.ylim([1e-3,1e-2])
	plt.yscale('log')
	#plt.xscale('log')
	plt.grid(True)
	xticks_str=['train1e4','train1e5','train1e6']


	nrz_simp_mse_fc3 	= [4.513000e-03,3.578000e-03,1.633000e-03,1.193000e-03,]
	nrz_simp_mce_fc3 	= [4.623000e-03,3.638000e-03,1.562000e-03,1.193000e-03,]
	nrz_simp_ce_fc3 	= [4.690000e-03,2.799000e-03,1.449000e-03,1.276000e-03,]
	nrz_fb_mse_fc3   	= [4.223000e-03,3.682000e-03,1.333000e-03,1.092000e-03,]
	nrz_fb_mce_fc3   	= [4.436000e-03,3.788000e-03,1.483000e-03,1.182000e-03,]
	nrz_fb_ce_fc3   	= [4.336000e-03,3.022000e-03,1.418000e-03,1.117000e-03,]
	plt.plot(xticks_str2,nrz_simp_mse_fc3, '-x', label = 'simp MSE FC3')
	plt.plot(xticks_str2,nrz_simp_mce_fc3, '-x', label = 'simp MCE FC3')
	plt.plot(xticks_str2,nrz_simp_ce_fc3, '-x', label = 'simp CE FC3')
	plt.plot(xticks_str2,nrz_fb_mse_fc3, '-o', label = 'fb MSE FC3')
	plt.plot(xticks_str2,nrz_fb_mce_fc3, '-o', label = 'fb MCE FC3')
	plt.plot(xticks_str2,nrz_fb_ce_fc3, '-o', label = 'fb CE FC3')
	plt.plot(xticks_str2,nrz_fir,'--', label = 'FIR')
	plt.plot(xticks_str2,nrz_dfe,'--', label = 'DFE')
	plt.plot(xticks_str2,nrz_fwdBwd,'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2) 
	plt.tight_layout(rect=[0,0,1,1])



	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr10_vit_b_sweep, '-^', label = 'SNR 10dB ')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr5_vit_b_sweep, '-v',  label = 'SNR 5dB')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr0_vit_b_sweep, '-o',  label = 'SNR 0dB')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr10_vit_b_sweep2, '--^', label = 'SNR 10dB ')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr5_vit_b_sweep2, '--d',  label = 'SNR 5dB')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr0_vit_b_sweep2, '--o',  label = 'SNR 0dB')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr10_vit_b_sweep3, '-ok', label = 'SNR 10dB ')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr5_vit_b_sweep3, '-ok', label = 'SNR 10dB ')
	#plt.plot(np.append([10000,100],np.arange(20,0,-2)),snr0_vit_b_sweep3, '-ok', label = 'SNR 10dB ')
	plt.figure(2)
	plt.title('MOD:PAM4, Layer:10x512x4')
	plt.grid(True)
	plt.yscale('log')
	plt.ylim([1e-3,1])
	xticks_str=['train1e4','train1e5','train1e6']
	pam4_simp_mse_fc0	= [3.664800e-02,9.259000e-03,5.520000e-03,]
	pam4_simp_mce_fc0 	= [3.400100e-02,8.716000e-03,5.714000e-03,]
	pam4_simp_ce_fc0 	= [5.104640e-01,4.980630e-01,4.968070e-01,]
	pam4_fb_mse_fc0 	= [6.505000e-03,5.025000e-03,2.475000e-03,]
	pam4_fb_mce_fc0 	= [5.811000e-03,7.422610e-01,7.425600e-01,]
	pam4_fb_ce_fc0 		= [6.878000e-03,3.765000e-03,2.304000e-03,]
	pam4_fir = [0.005261026305131525]*4
	pam4_dfe = [0.0023060115300576503]*4
	pam4_fwdBwd = [0.001020010200102001]*4
	plt.plot(xticks_str,pam4_simp_mse_fc0	,'-x', label = 'simp MSE FC0')
	plt.plot(xticks_str,pam4_simp_mce_fc0 	,'-x', label = 'simp MCE FC0')
	plt.plot(xticks_str,pam4_simp_ce_fc0 	,'-x', label = 'simp CE FC0')
	plt.plot(xticks_str,pam4_fb_mse_fc0 	,'-o', label = 'fb MSE FC0')
	plt.plot(xticks_str,pam4_fb_mce_fc0 	,'-o', label = 'fb MCE FC0')
	plt.plot(xticks_str,pam4_fb_ce_fc0 		,'-o', label = 'fb CE FC0')
	plt.plot(xticks_str,pam4_fir[:3],'--', label = 'FIR')
	plt.plot(xticks_str,pam4_dfe[:3],'--', label = 'DFE')
	plt.plot(xticks_str,pam4_fwdBwd[:3],'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2)
	plt.tight_layout(rect=[0,0,1,1])


#[0.0, 0.0, 0.0, 4e-07, 4.72e-05, 0.0012977, 0.0108734, 0.0415746, 0.0981211, 0.1696631, 0.2446467]

	plt.figure(3)
	plt.title('MOD:PAM4, Layer:10x512x512x4')
	plt.grid(True)
	plt.yscale('log')
	plt.ylim([1e-3,1])
	pam4_simp_mse_fc1	= [5.708000e-03,4.607000e-03,1.588000e-03,1.574000e-03,]
	pam4_simp_ce_fc1 	= [5.985000e-03,5.552000e-03,1.549000e-03,1.507000e-03,]
	pam4_fb_mse_fc1 	= [5.592000e-03,4.340000e-03,1.505000e-03,1.527000e-03,0.0012977]
	pam4_fb_ce_fc1 		= [5.544000e-03,5.449000e-03,1.516000e-03,1.516000e-03,]
	#pam4_simp_mse_fc1	= [1.585310e-01,2.076300e-02,1.323700e-02,1.553000e-03,]
	#pam4_simp_mce_fc1 	= [1.845060e-01,3.733700e-02,2.200500e-02,7.426540e-01,]
	#pam4_simp_ce_fc1 	= [5.617570e-01,5.053030e-01,5.066180e-01,4.957850e-01,]
	#pam4_fb_mse_fc1 	= [5.722000e-03,3.371000e-03,1.638000e-03,1.468000e-03,]
	#pam4_fb_mce_fc1 	= [7.482690e-01,7.422610e-01,7.425600e-01,7.426540e-01,]
	#pam4_fb_ce_fc1 		= [7.377000e-03,3.981000e-03,1.804000e-03,1.897000e-03,]
	plt.plot(xticks_str2,pam4_simp_mse_fc1	,'-x', label = 'simp MSE FC1')
	#plt.plot(xticks_str2,pam4_simp_mce_fc1 	,'-x', label = 'simp MCE FC1')
	plt.plot(xticks_str2,pam4_simp_ce_fc1 	,'-x', label = 'simp CE FC1')
	plt.plot(xticks_str3,pam4_fb_mse_fc1 	,'-o', label = 'fb MSE FC1')
	#plt.plot(xticks_str2,pam4_fb_mce_fc1 	,'-o', label = 'fb MCE FC1')
	plt.plot(xticks_str2,pam4_fb_ce_fc1 		,'-o', label = 'fb CE FC1')
	plt.plot(xticks_str2,pam4_fir,'--', label = 'FIR')
	plt.plot(xticks_str2,pam4_dfe,'--', label = 'DFE')
	plt.plot(xticks_str2,pam4_fwdBwd,'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2)
	plt.tight_layout(rect=[0,0,1,1])


	plt.figure(4)
	plt.title('MOD:PAM4, Layer:10x64x64x4')
	plt.grid(True)
	plt.yscale('log')
	plt.ylim([1e-3,1])
	pam4_simp_mse_fc2	= [3.385400e-02,7.883000e-03,4.925000e-03,]
	pam4_simp_mce_fc2 	= [3.476300e-02,7.874000e-03,4.901000e-03,]
	pam4_simp_ce_fc2 	= [5.160520e-01,4.983810e-01,4.964670e-01,]
	pam4_fb_mse_fc2 	= [4.964000e-03,3.481000e-03,1.957000e-03,]
	pam4_fb_mce_fc2 	= [5.097000e-03,3.341000e-03,7.425600e-01,]
	pam4_fb_ce_fc2 		= [6.489000e-03,3.497000e-03,2.585000e-03,]
	plt.plot(xticks_str,pam4_simp_mse_fc2	,'-x', label = 'simp MSE FC2')
	plt.plot(xticks_str,pam4_simp_mce_fc2 	,'-x', label = 'simp MCE FC2')
	plt.plot(xticks_str,pam4_simp_ce_fc2 	,'-x', label = 'simp CE FC2')
	plt.plot(xticks_str,pam4_fb_mse_fc2 	,'-o', label = 'fb MSE FC2')
	plt.plot(xticks_str,pam4_fb_mce_fc2 	,'-o', label = 'fb MCE FC2')
	plt.plot(xticks_str,pam4_fb_ce_fc2 		,'-o', label = 'fb CE FC2')
	plt.plot(xticks_str,pam4_fir[:3],'--', label = 'FIR')
	plt.plot(xticks_str,pam4_dfe[:3],'--', label = 'DFE')
	plt.plot(xticks_str,pam4_fwdBwd[:3],'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2)
	plt.tight_layout(rect=[0,0,1,1])

	plt.figure(5)
	plt.title('MOD:PAM4, Layer:10x512x512x512x4')
	plt.grid(True)
	plt.yscale('log')
	plt.ylim([1e-3,1])
	pam4_simp_mse_fc3	= [1.658800e-01,1.138410e-01,4.220700e-02,1.863000e-03,]
	pam4_simp_mce_fc3 	= [7.482690e-01,9.497200e-02,7.425600e-01,7.426540e-01,]
	pam4_simp_ce_fc3 	= [5.570580e-01,5.389820e-01,5.546180e-01,4.957890e-01,]
	pam4_fb_mse_fc3 	= [9.444000e-03,4.054000e-03,1.610000e-03,1.565000e-03,]
	pam4_fb_mce_fc3 	= [6.385000e-03,7.422610e-01,7.425600e-01,7.426540e-01,]
	pam4_fb_ce_fc3 		= [8.441000e-03,4.822000e-03,2.003000e-03,1.850000e-03,]
	pam4_fir = [0.005261026305131525]*4
	pam4_dfe = [0.0023060115300576503]*4
	plt.plot(xticks_str2,pam4_simp_mse_fc3	,'-x', label = 'simp MSE FC3')
	plt.plot(xticks_str2,pam4_simp_mce_fc3 	,'-x', label = 'simp MCE FC3')
	plt.plot(xticks_str2,pam4_simp_ce_fc3 	,'-x', label = 'simp CE FC3')
	plt.plot(xticks_str2,pam4_fb_mse_fc3 	,'-o', label = 'fb MSE FC3')
	plt.plot(xticks_str2,pam4_fb_mce_fc3 	,'-o', label = 'fb MCE FC3')
	plt.plot(xticks_str2,pam4_fb_ce_fc3 		,'-o', label = 'fb CE FC3')
	plt.plot(xticks_str2,pam4_fir,'--', label = 'FIR')
	plt.plot(xticks_str2,pam4_dfe,'--', label = 'DFE')
	plt.plot(xticks_str2,pam4_fwdBwd,'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2)
	plt.tight_layout(rect=[0,0,1,1])

	plt.figure(6)
	plt.title('MOD:PAM4, Layer:10x512x512x4, Mismatch[1,0.44,0.22,0.11]')
	plt.grid(True)
	plt.yscale('log')
	plt.ylim([1e-3,1])
	pam4_simp_mse_fc1_mismatch	= [6.376100e-02,1.047900e-02,5.198000e-03,]
	pam4_simp_ce_fc1_mismatch 	= [5.088030e-01,5.039670e-01,4.963200e-01,]
	pam4_fb_mse_fc1_mismatch 	= [6.631000e-03,4.330000e-03,2.104000e-03,]
	pam4_fb_ce_fc1_mismatch 	= [1.713100e-02,5.112000e-03,2.246000e-03,]
	plt.plot(xticks_str,pam4_simp_mse_fc1_mismatch	,'-x', label = 'simp MSE fc1_mismatch')
	plt.plot(xticks_str,pam4_simp_ce_fc1_mismatch 	,'-x', label = 'simp CE fc1_mismatch')
	plt.plot(xticks_str,pam4_fb_mse_fc1_mismatch 	,'-o', label = 'fb MSE fc1_mismatch')
	plt.plot(xticks_str,pam4_fb_ce_fc1_mismatch 		,'-o', label = 'fb CE fc1_mismatch')
	plt.plot(xticks_str,pam4_fir[:3],'--', label = 'FIR')
	plt.plot(xticks_str,pam4_dfe[:3],'--', label = 'DFE')
	plt.plot(xticks_str,pam4_fwdBwd[:3],'--', label = 'fwdBwd')
	plt.legend(bbox_to_anchor=(0.5,-0.12) , loc='upper center', ncol=2)
	plt.tight_layout(rect=[0,0,1,1])


	plt.show()
