GPS Module not sending data on Puck.js #2857
Replies: 22 comments
-
Posted at 2018-08-23 by @gfwilliams Is RX connected to TX and vice-versa? Always worth checking :) However I've noticed that some GPS modules don't output anything at all until they get a lock - so it might be worth leaving the GPS in a window for 10 minutes just to make sure? Otherwise maybe detach the RX and TX wires and put a scope (or even just a LED) on them to see if any data is being sent? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-23 by MobiTech After some time I get this in the console <- Serial1. I also tried changing the wires. It also does not work. The waiting does not help as well. |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-23 by @gfwilliams Are you trying the GPS out while connected to Bluetooth?
If you disconnect the GPS, then short RX and TX together, I bet you'll find that I'd try the LED thing - but if that's flashing about the only other thing could be that the GPS is using a different baud rate (even if 9600 is the default for most GPS systems) |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-23 by @allObjects Use this piece of code to check on GPS's output. Upload and start with entering
The red LED - LED1 - comes on. Then you can probe with a wire connected to the pin the GPS output (TX). If GPS sends something, TX is going low for the start bit and the LED goes out. You can play with the debounce value. Espruino is not fast enough to catch all 9600 baud changes and the event buffer may overflow... but you will get for sure some reaction when the GPS actually sends something. You may also use some other methods of recording what's going on at a pin, such as the way to record the IR remote control signal (see ):
Looking at the times you may even determine the baud rate. (I'm sure you came across my posts about GPS:
Third one - I guess - is not what you are heading for, because this lead me to this question: How do you power the GPS? ...are you using puck's power? ...this could be a reason that the GPS module does not get enough power and puck may even brown out... (when button cell is not fresh anymore). After all, GPS is a bit power hungry when starting... as you can read in the post about powering the GPS by pins in order to be able to shut it down completely... |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-24 by MobiTech The power might be a problem. If the red LED on the GPS module is lighting constantly, the Puck.js delivers Battery level 0. If the GPS module is not connected it delivers a Battery level of 80. So does the puck not have enough power to use a gps module? What is the recommended battery for it? Maybe Varta? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-24 by @allObjects Puck's CR2032 has an average capacity of 225mAh. Capacity is measured with (usually) 10% load, which means, if you draw 22.5mA, it will last 10 hours. In low power / energy context as with Puck, load is even much less and jsut pulsed in order to have a battery last very very long. After capacity is exhausted, voltage collapses practically completely (see datasheet). Since the GPS needs about 60..70mA peak - you may check this with the data sheet of your GPS module - this is way too much to keep power up. You may get 2 (fresh) alkaline AA / AAA batteries and power with them the GPS. This way puck is the only one sitting on the button cell... NOTE: With the GPS powered separately, you need then only three (3) wires between Puck and GPS: GND, RX, TX. To use the code snippets in my previous post - #5 - you need only to connect the GNDs; and the wire on the watching / recording pin you connect to TX of the GPS module.Attachments: |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-24 by MobiTech
Thank you. I am quite new at working with electronic components. Do you have a tutorial how to power the GPS module by a battery? I guess that I have to solder something to the VCC pin? Is there something that I should notice? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-24 by @allObjects If the modules do not have female or male pin headers and there is enough space, I solder those on. then I use a bread board and some wires with combination of female and male connecters on both sides to connect the components and modules. If there is not enough space I cut a wire with pins in half solder the cut end onto the module. The other end of the wire I plug into the bread board... It is also very practical to have a power supply for the board that delivers - in your case 3.3V. Using a DC-DC (buck step down) converter with a USB plug that takes 5V from a USB and produces 3.3V output. On many posts you can see how it's done, for example: Breadboard friendly PICO. If you have not soldered yet, take some scrap things and practice on them. Go to youtube and search for some instructional videos. Attachments: |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-24 by @gfwilliams The module (if it's this one? https://www.openimpulse.com/blog/products-page/product-category/gy-neo6mv2-gps-module/) says it supports input voltages of between 3 and 5v - so you could attach:
Just be careful not to connect VCC to Puck.js as well - Puck.js only supports input voltages between 2 and 3.6v. If you want to connect both to the same power supply you'd do best to use a regulated 3.3v supply that you can then power from anything within the power supply's input range. |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-24 by @gfwilliams Just to add to this, if you use something like the MDBT42 Breakout or Pixl.js then those have 3.3v regulators inside already - so you could wire them up and they could power the GPS from whatever power source you decided to use for them. |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-26 by MobiTech Do I have to solder a battery holder like this (https://shop.pimoroni.de/products/battery-holder-3xaa-with-cover-and-switch?utm_medium=cpc&utm_source=googlepla&variant=19618738116&gclid=Cj0KCQjwn4ncBRCaARIsAFD5-gVPMPQg-Hr6TeOP63dCP3NIcx_pjwnf5qXUCgWFh1-4kTcRJSXkzfEaArLhEALw_wcB) to the GPS module? Red cable to vcc and black cable to GND? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-26 by @allObjects That works well... I have one of these too... and the ON/OFF switch is a great bonus. I do not know the purpose of your project and the overall setup... but "Gehaeuse mit AA Batteriefach" could work as well... or a plain box and simple batterie holder for 3 batteries so you can all fit in a single box (w/ or w/o cutout for accessing/exposing puck. |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-29 by MobiTech After connecting the GPS module to a battery box the connection to the puck works.
Any idea how to fix that? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-29 by @gfwilliams Just put it near the window and wait a few minutes. GPS can take a while to get a lock. The GPS on your phone gets helped along a bit my the cellular network (providing time & rough location), but a standalone one can't assume anything, so it takes a bit longer. |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-29 by @allObjects If you cannot find an enclosure with separate battery compartment, you may us a battery box for more cells than you need and use the superfluous for your electronics... similar to what you find in this publication. Regarding the time to find first and subsequent fixes / satellites, you may even need to move the GPS antenna/receiver close to a window/onto the window sill with free sight of some sky. When had my GPS 6M receiver not on the window sill/somewhere in the middle of the, it sometimes did not even find a single satellite.Attachments: |
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by RolandGalibert Can I ask if you guys ever resolved this? I'm having the same trouble MobiTech did in the original post.
|
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by @allObjects Since @mobitech went silent, we can assume it got resolved for him... because post #14 is what you get until the gps could find fixes... (good enough reception over time to make sound calculations...). In your case - assuming GND and RX(Puck)-TX(GPS) are reliably connected and baud rate is matching, you should get at least what you see in post #4. To check if gps module gets some data from gps, you can enter Btw, the GPS most likely send more than just the "GGA Sentence". Each line it sends has some identifier about the content and the module out of the box gives you only the GGA Sentence. If your GPS is for what ever reason differently configured / does not send this sentence, nothing will ever come out of the module... :\ |
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by @gfwilliams Just to elaborate on @allObjects post as I'm not sure it's that clear:
You mentioned in your post that you're getting some data on You could also try:
Which will print out all data that was received - whether it's a valid GPS line or not. Might be handy for debugging? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by RolandGalibert Hi Gordon - Thanks, I did have my wires crossed, literally. I think I'm close to success, now in the console I'm getting a steady stream of Data[object Object] When I run your debugging solution (last code example in your last post), I do appear to be getting correct data, it's a steady stream of a lot of (JSON?) data, and some of them look like GPS readings. Could you please tell me how to fix the Data[object Object] to make it look more like actual data? |
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by @allObjects @gfwilliams , if data is mangled, then the sentence coming from GPS device is not what GPS module expects and parser goes high wire. @user97706 , take a look at GPS Module, Extensions for handling other sentences, and u-blox NEO-6M GPS receiver, especially post #3, that shows all what (my) GPS (at that time) sends (/sent). |
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by RolandGalibert Please disregard my last post, everything's working now. For some reason the string "DATA" in the original code was causing Data[object Object] output; I deleted the string and am now getting good results (thanks for all your help). A quick question (again, I'm a complete newbie): Why is it important to connect the ground of the GPS module to the ground of the puck? (I did do that, just wondering why it's important : ) |
Beta Was this translation helpful? Give feedback.
-
Posted at 2019-02-11 by @gfwilliams Ahh - thanks! I just modified the posts above to use
It's just a general electrical thing. Voltage is relative - imagine you're trying to measure the voltage on a battery - you need to connect both ends of it to the volt meter - just one isn't enough. So in pretty much all digital electronics, to make things easier you just connect all the grounds together, so that always sorts out one side of the connection and then you just worry about the signal wires. |
Beta Was this translation helpful? Give feedback.
-
Posted at 2018-08-23 by MobiTech
Hello,
I bought the GPS Module Ublox Neo 6m (GY-NEO6MV2).
Then I connected it the following way to the Puck.js:
GPS Module -> Puck.js
RX -> D28
TX -> D29
VCC -> 3V
GND -> GND
The red LED on the GPS module is lighting.
After that I wrote a small program:
Unfortunately there is no output in the console. Doe you have any idea what could be wrong? Are there methods to check what might cause this problem?
Beta Was this translation helpful? Give feedback.
All reactions