我想绘制一个具有2个数组的图,但它不起作用...输出显示“ ValueError:x和y必须具有相同的第一维,但形状为(50,)和(10,)”...。 ................................................... ................................................... ................................................... ................................................... ...
非常感谢你!
import numpy as np
import matplotlib.pyplot as plt
p = float(input("Introduzca probabilidad de error de bit: "))
while p < 0 or p > 1:
p = float(input("Introduzca probabilidad de error de bit: "))
n = int(input("Introduzca número de bits: "))
while n < 0:
n = int(input("Introduzca número de bits: "))
q = 1-p
pexito = q**n
intentos = 1/pexito
print()
print("El número medio de intentos es:",intentos)
print()
print("La probabilidad de transmitir correctamente",n,"bits es:",pexito)
listapmf = []
listacdf = []
for i in range(n):
pmf = (p**(n-1))*q
listapmf.append(pmf)
for j in range(n):
cdf = 1-(p**n)
listacdf.append(cdf)
arraycdf = np.array(listacdf)
arraypmf = np.array(listapmf)
x1 = np.linspace(0.0, n)
x2 = np.linspace(0.0, n)
plt.subplot(2, 1, 2)
plt.plot(x1, arraypmf, '.-')
plt.title('Intentos de transmisión en base a una probabilidad de error de bit')
plt.ylabel('PMF')
plt.subplot(2, 1, 1)
plt.plot(x2, arraycdf, '.-')
plt.xlabel('Intentos')
plt.ylabel('CDF')
plt.show()
您需要修正定义x1
和x2
的方式。 np.linspace()
的默认值是将传递的值分成50个值。我不确定您的期望是什么,但这也许行得通吗? (从功能上来说,它确实可以100%工作,但不确定是否是您打算使用的逻辑)
错误:
x1 = np.linspace(0.0, n) <-- Split values between 0 and n in 50 values
x2 = np.linspace(0.0, n) <-- Same
更改为:
x1 = np.linspace(0.0, 1, num = n)
x2 = np.linspace(0.0, 1, num = n)