replace bodge/HX711 with Sthing/Q2-HX711-Arduino-Library
This commit is contained in:
		
							parent
							
								
									3f348f2abb
								
							
						
					
					
						commit
						e26fc4051b
					
				|  | @ -25,7 +25,7 @@ | ||||||
| #include <cmath> | #include <cmath> | ||||||
| #include <type_traits> | #include <type_traits> | ||||||
| 
 | 
 | ||||||
| #include <HX711.h> | #include <Q2HX711.h> | ||||||
| #include "mini_beieli_node.h" | #include "mini_beieli_node.h" | ||||||
| 
 | 
 | ||||||
| using namespace McciCatena; | using namespace McciCatena; | ||||||
|  | @ -132,7 +132,7 @@ Catena_Mx25v8035f gFlash; | ||||||
| bool fFlash; | bool fFlash; | ||||||
| 
 | 
 | ||||||
| // Scales
 | // Scales
 | ||||||
| HX711 LoadCell; | Q2HX711 hx711(A1, A0); | ||||||
| 
 | 
 | ||||||
| //  USB power
 | //  USB power
 | ||||||
| bool fUsbPower; | bool fUsbPower; | ||||||
|  | @ -302,19 +302,9 @@ bool setup_scales(void) | ||||||
|   // Enable Power
 |   // Enable Power
 | ||||||
|   digitalWrite(D10, HIGH); |   digitalWrite(D10, HIGH); | ||||||
| 
 | 
 | ||||||
|   // Initialize library with data output pin, clock input pin and gain factor.
 |   // we wait 400ms (settling time according HX711 datasheet @ 10 SPS
 | ||||||
|   // Channel selection is made by passing the appropriate gain:
 |   delay(400); | ||||||
|   // - With a gain factor of 64 or 128, channel A is selected
 |    | ||||||
|   // - With a gain factor of 32, channel B is selected
 |  | ||||||
|   // By omitting the gain factor parameter, the library
 |  | ||||||
|   // default "128" (Channel A) is used here.
 |  | ||||||
|   LoadCell.begin(A1, A0, 32); |  | ||||||
| 
 |  | ||||||
|   if (!(LoadCell.wait_ready_timeout(2000))) { |  | ||||||
|     gCatena.SafePrintf("%010d - Scale not ready after Init.\n"); |  | ||||||
|     res = false; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   if (config_data.debug_level > 0) { |   if (config_data.debug_level > 0) { | ||||||
|     gCatena.SafePrintf("%010d - setup_scale done\n", millis()); |     gCatena.SafePrintf("%010d - setup_scale done\n", millis()); | ||||||
|   } |   } | ||||||
|  | @ -576,7 +566,7 @@ void bubbleSort(long A[], int len) { | ||||||
| 
 | 
 | ||||||
| long my_read_average(byte gain, byte times) { | long my_read_average(byte gain, byte times) { | ||||||
|   long res; |   long res; | ||||||
|   int const num_scale_readings = 25; // number of instantaneous scale readings to calculate the median
 |   int const num_scale_readings = 50; // number of instantaneous scale readings to calculate the median
 | ||||||
| 
 | 
 | ||||||
|   // we use the median, not the average, see https://community.particle.io/t/boron-gpio-provides-less-current-than-electrons-gpio/46647/13
 |   // we use the median, not the average, see https://community.particle.io/t/boron-gpio-provides-less-current-than-electrons-gpio/46647/13
 | ||||||
|   long readings[num_scale_readings];  // create arry to hold readings
 |   long readings[num_scale_readings];  // create arry to hold readings
 | ||||||
|  | @ -585,12 +575,10 @@ long my_read_average(byte gain, byte times) { | ||||||
|     gCatena.SafePrintf("%010d - my_read_average, measurements: ", millis()); |     gCatena.SafePrintf("%010d - my_read_average, measurements: ", millis()); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   LoadCell.set_gain(gain); |   hx711.setGain(gain); | ||||||
|   // we wait 400ms (settling time according HX711 datasheet @ 10 SPS
 |  | ||||||
|   delay(400); |  | ||||||
| 
 | 
 | ||||||
|   for (int i = 0; i < num_scale_readings; i++) { |   for (int i = 0; i < num_scale_readings; i++) { | ||||||
|     readings[i] = LoadCell.read();  // fill the array with instantaneous readings from the scale
 |     readings[i] = hx711.read();  // fill the array with instantaneous readings from the scale
 | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   res = median(readings, num_scale_readings); // calculate median
 |   res = median(readings, num_scale_readings); // calculate median
 | ||||||
|  |  | ||||||
|  | @ -56,7 +56,7 @@ enum { | ||||||
|   | |   | | ||||||
|   \****************************************************************************/ |   \****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| static const int32_t fwVersion = 20200207; | static const int32_t fwVersion = 20200210; | ||||||
| 
 | 
 | ||||||
| static const byte INIT_PACKAGE_INTERVAL = 100;  // send an init package every 100 packages;
 | static const byte INIT_PACKAGE_INTERVAL = 100;  // send an init package every 100 packages;
 | ||||||
| static const byte MAX_VALUES_TO_SEND = 8; | static const byte MAX_VALUES_TO_SEND = 8; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue