Skip to content
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

Inconsistent Weight Readings #25

Closed
a123qwertz567 opened this issue Aug 19, 2021 · 11 comments
Closed

Inconsistent Weight Readings #25

a123qwertz567 opened this issue Aug 19, 2021 · 11 comments
Labels
bug Something isn't working good first issue Good for newcomers help wanted Extra attention is needed

Comments

@a123qwertz567
Copy link

a123qwertz567 commented Aug 19, 2021

I am not able to get a constant load readings from my setup with this plugin. It fluctuates in a wide range. I did the following troubleshooting steps:

  • Checked and measured the wire connections. All looked good.
  • Measured the load cells resistance directly while applying voltage and some load. All looked normal on the cell.
  • Connected everything (cell+sensor board) to an Arduino Nano and running some tests. I got good and precise readings from a know weight.

At this point I am pretty sure its not my equipment (of course it is the almost the cheapest stuff you can get) because it worked fine on the Arduino. I am thinking maybe it has to do something with the way the plugin reads the cell. Maybe it is the refreshing frequency? Or the calibration factor is a problem, I had to set some really high values on the Arduino setup.

If needed I could provide more information. I do not want to spam logs or anything else here without request :)

EDIT: I have hooked up a filament sensor and a relays module, too. Some other GPIO pins are in use.

I found only one "kind of" error in the log file:
2021-08-18 18:00:48,259 - py.warnings - WARNING - /home/pi/oprint/lib/python3.7/site-packages/filament_scale_enhanced/hx711.py:28: RuntimeWarning: This channel is already in use, continuing anyway. Use GPIO.setwarnings(False) to disable warnings.

@a123qwertz567 a123qwertz567 changed the title Can not get a constant weight reading Problem: Can not get a constant weight reading Aug 19, 2021
@techman83
Copy link
Owner

@a123qwertz567 an arduino has a really close relationship with the GPIOs, a Raspberry PI doesn't. So we're going to be a little limited in how tight the timings and reliability can be. I added a bunch of filtering to discard funky results when I took over the maintenance, so it's much better. But it still fluctuates. If you were able to get me a reference python implementation that could reliably read the cell, I could look at implementing it in the library.

The warning is benign and relates to #17

@techman83 techman83 changed the title Problem: Can not get a constant weight reading Inconsistent Weight Readings Aug 19, 2021
@techman83 techman83 added bug Something isn't working good first issue Good for newcomers help wanted Extra attention is needed labels Aug 19, 2021
@a123qwertz567
Copy link
Author

Sad to hear, maybe the Pi needs some counseling with its pins ;)

I did some further experiments on a spare Pi Zero and ran the example python code provided by this tutorial (the one you linked for wiring).

With this code I got a consistent reading of a known weight. Without load it flings a round 0 to -1, which seems fine.

I am thinking there is maybe some problem with the GPIO pins on the octoprint server....What would be necessary to change the pins in the plugin? Maybe I can do it myself.

In the meantime I will test another Raspberrypi.

@a123qwertz567
Copy link
Author

Just as an additional info. I have been monitoring the plugin on its configuration page in the settings for quite a while. And beside the inconsistent reading, the plugin seems to loose connection to the load cell. Then I get the error message telling me which pins to use. After some seconds it connects again and shows a reading. This disconnecting thing it not consistent, I timed it with a stop watch.

@a123qwertz567
Copy link
Author

Did some more testing now with the hardware the octoprint server runs in production.

  1. I used a fresh SD card with Rasbian and the example code from the link above. All worked fine and I got good readings.
  2. I used the existing Octoprint installation and hooked up a display and keyboard. I ran the same example code but now I get inconsistent readings.

So my conclusion would be that a hardware issue of the GPIO pins can be ruled out. I would guess it has to do with the OS itself....

Any suggestions where to dig in?

@techman83
Copy link
Owner

Interesting. It very likely relates to how it runs within the OctoPrint server, which likely isn't super optimal.

Most of the work I've done since taking over maintenance has been making it work with Python 3 and adding some CI/CD.

If you have some ideas, I'll see how they can be implemented. I need to get some time to put my printer back together!

@a123qwertz567
Copy link
Author

a123qwertz567 commented Aug 22, 2021

Got some more info. I bought a second Raspberry Pi 3+ (just do be sure and I needed it anyways) to do some more testing. I setup a fresh Octoprint, too. Here is what I found:

  1. Pi No. 1 + Old Octo = Problems with scale
  2. Pi No. 1 + New Octo = No Problems, got readings just a few disconnections (which are normal I guess)
  3. Pi No. 2 + Old Octo = Problems with scale
  4. Pi No. 2 + New Octo = No Problems, got readings just a few disconnections (which are normal I guess)

So I suppose it is a problem with my existing Ocotprint installation. It is about a year old and got updated all the time with no manual changes.

I will try to migrate to the fresh install with a backup to test if it works this way.

I would like to keep this issue open for documentation.

@a123qwertz567
Copy link
Author

a123qwertz567 commented Aug 22, 2021

After mounting everything I got some inconsistent readings again. Which stopped when I started a print....

Not sure what it is, maybe some funky electrical feedback in my setup. I will monitor it a bit, but for today I am to frustrated ;)

@techman83
Copy link
Owner

I'd be figuring out all the versions of the different components. Octoprint, plugin, OS version, kernel version, list of other plugins installed.

More than happy to keep the issue and see where you get to. If there is something we can do in code to fix this it'll be great. Or at least add some documentation in the Readme on what steps can be taken to investigate.

@a123qwertz567
Copy link
Author

After some more monitoring I found lighter spools to be more problematic then heavier (max 1kg) spools. Maybe that has to do with me using a 10kg load cell.

For now I will not look further in to this because the measurements from print job history and my filament management plugin are just 3g off from manual weighing.

@techman83
Copy link
Owner

Yeah, the bigger the rating, the more the error margin will come into play. +/- 0.05% at 10,000g is +/- 500g (if my pre ☕ brain is mathing correctly). So a load cell that is closer to what range you're trying to measure will be more accurate. They will also drift a little when holding a static weight for extended periods of time.

I'll close this out for now. For me I picked it up to make it easier to accept and release updates to the plugin, whilst solving my use case (I change spools a lot, so an indication of how much is left is as much as I need).

@a123qwertz567
Copy link
Author

Ok.
I will order a 2kg cell just for fun.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working good first issue Good for newcomers help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants