Problem with module MPU6050

Posted on
  • Hello ,
    when I save this code on my Pico or EspruiniWiFi :

    1. *I2C1.setup({scl:B8,sda:B9});
    2. var mpu=require(MPU6050);*

    the console return :

    ``` TypeError: Cannot read property 'length' of undefined in MPU6050
    TypeError: Cannot read property 'length' of undefined

    ____ _ | |_ ___ ___ _ ||___ ___ | |_ -| . | _| | | | | . | ||_| || |_|||_|_|

    1. |_| espruino.com 2v00 (c) 2018 G.Williams

    Uncaught SyntaxError: Got '=' expected ',' at line 263 col 65 ...ction(bank, prefetchEnabled=false, userBank=false) {

    1. ^ ```

    I tried other module successfully.
    Is the MPU6050 module a problem?
    Am I missing something?

    Thank you for your help

  • Sat 2019.11.16

    Hi @Ptitonio,

    'I tried other module successfully'

    Which module did you have success with?



    I just checked the sample script:

    http://www.espruino.com/MPU6050

    and it appears there is no binding of the pins for I2C to the MPU6050 using the connect() function. Is all the code actually provided in #1?



    Also, the pin labeling L#1 scl,sda needs another look as the pin numbers are different between devices:

    for instance
    http://www.espruino.com/Pico



    Formatting help suggestion: It appears the reason for the block within the three backticks is not displaying correctly, is that this line 'TypeError: Cannot read property 'length'' needs to start on the next line following the backticks. Both opening and closing backtick group needs to be on its own line.

  • Thank you Robin for your response.

    Good test with the HR-SR04 module :
    https://www.espruino.com/HC-SR04

    Bad test with MPU6050 module :
    https://www.espruino.com/MPU6050

    I did tests on PICO and ESPRUINOWIFI with the same problem.
    (screenshot of tests with ESPRUINOWIFI).

  • screenshots...


    2 Attachments

    • 2019-11-16 22_58_46-Espruino Web IDE.png
    • HC-SR04_ModuleTest.png
  • Has dump() been tried to look for 'undefined' vars? (e.g. is code module loading)

    or try mpu

    Another idea to wrap the code snippet in a try/catch code block to see if errors are occurring that are bubbling up and not caught.



    Take a peek at the WebIDE console output: (the end of the listing)

    WebIDE >> Settings >> Console



    It's possible, but a bit unlikely that upgrading to 2v04 might resolve. (not there yet)



    Was it noticed that the modules require different operational voltages?

    SCL SDA swapped?

    Solid grounding between the Espruino device and the module?

  • Turn off minification. The error on the first screenshot points to prefetchenabled=false in a function signature.
    What version of the IDE you have? I thought the latest IDE can minify all of ES6.

  • Here's the dump()

    dump() var mpu = undefined; I2C1.setup({"scl":B6,"sda":B7}); pinMode(B6, "af_opendrain", true); pinMode(B7, "af_opendrain", true);
    =undefined

    mpu
    =undefined

    I put the minification off (the second red error message disappears).
    I controlled the wiring well.
    I made tests with firmware 1.97, 2.00, 2.02 & 2.04, without success.
    Attached a copy of the console


    1 Attachment

  • Hi AkosLukacs,

    Turn off minification only deletes the message :

    TypeError: Cannot read property 'length' of undefined

    I have Web Ide 0.72.1

    I have also a Espruino IDE Native version 0.69.0 for my MDBT42Q Bluetooth Module.
    I made tests with it on Pico this morning, and COOL ! It works fine ?

    There are some issues with Web Ide 0.72.1

  • Ah, ok, another problem is that the MPU6050 is rather big, there is another recent thread, and
    Gordon's comment solved the size problem in the other thread.

    Oh, and update the Native Ide, might help.

  • I installed Espruino IDE Native version 0.72.1 and it works well with the MPU6050 module.

  • Mon 2019.11.18

    Glad you got it working!

    A bit of confusion in #8, so the Pico is working with Native 0.69.0 then?

    Was it the uploading of modules as functions? (ref Gordon's comment link in #9)

    ... or, ...

    upgrading to IDE Native version 0.72.1? (as indicated in #10)


    'There are some issues with Web Ide 0.72.1'

    What specifically is observed with 'some issues'?

  • Yes Pico (and EspruinoWifi) works when I use IDE Native 0.69.0 (and 0.72.1) to transfert code.
    Its just longer , about 1 mn forthis code :

    1. I2C3.setup({scl:A8, sda:B4, bitrate:100000});
    2. const MPU = require("MPU6050").connect(I2C3);
    3. // 2nd parameter is the fifoRate. The DMP output frequency = 200Hz / (1 + fifoRate)
    4. const DMP = require("MPU6050_DMP").create(MPU, 3);
    5. function pidLoop(args) {
    6. var data = DMP.getData();
    7. if(data !== undefined) console.log(DMP.getYawPitchRoll(data));
    8. }
    9. setWatch(pidLoop, B5, { repeat:true, edge:'rising' });

    No I didn't use the option "Module uploaded as functions". The code is uploaded in RAM .

    When I was doing tests with different IDE, I noticed some strange things. I'm going to synthesize all this in a new post.

  • Here is the result of my tests with 2 IDEs: WEB IDE 0.72.1 and Espruino Native IDE 0.72.1
    I use the same hardware based on PICO, with the following code:

    1. I2C3.setup({scl:A8, sda:B4, bitrate:100000});
    2. const MPU = require("MPU6050").connect(I2C3);
    3. // 2nd parameter is the fifoRate. The DMP output frequency = 200Hz / (1 + fifoRate)
    4. const DMP = require("MPU6050_DMP").create(MPU, 3);
    5. function pidLoop(args) {
    6. var data = DMP.getData();
    7. if(data !== undefined) console.log(DMP.getYawPitchRoll(data));
    8. }
    9. setWatch(pidLoop, B5, { repeat:true, edge:'rising' });

    We see:

    • 1 - WEB IDE without Minification
      An error LOW_MEMORY

    • 2 - Espruino Native IDE without Minification
      No error, Upload ok, working ok

    • 3 - WEB IDE with Minification (Esprima Offline)
      "TypeError" errors on MPU6050 module but not on MPU6050_DM module whose size is 31561 bytes
      A syntax error ...

    • 4 - Espruino Native IDE with Minification (Esprima Offline)
      No error, Upload ok, the size of the module MPU6050_DM = 17182 bytes
      Operation ok

    It's strange the modules do not have the same size.
    Apparently the 2 IDEs do not use the same modules.

  • Screenshoots ...


    4 Attachments

    • 1-Web IDE.png
    • 2-Native IDE.png
    • 3-Web IDE.png
    • 4-Native IDE.png
  • In your IDE's settings (the one with the error), is communications -> Module extensions set to .min.js|.js? That's the default.

    If so the minified modules should already be loaded by default. The length of 31561 you're seeing would only be happening if the IDE was loading the unminified file. Is it possible you changed that setting, or have your own local copy of the module?

    Also, when you mention WEB IDE with Minification (Esprima Offline) - is this the one from espruino.com/ide, or the Chrome Web store? Up to date versions of the IDE should use a newer version of Esprima which I'm pretty sure doesn't have the TypeError issue

  • Gordon ! We are a genie !
    Indeed the setting of Chrome Web store IDE was : .js.|min.j
    Yet I had control over the setting of both IDE.
    I do not remember having modified this parameter on Chrome Web store IDE.
    Now Both of IDE works fine.

    Thanks a lot

    PS: WEB IDE = Chrome Web store IDE

  • Post a reply
    • Bold
    • Italics
    • Link
    • Image
    • List
    • Quote
    • code
    • Preview
    • $ Donate
About

Problem with module MPU6050

Posted by Avatar for Ptitonio @Ptitonio

Actions