我想绘制一些数据.第一列包含x数据.但matplotlib没有绘制这个.我的错误在哪里?
import numpy as np
from numpy import cos
from scipy import *
from pylab import plot, show, ylim, yticks
from matplotlib import *
from pprint import pprint
n1 = 1.0
n2 = 1.5
#alpha, beta, intensity
data = [
[10, 22, 4.3],
[20, 42, 4.2],
[30, 62, 3.6],
[40, 83, 1.3],
[45, 102, 2.8],
[50, 123, 3.0],
[60, 143, 3.2],
[70, 163, 3.8],
]
for i in range(len(data)):
rhotang1 = (n1 * cos(data[i][0]) - n2 * cos(data[i][1]))
rhotang2 = (n1 * cos(data[i][0]) + n2 * cos(data[i][1]))
rhotang = rhotang1 / rhotang2
data[i].append(rhotang) #append 4th value
pprint(data)
x = data[:][0]
y1 = data[:][2]
y3 = data[:][3]
plot(x, y1, x, y3)
show()
Run Code Online (Sandbox Code Playgroud)
编辑:http://paste.pocoo.org/show/205534/ 但它不起作用.
您可以通过将数据转换为numpy数组来完成此操作:
data = np.array(data) # insert this new line after your appends
pprint(data)
x = data[:,0] # use the multidimensional slicing notation
y1 = data[:,2]
y3 = data[:,3]
plot(x, y1, x, y3)
Run Code Online (Sandbox Code Playgroud)
还有几点:
您可以使用numpy以更清晰和矢量化的方式进行计算,就像这样
data = np.array(data)
rhotang1 = n1*cos(data[:,0]) - n2*cos(data[:,1])
rhotang2 = n1*cos(data[:,0]) + n2*cos(data[:,1])
y3 = rhotang1 / rhotang2
Run Code Online (Sandbox Code Playgroud)
正如你所写的,你的计算可能不会给你想要的东西,因为cos
等等以弧度为输入,你的数字看起来像度.
归档时间: |
|
查看次数: |
12360 次 |
最近记录: |