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

Load cell gram scale #6729

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

garethky
Copy link
Contributor

@garethky garethky commented Nov 5, 2024

This PR adds the features needed to make a load cell actually work as a gram scale. This PR will let you weight filament or measure a force in grams. (no homing or probing yet!)

  • Convert raw sensor counts to grams and make this force data available via unix socket and printer object status
  • Track sensor calibration state and allow sensors to go from un-calibrated to calibrated at runtime
  • Add basic GCodes for tearing and reading the load cell
  • Add a guided calibration tool so users can calibrate a load cell with a known mass or measured force.
  • Add diagnostic GCode to check the health and performance of the load cell and sensor

This code has been tested by several people in the community and some last minute bug fixes and changes were landed:

  • The reverse option allows the polarity of the force readings to be inverted. You can have your probing collision graphs in either orientation now.
  • reference_tare_counts is written to config and read as an integer. link
  • Fixed crash when guided calibration tool being entered twice
  • Fixed crash when CALIBRATE was used before TARE

A lot of work (months) and bug fixing went into parts of this, particularly LOAD_CELL_DIAGNOSTIC and the LoadCellSampleCollector. These bits have to work when the sensor is buggy and still produce usable output. LoadCellSampleCollector also underpins later work for probing.

numpy is required for this PR. We could change that. But PR's for probing will absolutely need it. If you want to merge [load_cell] and [load_cell_probe] then it seems there is no point in trying to keep it out of this PR.

@garethky
Copy link
Contributor Author

garethky commented Nov 5, 2024

The tests failed because of the numpy dependency. I guess I could move the check out of __init__ to get them to pass.

@JamesH1978
Copy link
Collaborator

such a pity numpy is so bloaty and time consuming to just add it to requirements

@Sineos
Copy link
Collaborator

Sineos commented Nov 6, 2024

such a pity numpy is so bloaty and time consuming to just add it to requirements

I'm not sure that this has a real world impact. I guess most, or at least a significant portion also use input shaping and have it installed anyway.
Might be even better to add it to the requirements and call for a version <1.26 to avoid clashing with input shaping.

@JamesH1978
Copy link
Collaborator

i think its the sheer time to compile numpy is the issue if the host is sub par, it can take hours on some

@garethky
Copy link
Contributor Author

garethky commented Nov 6, 2024

I would love to get on my "just require numpy" soap box (Binaries are installed automatically for 32bit, you don't need to compiling it. Its shockingly fast vs plain python. "Your job as a Python programmer is to write C") but... I want to ship this and be 'done' with the project. So what do I have to do?

I can push the numpy require check back to the point where its clear that you are configuring a probe. Most of what I'm using it for in this PR (average, min, max, unique) is relatively easy to replace or remove.

For probing, I need linalg.lstsq. There are some optimizations I discussed with @KevinOConnor to replace the bulk of those calls, but I still have to make several calls to plain least squares. numpy/c is so much faster than Python that any sort of optimizations that we do might be washed away because they aren't in c (plus the code is very complicated). There is also, very very likely, a numpy/vectorized version of what we want to do that will crush the pure Python version (it has loops, its probably 50x slower than numpy). If this code is slow, it causes noticeable pauses.

@Sineos
Copy link
Collaborator

Sineos commented Nov 6, 2024

Is there any way to provide / use a prebuilt v1.26 wheel?


This document describes Klipper's support for load cells and load cell based
probes.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

not knowing what a load cell does/means for a 3d printer, could you add a sentence or two describing it's usage/benefits for 3d printers/klipper?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I made some updates to the documentation including a little bit more exposition at the top and a section about how to read the load cell gram force

* Convert sensor counts to grams and make this available via unix socket and object status
* Basic GCodes for tearing and reading the load cell
* Guided Calibration
* Diagnostic gcode to check the health of the load cell

Signed-off-by: Gareth Farrington <[email protected]>
* Add API server load_cell/dump_force endpoint
* Update [load_cell] config with calibration fields
* Add G-Code commands for working with load cells
* Add status reference for load_cell objects

Signed-off-by: Gareth Farrington <[email protected]>
@garethky
Copy link
Contributor Author

Is there any way to provide / use a prebuilt v1.26 wheel?

For users: if you use Python 3.0 on a 32 bit RPI OS then PiWheels will just install a binary. That's the default behavior. You have to kinda work hard to not get that to happen. i.e. willfully use Python 2 or pick a 64 bit OS.

For the git build system: I'm not sure how that works.

@Sineos
Copy link
Collaborator

Sineos commented Nov 11, 2024

For users: if you use Python 3.0 on a 32 bit RPI OS then PiWheels will just install a binary.

PyPi has some arm64 wheels as well

For the git build system: I'm not sure how that works.

There are examples of project who built the necessary wheels as CI actions. E.g. https://github.com/matrix-org/synapse/pull/14212/files

Maybe it would be an option to built the needed wheels (Python 2 and Python3?) as Klipper CI and the install scripts (or KIAUH) could automatically draw upon them.

@garethky
Copy link
Contributor Author

This was updated to remove the numpy dependency

# Load Cells

This document describes Klipper's support for load cells. Basic load cell
functionality can be used to read force data and to weigh things like filament.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider adding a note that weighing things is only possible on printers with the load cells in the bed, and not those with the cell in the extruder.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't want to get into applications because there are many. You don't even have to put it in the printer! Several people want to use this functionality to weigh filament spools mounted outside the printer. E.g. https://klipper.discourse.group/t/filament-spool-scale-hx711/19800/

  • You could check before a print if there is enough filament on the spool based on the print weight
  • Track filament used by weight.
  • Track drying if the filament by weight lost
    In the future this may be in an application that is just a dry box and not even a printer.
    One community member is even working on runout detection in a resin printer.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants