Последние 2 дня я пытался запустить следующий скрипт на Python, который требует matplotlib для построения данных в реальном времени с датчика, но безуспешно.
#!/usr/bin/python
import smbus
import math
import matplotlib as mpl
mpl.use('tkagg')
import matplotlib.pyplot as plt
# Power management registers
power_mgmt_1 = 0x6b
power_mgmt_2 = 0x6c
incl = []
plt.ion
def makefig():
plt.plot(incl,'ro-')
def read_byte(adr):
return bus.read_byte_data(address, adr)
def read_word(adr):
high = bus.read_byte_data(address, adr)
low = bus.read_byte_data(address, adr+1)
val = (high << 8) + low
return val
def read_word_2c(adr):
val = read_word(adr)
if (val >= 0x8000):
return -((65535 - val) + 1)
else:
return val
def dist(a,b):
return math.sqrt((a*a)+(b*b))
def get_y_rotation(x,y,z):
radians = math.atan2(x, dist(y,z))
return -math.degrees(radians)
def get_x_rotation(x,y,z):
radians = math.atan2(y, dist(x,z))
return math.degrees(radians)
bus = smbus.SMBus(1) # or bus = smbus.SMBus(1) for Revision 2 boards
address = 0x68 # This is the address value read via the i2cdetect command
while True:
# Now wake the 6050 up as it starts in sleep mode
bus.write_byte_data(address, power_mgmt_1, 0)
gyro_xout = read_word_2c(0x43)
gyro_yout = read_word_2c(0x45)
gyro_zout = read_word_2c(0x47)
#print ("gyro_xout: ", gyro_xout, " scaled: ", (gyro_xout / 131))
#print ("gyro_yout: ", gyro_yout, " scaled: ", (gyro_yout / 131))
#print ("gyro_zout: ", gyro_zout, " scaled: ", (gyro_zout / 131))
accel_xout = read_word_2c(0x3b)
accel_yout = read_word_2c(0x3d)
accel_zout = read_word_2c(0x3f)
accel_xout_scaled = accel_xout / 16384.0
accel_yout_scaled = accel_yout / 16384.0
accel_zout_scaled = accel_zout / 16384.0
#print ("accel_xout: ", accel_xout, " scaled: ", accel_xout_scaled)
#print ("accel_yout: ", accel_yout, " scaled: ", accel_yout_scaled)
#print ("accel_zout: ", accel_zout, " scaled: ", accel_zout_scaled)
#my_incl = (get_x_rotation(accel_xout_scaled, accel_yout_scaled, accel_zout_scaled))
#incl.appned(my_incl)
#drawnow(makefig)
#plt.pause(0.00001)
# print ("x rotation: " , '{0:.0f}'.format(my_incl))
#print ("y rotation: " , get_y_rotation(accel_xout_scaled, accel_yout_scaled, accel_zout_scaled))
При выполнении вышеизложенного я получаю следующую ошибку от numpy:
RuntimeError: модуль скомпилирован с версией API 0xc, но эта версия numpy - 0xa
Traceback (последний вызов был последним):
Файл "/home/pi/Desktop/car/car.py", строка 7, в
импортировать matplotlib.pyplot как plt
Файл "/usr/local/lib/python3.5/dist-packages/matplotlib/pyplot.py", строка 32, в
импорт matplotlib.colorbar
Файл "/usr/local/lib/python3.5/dist-packages/matplotlib/colorbar.py", строка 28, в
импорт matplotlib.artist в качестве мартиста
Файл "/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py", строка 11, в
из пути импорта .path
Файл "/usr/local/lib/python3.5/dist-packages/matplotlib/path.py", строка 17, в
от . import _path, rcParams
ImportError: не удалось импортировать numpy.core.multiarray
Мне кажется, что у меня неправильная версия numpy.
Но все же после обновления numpy, деинсталляции, переустановки, поиска помощи здесь и т. Д. (Не все при одной попытке, каждая как отдельная попытка) Я все еще не знаю, как это исправить ...
Любая помощь будет наиболее ценной.