Junichi Katsu
/
Grove_Accelerometer
GROVE - 3軸加速度センサ サンプルプログラム
Fork of TestCode_MMA7660FC by
main.cpp@2:152191e37eb1, 2012-07-05 (annotated)
- Committer:
- edodm85
- Date:
- Thu Jul 05 17:48:44 2012 +0000
- Revision:
- 2:152191e37eb1
- Parent:
- 1:78138640bd0e
Rev 3
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
edodm85 | 0:a006e8002089 | 1 | /* Author: Edoardo De Marchi |
edodm85 | 0:a006e8002089 | 2 | * Name: Test Code for MMA7660FC |
edodm85 | 0:a006e8002089 | 3 | */ |
edodm85 | 0:a006e8002089 | 4 | #include "mbed.h" |
edodm85 | 0:a006e8002089 | 5 | #include "MMA7660FC.h" |
edodm85 | 0:a006e8002089 | 6 | |
edodm85 | 1:78138640bd0e | 7 | #define ADDR_MMA7660 0x98 // I2C SLAVE ADDR MMA7660FC |
edodm85 | 0:a006e8002089 | 8 | |
edodm85 | 1:78138640bd0e | 9 | MMA7660FC Acc(p28, p27, ADDR_MMA7660); //sda, scl, Addr |
edodm85 | 0:a006e8002089 | 10 | Serial pc(USBTX, USBRX); |
edodm85 | 0:a006e8002089 | 11 | |
edodm85 | 0:a006e8002089 | 12 | |
edodm85 | 0:a006e8002089 | 13 | float G_VALUE[64] = {0, 0.047, 0.094, 0.141, 0.188, 0.234, 0.281, 0.328, 0.375, 0.422, 0.469, 0.516, 0.563, 0.609, 0.656, 0.703, 0.750, 0.797, 0.844, 0.891, 0.938, 0.984, 1.031, 1.078, 1.125, 1.172, 1.219, 1.266, 1.313, 1.359, 1.406, 1.453, -1.500, -1.453, -1.406, -1.359, -1.313, -1.266, -1.219, -1.172, -1.125, -1.078, -1.031, -0.984, -0.938, -0.891, -0.844, -0.797, -0.750, -0.703, -0.656, -0.609, -0.563, -0.516, -0.469, -0.422, -0.375, -0.328, -0.281, -0.234, -0.188, -0.141, -0.094, -0.047}; |
edodm85 | 0:a006e8002089 | 14 | |
edodm85 | 0:a006e8002089 | 15 | |
edodm85 | 0:a006e8002089 | 16 | |
edodm85 | 0:a006e8002089 | 17 | int main() |
edodm85 | 0:a006e8002089 | 18 | { |
edodm85 | 0:a006e8002089 | 19 | |
edodm85 | 0:a006e8002089 | 20 | Acc.init(); // Initialization |
edodm85 | 0:a006e8002089 | 21 | pc.printf("Value reg 0x06: %#x\n", Acc.read_reg(0x06)); // Test the correct value of the register 0x06 |
edodm85 | 0:a006e8002089 | 22 | pc.printf("Value reg 0x08: %#x\n", Acc.read_reg(0x08)); // Test the correct value of the register 0x08 |
edodm85 | 0:a006e8002089 | 23 | pc.printf("Value reg 0x07: %#x\n\r", Acc.read_reg(0x07)); // Test the correct value of the register 0x07 |
edodm85 | 0:a006e8002089 | 24 | |
edodm85 | 0:a006e8002089 | 25 | while(1) |
edodm85 | 0:a006e8002089 | 26 | { |
edodm85 | 1:78138640bd0e | 27 | float x=0, y=0, z=0; |
edodm85 | 0:a006e8002089 | 28 | |
edodm85 | 2:152191e37eb1 | 29 | Acc.read_Tilt(&x, &y, &z); // Read the acceleration |
edodm85 | 1:78138640bd0e | 30 | pc.printf("Tilt x: %2.2f degree \n", x); // Print the tilt orientation of the X axis |
edodm85 | 1:78138640bd0e | 31 | pc.printf("Tilt y: %2.2f degree \n", y); // Print the tilt orientation of the Y axis |
edodm85 | 1:78138640bd0e | 32 | pc.printf("Tilt z: %2.2f degree \n", z); // Print the tilt orientation of the Z axis |
edodm85 | 0:a006e8002089 | 33 | |
edodm85 | 1:78138640bd0e | 34 | wait_ms(100); |
edodm85 | 1:78138640bd0e | 35 | |
edodm85 | 2:152191e37eb1 | 36 | pc.printf("x: %1.3f g \n", G_VALUE[Acc.read_x()]); // Print the X axis acceleration |
edodm85 | 2:152191e37eb1 | 37 | pc.printf("y: %1.3f g \n", G_VALUE[Acc.read_y()]); // Print the Y axis acceleration |
edodm85 | 2:152191e37eb1 | 38 | pc.printf("z: %1.3f g \n", G_VALUE[Acc.read_z()]); // Print the Z axis acceleration |
edodm85 | 0:a006e8002089 | 39 | pc.printf("\n"); |
edodm85 | 1:78138640bd0e | 40 | wait(5); |
edodm85 | 0:a006e8002089 | 41 | |
edodm85 | 0:a006e8002089 | 42 | } |
edodm85 | 0:a006e8002089 | 43 | } |
edodm85 | 0:a006e8002089 | 44 |