GPIO で DSLR を RPi に接続しました。I2Cを使用してMPU6050からRPiへ。カメラのシャッター ボタンを押したときに、ジャイロと加速度計のデータを短い時間枠 (通常は 50 ミリ秒未満) で記録しようとしています。希望するサンプリング レートは 500Hz から 1000Hz の間です。また、FIFO を使用してセンサー データを一時的に保存します。
現在の問題は、コードが時々オーバーサンプリングすることです (理論値と比較して大きなオフセット)。たとえば、500Hz を 100ms に設定した場合、50 サンプルを期待していましたが、62 サンプルでした。カメラを同期せずに MPU6050 を実行している場合、この問題は発生しません。
また、私は混乱しています
Status = mpu6050.readStatus()
if (Status & 0x10) == 0x10 :
print "Overrun Error! Quitting.\n"
為に?
誰かが助けてくれれば本当にありがたいです。ありがとう!
Python コード:
import datetime
import MPU6050
import math
import time
import numpy
import RPi.GPIO as GPIO
import time
import sys
GPIO.setmode(GPIO.BCM)
TargetSampleTime= 20 #int(sys.argv[1])
TargetRate= 500 #float(sys.argv[2])
GPIO.setup(24,GPIO.IN,pull_up_down=GPIO.PUD_DOWN)
mpu6050 = MPU6050.MPU6050()
mpu6050.setup()
mpu6050.setGResolution(2)
mpu6050.setSampleRate(TargetRate)
mpu6050.enableFifo(False)
time.sleep(0.01)
print "Capturing in {0} ms at {1} samples/sec".format(TargetSampleTime, mpu6050.SampleRate)
mpu6050.resetFifo()
mpu6050.enableFifo(True)
time.sleep(0.01)
Values = []
Total = 0
def my_callback(channel):
print "Rising edge detected on 24"
GPIO.remove_event_detect(24)
GPIO.cleanup()
a = datetime.datetime.now()
# read MPU6050 from FIFO
while True:
Values.extend(mpu6050.readDataFromFifo())
b = datetime.datetime.now()
dt = int((b-a).microseconds/1000)
if dt >= TargetSampleTime:
break;
b = datetime.datetime.now()
Total = len(Values)/14
print "Capture in {0} ms".format((b-a).microseconds/1000)
print "Captured {0} samples".format(Total)
if Total > 0:
Status = mpu6050.readStatus()
if (Status & 0x10) == 0x10 :
print "Overrun Error! Quitting.\n"
quit()
# writing IMU data to txt
print "Saving RawData.txt file."
FO = open("RawData.txt","w")
FO.write("GT\tGx\tGy\tGz\tTemperature\tGyrox\tGyroy\tGyroz\n")
fftdata = []
for loop in range (Total):
SimpleSample = Values[loop*14 : loop*14+14]
I = mpu6050.convertData(SimpleSample)
CurrentForce = math.sqrt( (I.Gx * I.Gx) + (I.Gy * I.Gy) +(I.Gz * I.Gz))
fftdata.append(CurrentForce)
FO.write("{0:6.3f}\t{1:6.3f}\t{2:6.3f}\t{3:6.3f}\t".format(CurrentForce, I.Gx , I.Gy, I.Gz))
FO.write("{0:5.1f}\t{1:6.3f}\t{2:6.3f}\t{3:6.3f}\n".format(I.Temperature,I.Gyrox,I.Gyroy,I.Gyroz))
FO.close()
quit()
# detect shutter button press
GPIO.add_event_detect(24, GPIO.RISING, callback=my_callback, bouncetime=100)
raw_input("Listening...")