
import numpy as np

import matplotlib.pyplot as plt


plt.figure()

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

berShannon = [4.910718399340429e-20, 2.6969033808299127e-16, 2.5771886632398563e-13, 6.138372836132094e-11, 4.847623579726111e-09, 1.5921938818530635e-07, 2.603777619982647e-06, 2.4456623740173902e-05, 0.00014778265994009324, 0.0006285966773417563, 0.0020214310993986375, 0.005201074818844495, 0.01119949213164796, 0.020915324481036446, 0.03484849916619692, 0.05298042029732867, 0.07481890215233784, 0.09954910387020827, 0.1262128014184939, 0.1538602521298209, 0.18165107044344897, 0.208904537733401, 0.23511140360020827, 0.25992161632453314, 0.2831200728850751]
berFwdBwd = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0001000100010001e-05, 3.0003000300030004e-05, 0.00024002400240024003, 0.00108010801080108, 0.0034803480348034803, 0.00837083708370837, 0.01818181818181818, 0.0333033303330333, 0.051545154515451545, 0.07484748474847484, 0.10027002700270027, 0.12742274227422742, 0.15668566856685667, 0.18134813481348136, 0.2065906590659066, 0.23155315531553156, 0.2536753675367537, 0.2786878687868787]
berDfe = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0001500075003752e-05, 0.00012000600030001501, 0.0008200410020501025, 0.002510125506275314, 0.005620281014050703, 0.01328066403320166, 0.025011250562528127, 0.04208210410520526, 0.06203310165508275, 0.08571428571428572, 0.11113555677783889, 0.13959697984899244, 0.16853842692134607, 0.19327966398319915, 0.21867093354667733, 0.24259212960648033, 0.26592329616480825, 0.2927046352317616]

plt.yscale('log')
plt.grid(True)

plt.plot(snr,berShannon, '-o', label='shannon capacity')
plt.plot(snr,berFwdBwd, '-o', label= 'fwdBwd')
plt.plot(snr,berDfe, '-o', label= 'dfe')

plt.legend(loc='best')
plt.show()