-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Read data from DMP #1
Comments
I'm looking into it. Right now I'm struggling to find any clear instrutions for this specific chip detailing how to upload and use the DMP firmware and any DMP-related registers - bar the one that has the DMP_EN bit - are simply missing from the ICM 20948 datasheet. Looking at the eMD SmartMotion code reveals a lot of registers which fit into the gaps left in said datasheet, so I feel like I'm on the right path. Unfortunately the SmartMotion code is an enterprisey spaghetti mess that's not easy to decypher. The setup process seems to involve flashing some 16Kb proprietary binary firmware blob over i2c, which is a fun start. |
Really glad to hear this! Had a feeling it would be a total mess... Keep us updated please!
|
Just wanted to share what I have learned after contacting Invensense. The DMP is an FPGA that comes up brain dead and must be programmed with a proprietary binary image before it is useable. Examples can be found here but you must register then get permission to perform the downloads. I downloaded several and the one labeled "ICM-20948 v1.0 for Nucleo Board" seems to be the easiest to understand. But be warned, this is not easy. I decided for my project I'm just going to read the raw Accel/Gyro/Mag data and compute my own fusion with the algorithm here. |
Initializing the DMP is relatively easy, this is the code I have (part of a bigger piece of code, so hopefully it's clear enough), let me know if you want more info I'm still working on offloading the data from the DMP, but I'm pretty sure that this Arduino code should be adaptable easily enough along with the documentation, it's for the previous version MPU-9250 that should be mostly compatible, other than the DMP being 6 degrees of freedom rather than 9 degrees of freedom SparkFun_MPU-9250-DMP_Arduino_Library
Where _acc is the bus interface, that for a I2C connection is defined as:
|
I don't have the bandwidth right now to push all the way to a working DMP, but if someone is willing to help with the next step, I can put in some work to merge my DMP initialization code |
I am currently writing a driver for the ICM20948. I've gotten to the point where all 9DOFs are working. The only big problem still remaining is the internal DMP for sensor fusion. |
I guess that you have already downloaded the C SDK from the Tdk invensense website? It's not a very nice code to read but it allows using the DMP. This repository is an implementation reusing this code, adapting it from the STM32 board used in the SDK to arduino like. It works but is missing the output rate/ODR configuration in order to set the ODR to something else than the default 5HZ. |
The missing code to set the ODR should be along the lines of: rc = inv_icm20948_set_sensor_period(&icm_device, idd_sensortype_conversion(INV_SENSOR_TYPE_LINEAR_ACCELERATION), ); |
The SDK code should be trusted for the logic of how to initialise this sensor, and then read values ou of the DMP, the datasheet only for the units, as quite vague and incomplete otherwise. If you compare it with the bosch hillcrest BNO080 in comparison, and also realise that the code is in github, really clear and regularly maintained, it makes one wonder why invensense is so lazy. They probably don't care about the makers market, only the big firms like phone manufacturers. I guess this is also why the BNO80 is twice the price. But as far as I'm concerned i wasted so much time trying to leverage the ICM20948 that I'd rather pay yhe price and then focus on writing my application logic rather than a driver that should be provided with the sensor. |
I don't use Arduino at all. The library I'm writing is a generic one which is platform independent and written in C++. I will take a closer look at the C SDK software and I's "arduinofied" version. Thank you @romatou18 for your input. If I manage to get it working will make it public. |
The invensense code exposes a generic interface called Serif. An object that implements i2C or SPI bus hardware abstraction layer. You're talking about a couple dozen lines of implementation at most. So if wanting to implement a generic lib, i suggest to take a look at the SDK and the arduinoified version in ericalbers' github. This way you'll easily identify how to implement that object. And yes a c++ lib would be great. Something maintainable and readable, something invensense is not excelling at obviously! |
Last but not least, Silicon labs has done a c++ driver that's found in mbed OS. The code does not implement the DMP but implements the sensor init and config in a very clear way. It's help me understand the TDK SDK mess, and from there depve into the DMP stuff. |
Does anybody have an idea what this blob of data means? |
Yup, this is the DMP firmware. It gets flashed into the chip on initialisation. Bith the MPU9250 and ICM20948 works this way. If you track the #include of that file it will appear clearly. |
The blob is the firmware. The code I posted (python) shows how to load it into the sensor. The spec sheet barely mentioned the DMP and says nothing about how to use it. You have to dig through the mess of code in the SDK which has so many abstraction layers that it's nearly impossible to follow. If I managed to follow it, you have to read the DMP through the FIFO, you cannot read it directly, and then there is a whole pile of math to translate what it outputs into quaternions. I need to dig back into it at some point and see if there is some clear code for the MPU9250 with it's simpler DMP to see if that might be used for bootstrapping the code. |
I'm currently writing a library for the ICM20948 and had a meeting with a sales engineer from TDK. He basically said what pidloop commented, that the DMP is a 14 kB, very powerful and complex FPGA. I was also told to use the DK-20948 project from the TDK Developer's Corner since it's the most updated, even though I'm using a nucleo board (they have a specific nucleo library). It's still just a massive project with not great documentation, but I have found some things not listed on datasheet (such as the max FIFO burst is 16 bytes). |
I'm glad people are still chipping away at this nightmare- thank you! I have started using the icm20948 in an illuminated-chair project and am finding integrating gyro data to be an uncompromising pain. I may find that it's easier for me to spend time figuring out the DMP than it is figuring out how to compensate sensors manually. |
@Gadgetoid What microprocessor/dev. workbench are you using? |
@polymurph in this case a full Pi Zero, code written in Python and using this very library. Actually right now I only have an old mpu9250 to hand so I wont be making any progress on this for a few weeks. |
Probably the biggest sticking point for getting this up and running in a way that anyone has a hope of reproducing, is being able to ship the binary firmware that's flashed to the DMP. @venumuz assuming you intend to ship your library, did you get any idea how amenable TDK would be to distributing the blob? |
I think they'd be fine since you can download it from their website but I never asked. I eventually decided that creating my own library for the basic functionalities we needed was a lot easier than trying to understand it (we basically just needed gyro/accel/magnetometer raw data). |
@oziqus However this certainly hasn't stopped I think @laughingrice has given pretty detailed instructions for the flashing process, but that doesn't get us meaningful data out. Changing the |
If you're looking for a working DMP with ready to go code, you're in exactly the wrong place 😆 This whole thread is slow progress toward trying to make it work. |
@oziqus Can you share the examples of getting DMP data in python that you have found ? |
If anyone can use this, got approval to make this piece of code public (wrote it some time ago for someone), it does not include reading DMP data yet, but does have the code for loading the DMP firmware. The project might be picked up again so might be able to allocate some time to have another look Currently supports reading out the raw data over either SPI or I2C, I did not explore utilizing the FIFO or DMP yet. |
Stumbling upon this as I've recently purchased the ICM20948 for the DMP feature. Sadly, it seems needlessly difficult to gain access to. By posting this, I hoped to determine if any of you in this chat made progress. I'm able to upload the firmware, but it's not clear (1) if it was successful and (2) what registers to poke to retrieve the orientation data I'm interested in. Thanks! |
Hello pimoroni team,
I would like to ask if there are any plans to enable DMP and read orientation data from this device, using this library, if possible! It will be for me the most amazing feature and a take-my-money move!
Thank you in advance.
The text was updated successfully, but these errors were encountered: