diff options
Diffstat (limited to 'tmk_core/tool/mbed/mbed-sdk/libraries/tests/mbed/i2c_MMA8451Q/main.cpp')
-rw-r--r-- | tmk_core/tool/mbed/mbed-sdk/libraries/tests/mbed/i2c_MMA8451Q/main.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/tmk_core/tool/mbed/mbed-sdk/libraries/tests/mbed/i2c_MMA8451Q/main.cpp b/tmk_core/tool/mbed/mbed-sdk/libraries/tests/mbed/i2c_MMA8451Q/main.cpp new file mode 100644 index 0000000000..2e17aea5a4 --- /dev/null +++ b/tmk_core/tool/mbed/mbed-sdk/libraries/tests/mbed/i2c_MMA8451Q/main.cpp @@ -0,0 +1,56 @@ +#include "mbed.h" +#include "MMA8451Q.h" +#include "test_env.h" + +#ifdef TARGET_KL05Z +#define SDA PTB4 +#define SCL PTB3 + +#elif TARGET_K20D50M +#define SDA PTB1 +#define SCL PTB0 + +#else +#define SDA PTE25 +#define SCL PTE24 +#endif + +namespace { + const int MMA8451_I2C_ADDRESS = 0x1D << 1; // I2C bus address + const float MMA8451_DIGITAL_SENSITIVITY = 4096.0; // Counts/g +} + +float calc_3d_vector_len(float x, float y, float z) { + return sqrt(x*x + y*y + z*z); +} + +#define TEST_ITERATIONS 25 +#define TEST_ITERATIONS_SKIP 5 +#define MEASURE_DEVIATION_TOLERANCE 0.025 // 2.5% + +int main(void) { + MBED_HOSTTEST_TIMEOUT(15); + MBED_HOSTTEST_SELECT(default_auto); + MBED_HOSTTEST_DESCRIPTION(MMA8451Q accelerometer); + MBED_HOSTTEST_START("KL25Z_5"); + + DigitalOut led(LED_GREEN); + MMA8451Q acc(SDA, SCL, MMA8451_I2C_ADDRESS); + bool result = true; + printf("WHO AM I: 0x%2X\r\n\n", acc.getWhoAmI()); + + for (int i = 0; i < TEST_ITERATIONS; i++) { + if (i < TEST_ITERATIONS_SKIP) { + // Skip first 5 measurements + continue; + } + const float g_vect_len = calc_3d_vector_len(acc.getAccX(), acc.getAccY(), acc.getAccZ()) / MMA8451_DIGITAL_SENSITIVITY; + const float deviation = fabs(g_vect_len - 1.0); + const char *succes_str = deviation <= MEASURE_DEVIATION_TOLERANCE ? "[OK]" : "[FAIL]"; + result = result && (deviation <= MEASURE_DEVIATION_TOLERANCE); + printf("X:% 6d Y:% 6d Z:% 5d GF:%0.3fg, dev:%0.3f ... %s\r\n", acc.getAccX(), acc.getAccY(), acc.getAccZ(), g_vect_len, deviation, succes_str); + wait(0.5); + led = !led; + } + MBED_HOSTTEST_RESULT(result); +} |