-
Notifications
You must be signed in to change notification settings - Fork 20
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
Make KBox repeat all NMEA/NMEA2000 messages to USB port #128
Conversation
- New USB mode active when the connection speed is set to 38400 bauds - In this mode all NMEA and NMEA2000 messages are repeated to USB - Removed KMessage/KMessageNMEAVisitor - they are not needed anymore - Make sure we read data from serial port in that mode to avoid the serial port locking up on Raspberry Pi (closes #68) - Also convert SerialK data to NMEA and output it (this provides an output for internal sensors but may result in duplicated data)
@sarfata
Would be nice to have it by config settings? edit 24/2/18:
In "my KBox" I made a config to enable/disable:
(But too many PR's pending, so I wait with pushing.) |
Need to calibrate IMU before it starts showing output on wifi or usb |
in ditto in line 101: |
as all datas from NMEA2000 and Serial are "repeated" AND coming from the Hub as SKUpdates aren´t they all duplicated? |
@sarfata I could imagine to extend the SKHub to do one central conversion for each format needed there. In principle all high frequency datas could run through a filter. I plan to move Performance calculations to SKHub too, as this is the central object where all datas come together. For sentences where mixed SKUpdates are necessary I think it is the right class too, to have variables there for storing. Especially for the WiFiService it will be positive to subscribe to "display" datas, because at the moment when you have NMEA2000 coming in, together with an external (10Hz) NMEA0183 IMU-Sensor plus internal barometer plus voltage the WiFi is freaking out. The same I am afraid will happen to logging too, as I cannot believe that all those datas could be written to SD-Card. |
@sarfata @ronzeiller |
@sarfata @ronzeiller |
Hi Ron, the IMU sensor has (internal) calibration values for accel, gyro, magnetic and an over all "system"
But values will only be sent (e.g. NMEA to serial, if enabled) if following conditions are true:
Just made an update to PR #124 Now you should see on the IMU page if values are sent or not. |
Yeah, the great thing with Kbox firmware is, that you can configure it as a simple logging device (without any sensors or display), as NMEA0183 Multiplexer (which I believe is more or less your demand) or as performance sailing computer. There where so many great changes in the last month, but no time at all to do a proper documentation, data flow diagrams, "how to" - descriptions etc. |
@sarfata @ronzeiller |
Yeah, meanwhile I have a whole book of notes too :-) Remark: Remark to documentation: |
RonZ, |
Hey guys, Thomas here back from sailing for a little bit ;) Thanks for the great feedback on this. I understand that it was not clear that you just need to connect at 38400 bauds but now that you have both understood that, I think you like this and I will merge it. @ronzeiller Thanks for putting that diagram together. That is super interesting. You are right that right now the conversion of SignalK to NMEA can happen multiple times. If we think that repeating the same thing to multiple serial ports (especially in your case where you have more) is going to become a use-case we can come up with a better solution.
Love that. Was it painful to write? Did you find a flexible way to do it so that we do not have to write each possible PGN in the config parsing code?
I think creating different sources is a great solution. This is what B&G does on NMEA2000 network too. For example the Vulcan 7 appears as "Vulcan 7 GPS", "Vulcan 7 Navigator", "Vulcan 7 Autopilot Controller". The ZG100 appears as a GPS and as a compass separately.
I have added that to the requirements.txt file. That is the proper way to list our dependencies. I will merge this PR now and continue work on KBox. |
Thomas,
This sounds great. I have been running the Kbox-firmware-usb-interface version, which I believed I downloaded from RonZ Github site, it has been working good for me (with the exceptions you have noted). Does your new master incorporate what was there? I will check it out. I like not having to remove the SD card to access it; tools/kbox.py –p COM3 (fwrite, fread and reboot) have worked well in making changes to the config file and downloading log files. I disabled the IMU mag Hd and my own boat sensor for heading has been coming thru in the NMEA sentences, so that was good. I also changed the calibration settings, so that heel/pitch were always sent, but I have not been able to maintain the ‘zero’ setting from one startup to another; although they are not off by much (~ 1 deg). I tried adding my own offset values to the config file and it will save and read those, but the startup value is not always the same (I think I have to look at my notes to be sure). Storing the values in ‘flash’ did not seem to be working for me. On line 55 in SDCardTask.cpp I changed “println()” to “println (“\r\n”); but I don’t remember ‘why’ I did this (LOL).
Glad to hear you are back from your sailing trip and things went well.
Ron
From: Thomas Sarlandie [mailto:[email protected]]
Sent: Monday, April 23, 2018 3:00 PM
To: sarfata/kbox-firmware
Cc: CaptainRon47; Mention
Subject: Re: [sarfata/kbox-firmware] Make KBox repeat all NMEA/NMEA2000 messages to USB port (#128)
Hey guys, Thomas here back from sailing for a little bit ;)
Thanks for the great feedback on this. I understand that it was not clear that you just need to connect at 38400 bauds but now that you have both understood that, I think you like this and I will merge it.
@ronzeiller <https://github.com/ronzeiller> Thanks for putting that diagram together. That is super interesting. You are right that right now the conversion of SignalK to NMEA can happen multiple times. If we think that repeating the same thing to multiple serial ports (especially in your case where you have more) is going to become a use-case we can come up with a better solution.
In "my KBox" I made a config to enable/disable:
* single N2k PGNs – if not enabled they get dropped before they are parsed and added to SKHub
Love that. Was it painful to write? Did you find a flexible way to do it so that we do not have to write each possible PGN in the config parsing code?
* enable own Talker-ID for internal sensor NMEA0183 sentences (to differentiate sources, if e.g. HdG is coming from N2k AND internal sensor)
-same for Performance calculations, made an own SKSource for it to differentiate output
I think creating different sources is a great solution. This is what B&G does on NMEA2000 network too. For example the Vulcan 7 appears as "Vulcan 7 GPS", "Vulcan 7 Navigator", "Vulcan 7 Autopilot Controller". The ZG100 appears as a GPS and as a compass separately.
need to install png pip install pypng
I have added that to the requirements.txt file. That is the proper way to list our dependencies.
I will merge this PR now and continue work on KBox.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub <#128 (comment)> , or mute the thread <https://github.com/notifications/unsubscribe-auth/AP9zq8Gel7PPtiv8XRifwBFABB99U-leks5triSpgaJpZM4SJOwa> .Image removed by sender.
|
@sarfata In the meantime I sailed my regatta and made lot of experiences with KBox. I will try to put these into concerning issues the next days (or weeks) to discuss it little by little. To your question:
No, sorry did not find a flexible way. One thing I did, was to put config "more global" which means I can look for config values more flexible wherever I need it in the code. As the config is growing, and so many things are connected, I believe it is a better way then to pass small pieces to classes and functions. And I put lot of stuff into SKHub, which is a central piece of dealing, construction and distribution of different SKUpdates. SKUpdates as they come in, SKUpdates from different inputs merged together (as needed for some NMEA0183 sentences), calculated values, hi-frequency and (filtered) low-frequency (for displays and navigation programs) SKUpdates. So you can "choose" which SKUpdate style you subscribe to. |
serial port locking up on Raspberry Pi (closes KBox serial outputs lock up when connected to a Raspberry Pi #68)
output for internal sensors but may result in duplicated data)