-
Notifications
You must be signed in to change notification settings - Fork 0
/
piimu.py.save
88 lines (63 loc) · 2.26 KB
/
piimu.py.save
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import smbus
from time import sleep
import WirelessTool, colorama, traceback
mainServer = WirelessTool.TCPClient('127.0.0.1',3000,0.1)
PWR_MGMT_1 = 0x6B
SMPLRT_DIV = 0x19
CONFIG = 0x1A
GYRO_CONFIG = 0x1B
INT_ENABLE = 0x38
ACCEL_XOUT_H = 0x3B
ACCEL_YOUT_H = 0x3D
ACCEL_ZOUT_H = 0x3F
GYRO_XOUT_H = 0x43
GYRO_YOUT_H = 0x45
GYRO_ZOUT_H = 0x47
def MPU_Init():
#write to sample rate register
bus.write_byte_data(Device_Address, SMPLRT_DIV, 7)
#Write to power management register
bus.write_byte_data(Device_Address, PWR_MGMT_1, 1)
#Write to Configuration register
bus.write_byte_data(Device_Address, CONFIG, 0)
#Write to Gyro configuration register
bus.write_byte_data(Device_Address, GYRO_CONFIG, 24)
#Write to interrupt enable register
bus.write_byte_data(Device_Address, INT_ENABLE, 1)
def read_raw_data(addr):
#Accelero and Gyro value are 16-bit
high = bus.read_byte_data(Device_Address, addr)
low = bus.read_byte_data(Device_Address, addr+1)
#concatenate higher and lower value
value = ((high << 8) | low)
#to get signed value from mpu6050
if(value > 32768):
value = value - 65536
return value
bus = smbus.SMBus(1)
Device_Address = 0x68 # MPU6050 device address
MPU_Init()
while True:
try:
acc_x = read_raw_data(ACCEL_XOUT_H)
acc_y = read_raw_data(ACCEL_YOUT_H)
acc_z = read_raw_data(ACCEL_ZOUT_H)
gyro_x = read_raw_data(GYRO_XOUT_H)
gyro_y = read_raw_data(GYRO_YOUT_H)
gyro_z = read_raw_data(GYRO_ZOUT_H)
Ax = float("{0:.2f}".format(acc_x/16384.0))
Ay = float("{0:.2f}".format(acc_y/16384.0))
Az = float("{0:.2f}".format(acc_z/16384.0))
Gx = float("{0:.2f}".format(gyro_x/131.0))
Gy = float("{0:.2f}".format(gyro_y/131.0))
Gz = float("{0:.2f}".format(gyro_z/131.0))
bun = str(Ax)+','+str(Ay)+','+str(Az)+','+str(Gx)+','+str(Gy)+','+str(Gz)
# print bun
#print "Ax:",Ax," Ay:",Ay," Az:",Az," Gx:",Gx," Gy:",Gy," Gz:",Gz
sleep(1)
mainServer.write('i1'+bun+'\t')
except BaseException as e:
print(colorama.Fore.RED + '[ERROR]\t' + colorama.Style.RESET_ALL + e.message)
print(colorama.Fore.RED + '[ERROR]\t' + colorama.Style.RESET_ALL + traceback.format_exc())
mainServer.close()
break