OlivierLD/raspberry-coffee

Exception with battery monitor

Closed this issue · 19 comments

Thanks for providing this. I also have a boat and solar panel. I'm also using a Witty Pi, USB router and modem to schedule and send back pictures and GPS details. Trying to implement the battery monitor too and seeing the following Exception after initial reading:

pi@raspberrypi:~/raspberry-pi4j-samples $ sudo ./gradlew [--daemon] build

FAILURE: Build failed with an exception.

  • What went wrong:
    Task 'C' is ambiguous in root project 'raspberry-pi4j-samples'. Candidates are: 'check', 'chordFinder', 'classes', 'clean', 'clojureRepl', 'clojureTest', 'clojuredoc', 'combineJs', 'compileClojure', 'compileGroovy', 'compileJava', 'compileKotlin', 'compileScala', 'compileTestGroovy', 'compileTestJava', 'compileTestKotlin', 'compileTestScala', 'components', 'copyResources'.

  • Try:
    Run gradlew tasks to get a list of available tasks. Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.

  • Get more help at https://help.gradle.org

BUILD FAILED in 10s
pi@raspberrypi:~/raspberry-pi4j-samples $

pi@raspberrypi:~/raspberry-pi4j-samples/ADC $ ./battery.monitor -min=289:3.75 -max=872:11.75 -debug=y
Read an ADC
Parameters are:
-calibration or -cal
-debug=y|n|yes|no|true|false - example -debug=y (default is n)
-ch=[0-7] - example -ch=0 (default is 0)
-min=minADC:minVolt - example -min=280:3.75 (default is 0:0.0)
-max=maxADC:maxVolt - example -min=879:11.25 (default is 1023:15.0)
-tune=ADC:volt - example -tune=973:12.6 (default is 1023:15.0)
-scale=y|n - example -scale=y (default is n)
-log=[log-file-name] - example -log=[batt.csv] (default is battery.log)

-min & -max are required if -tune is not here, and vice versa.
Prms: ADC Channel:0, MinADC:289, MinVolt:3.75, MaxADC:872, maxVolt:11.75
Volt [3.75, 11.75]
ADC [289, 872]
a=0.013227414, b=0.21569468
Value range: ADC=0 => V=0.21569468, ADC=1023 => V=13.747339
readAdc:858 (0x35A, 0&1101011010) Volume:83% (858) Volt:11.56
Exception in thread "main" java.lang.NullPointerException
at adc.sample.BatteryMonitor$1.valueUpdated(BatteryMonitor.java:145)
at adc.ADCContext.fireValueChanged(ADCContext.java:39)
at adc.ADCObserver.start(ADCObserver.java:121)
at adc.ADCObserver.start(ADCObserver.java:85)
at adc.sample.BatteryMonitor.(BatteryMonitor.java:154)
at adc.sample.BatteryMonitor.(BatteryMonitor.java:89)
at adc.sample.BatteryMonitor.main(BatteryMonitor.java:264)

Shutting down
Closing log file

Not sure if you can advise?

Thanks, Doug

Hi @freshlydoug , I'll look into this. That should be easy to fix.

Found something, and modified the code.
I'll be able to test it later in the week, but @freshlydoug, you might want to pull the new code, compile it and give it a try...
Please provide the stack dump as you did if a problem shows up...
Thanks!

Thanks @OlivierLD ,

Not sure if this is partly environment related. Deleted directory and did another git. First Error:
sudo ./gradlew [--daemon] build
Starting a Gradle Daemon, 1 busy Daemon could not be reused, use --status for de tails

FAILURE: Build failed with an exception.

  • What went wrong:
    Task 'C' is ambiguous in root project 'raspberry-pi4j-samples'. Candidates are: 'check', 'chordFinder', 'classes', 'clean', 'clojureRepl', 'clojureTest', 'clojuredoc', 'combineJs', 'compileClojure', 'compileGroovy', 'compileJava', 'compileKotlin', 'compileScala', 'compileTestGroovy', 'compileTestJava', 'compileTestKotlin', 'compileTestScala', 'components', 'copyResources'.

  • Try:
    Run gradlew tasks to get a list of available tasks. Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.

  • Get more help at https://help.gradle.org

BUILD FAILED in 40s

Now I executed just build:

pi@raspberrypi:~/raspberry-pi4j-samples $ sudo ./gradlew build
:common-utils:compileJava
:common-utils:processResources NO-SOURCE
:common-utils:classes
:common-utils:jar
:ADC:compileJava
:ADC:processResources NO-SOURCE
:ADC:classes
:ADC:jar
:RMI.sample:compileJava
:RMI.sample:processResources NO-SOURCE
:RMI.sample:classes
:RMI.sample:jar
:I2C.SPI:compileJava
:I2C.SPI:processResources NO-SOURCE
:I2C.SPI:classes
:I2C.SPI:jar
:ADC-benchmark:compileJava
:ADC-benchmark:processResources NO-SOURCE
:ADC-benchmark:classes
:ADC-benchmark:jar
:Adafruit.IO.REST:compileJava
:Adafruit.IO.REST:processResources NO-SOURCE
:Adafruit.IO.REST:classes
:Adafruit.IO.REST:jar
:AlaMode.101:compileJava
:AlaMode.101:processResources NO-SOURCE
:AlaMode.101:classes
:AlaMode.101:jar
:Arduino.RaspberryPI:compileJava
:Arduino.RaspberryPI:processResources NO-SOURCE
:Arduino.RaspberryPI:classes
:Arduino.RaspberryPI:jar
:DAC:compileJava
:DAC:processResources NO-SOURCE
:DAC:classes
:DAC:jar
:Serial.IO:compileJava
:Serial.IO:processResources NO-SOURCE
:Serial.IO:classes
:Serial.IO:jar
:FONA:compileJava
:FONA:processResources NO-SOURCE
:FONA:classes
:FONA:jar
:GPIO.01:compileJava
:GPIO.01:processResources NO-SOURCE
:GPIO.01:classes
:GPIO.01:jar
:GPS.read:compileJava
:GPS.read:processResources NO-SOURCE
:GPS.read:classes
:GPS.read:jar
:HanoiTower:compileJava
:HanoiTower:processResources
:HanoiTower:classes
:HanoiTower:jar
:JavaSoundDemo:compileJavaNote: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.

.... shortened output, apparent success down till:

:PhoneKeyboard3x4:compileTestJava
Download https://repo1.maven.org/maven2/junit/junit/4.11/junit-4.11.pom
Download https://repo1.maven.org/maven2/org/hamcrest/hamcrest-core/1.3/hamcrest-core-1.3.pom
Download https://repo1.maven.org/maven2/org/hamcrest/hamcrest-parent/1.3/hamcrest-parent-1.3.pom
Download https://repo1.maven.org/maven2/org/hamcrest/hamcrest-core/1.3/hamcrest-core-1.3.jar
Download https://repo1.maven.org/maven2/junit/junit/4.11/junit-4.11.jar
:PhoneKeyboard3x4:processTestResources NO-SOURCE
:PhoneKeyboard3x4:testClasses
:PhoneKeyboard3x4:test

membrane.PinsCustomization > goodFive FAILED
junit.framework.AssertionFailedError at PinsCustomization.java:84

10 tests completed, 1 failed
:PhoneKeyboard3x4:test FAILED

FAILURE: Build failed with an exception.

  • What went wrong:
    Execution failed for task ':PhoneKeyboard3x4:test'.

There were failing tests. See the report at: file:///home/pi/raspberry-pi4j-samples/PhoneKeyboard3x4/build/reports/tests/test/index.html

  • Try:
    Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.

  • Get more help at https://help.gradle.org

BUILD FAILED in 5m 7s
93 actionable tasks: 93 executed
w: Detected multiple Kotlin daemon sessions at build/kotlin/sessions

CD ADC
pi@raspberrypi:~/raspberry-pi4j-samples/ADC $ sudo ../gradlew shadowJar
:common-utils:compileJava UP-TO-DATE
:common-utils:processResources NO-SOURCE
:common-utils:classes UP-TO-DATE
:common-utils:jar UP-TO-DATE
:ADC:compileJava UP-TO-DATE
:ADC:processResources NO-SOURCE
:ADC:classes UP-TO-DATE
:ADC:shadowJar
The SimpleWorkResult type has been deprecated and is scheduled to be removed in Gradle 5.0. Please use WorkResults.didWork() instead.

BUILD SUCCESSFUL in 20s
4 actionable tasks: 1 executed, 3 up-to-date

As per below all looks good so I think perhaps it's solved! I'm using a 9v battery to test.

pi@raspberrypi:~/raspberry-pi4j-samples/ADC $ ./battery.monitor -min=289:3.75 -max=872:11.75 -debug=y Read an ADC
Parameters are:
-calibration or -cal
-debug=y|n|yes|no|true|false - example -debug=y (default is n)
-ch=[0-7] - example -ch=0 (default is 0)
-min=minADC:minVolt - example -min=280:3.75 (default is 0:0.0)
-max=maxADC:maxVolt - example -min=879:11.25 (default is 1023:15.0)
-tune=ADC:volt - example -tune=973:12.6 (default is 1023:15.0)
-scale=y|n - example -scale=y (default is n)
-log=[log-file-name] - example -log=[batt.csv] (default is battery.log)

-min & -max are required if -tune is not here, and vice versa.
Prms: ADC Channel:0, MinADC:289, MinVolt:3.75, MaxADC:872, maxVolt:11.75
Volt [3.75, 11.75]
ADC [289, 872]
a=0.013227414, b=0.21569468
Value range: ADC=0 => V=0.21569468, ADC=1023 => V=13.747339
readAdc:73 (0x49, 0&01001001) Volume:7% (73) Volt:01.18
readAdc:60 (0x3C, 0&00111100) Volume:5% (60) Volt:01.01
readAdc:844 (0x34C, 0&1101001100) Volume:82% (844) Volt:11.38
readAdc:785 (0x311, 0&1100010001) Volume:76% (785) Volt:10.60
readAdc:799 (0x31F, 0&1100011111) Volume:78% (799) Volt:10.78
readAdc:786 (0x312, 0&1100010010) Volume:76% (786) Volt:10.61
readAdc:799 (0x31F, 0&1100011111) Volume:78% (799) Volt:10.78
readAdc:782 (0x30E, 0&1100001110) Volume:76% (782) Volt:10.56

Thank you!

Hi @OlivierLD , Sorry to come back. I don't appear to be able to populate the log file. I changed the battery.log permissions and explicitly specified the -log=battery.log but nothing appears to be happening. No errors shown, just an empty log file. No issues as I'll capture the output via nohup. Thanks again, Doug

Hey @freshlydoug , I found and fixed - I think - the problem you're mentioning.
Please pull the new code, do a ../gradlew build shadowJar from the ADC directory, then the log file should be populated.
Please let me know how this goes... Thanks!

Hi @OlivierLD ,

I removed the directory and did another git. Maybe I didn't need to do this but I did another build:
sudo ./gradlew build
.............................
:JavaSoundDemo:compileJavaNote: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.

:JavaSoundDemo:processResources NO-SOURCE
:JavaSoundDemo:classes
:JavaSoundDemo:jar
:RangeSensor:compileJava
:RangeSensor:processResources NO-SOURCE
:RangeSensor:classes
:RangeSensor:jar
:LelandOilDetector:compileJava/home/pi/raspberry-pi4j-samples/LelandOilDetector/src/adc/levelreader/manager/SevenADCChannelsManager.java:173: error: unreported exception NotOnARaspberryException; must be caught or declared to be thrown
obs.start(-1, BETWEEN_LOOPS); // Tolerance -1: all values, pause
^
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
1 error
FAILED

FAILURE: Build failed with an exception.

  • What went wrong:
    Execution failed for task ':LelandOilDetector:compileJava'.

Compilation failed; see the compiler error output for details.

  • Try:
    Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.

  • Get more help at https://help.gradle.org

BUILD FAILED in 36s
34 actionable tasks: 34 executed

But anyway as you mentioned ../gradlew build shadowJar from the ADC directory worked fine.

pi@raspberrypi:~/raspberry-pi4j-samples/ADC $ sudo ../gradlew shadowJar
:common-utils:compileJava UP-TO-DATE
:common-utils:processResources NO-SOURCE
:common-utils:classes UP-TO-DATE
:common-utils:jar UP-TO-DATE
:ADC:compileJava UP-TO-DATE
:ADC:processResources NO-SOURCE
:ADC:classes UP-TO-DATE
:ADC:shadowJar
The SimpleWorkResult type has been deprecated and is scheduled to be removed in Gradle 5.0. Please use WorkResults.didWork() instead.

BUILD SUCCESSFUL in 11s
4 actionable tasks: 1 executed, 3 up-to-date


And battery.log is populating just fine now! Thanks very much again.

Cool! And I think I've now fixed the rest of the errors you've seen as well ;)

Hi @OlivierLD , I'd like to move off my breadboard version to this which arrived today: https://www.tindie.com/products/cburgess129/10-bit-adcvms-board-hat-for-raspberry-pi-v21/
The issue is the pins aren't the same! Can I easily change the pins: clk GPIO05; miso GPIO06; mosi GPIO13; cs GPIO19 and recompile? Thanks!

Hi @freshlydoug , yes, could do modify the pins in ADCObserver, but for convenience, I did a quick modif, you can now provide the pins as parameters to the BatteryMonitor class, and to the battery.monitor script.
You should refresh the code, recompile as you did before (../gradlew shadowJar), and run ./battery.monitor, you should see the following ouput:

./battery.monitor 
Read an ADC
Parameters are:
  -calibration or -cal
  -debug=y|n|yes|no|true|false - example -debug=y        (default is n)
  -ch=[0-7]                    - example -ch=0           (default is 0)
  -min=minADC:minVolt          - example -min=280:3.75   (default is    0:0.0)
  -max=maxADC:maxVolt          - example -min=879:11.25  (default is 1023:15.0)
  -tune=ADC:volt               - example -tune=973:12.6  (default is 1023:15.0)
  -scale=y|n                   - example -scale=y        (default is n)
  -simulate=y|n                - example -simulate=y     (default is n)
  -log=[log-file-name]         - example -log=[batt.csv] (default is battery.log)

  -miso=XX                     - example -miso=4         (default is GPIO_04)
  -mosi=XX                     - example -mosi=5         (default is GPIO_05)
  -clk=XX                      - example -clk=1          (default is GPIO_01)
  -cs=XX                       - example -cs=6           (default is GPIO_06)

 -min & -max are required if -tune is not here, and vice versa.
Prms: ADC Channel:0, MinADC:0, MinVolt:0.0, MaxADC:1023, maxVolt:15.0
Reading MCP3008 on channel 0
 Wiring of the MCP3008-SPI (without power supply):
 +---------++-------------------------------------------------+
 | MCP3008 || Raspberry PI                                    |
 +---------++------+--------------+------+---------+----------+
 |         || Pin# | Name         | Role | GPIO    | wiringPI |
 |         ||      |              |      | /BCM    | /PI4J    |
 +---------++------+--------------+------+---------+----------+
 | CLK (13)|| #12  | PCM_CLK/PWM0 | CLK  | GPIO_18 | 01       |
 | Din (11)|| #18  | GPIO_5       | MOSI | GPIO_24 | 05       |
 | Dout(12)|| #16  | GPIO_4       | MISO | GPIO_23 | 04       |
 | CS  (10)|| #22  | GPIO_6       | CS   | GPIO_25 | 06       |
 +---------++------+--------------+-----+----------+----------+
Raspberry PI is the Master, MCP3008 is the Slave:
- Dout on the MCP3008 goes to MISO on the RPi
- Din on the MCP3008 goes to MOSI on the RPi
Pins on the MCP3008 are numbered from 1 to 16, beginning top left, counter-clockwise.
       +--------+ 
* CH0 -+  1  16 +- Vdd 
  CH1 -+  2  15 +- Vref 
  CH2 -+  3  14 +- aGnd 
  CH3 -+  4  13 +- CLK 
  CH4 -+  5  12 +- Dout 
  CH5 -+  6  11 +- Din 
  CH6 -+  7  10 +- CS 
  CH7 -+  8   9 +- dGnd 
       +--------+ 
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       | BCM | wPi | Name         |  Physical  |         Name | wPi | BCM |
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       |     |     | 3v3          | #01 || #02 |          5v0 |     |     |       
       |  02 |  08 | SDA1         | #03 || #04 |          5v0 |     |     |       
       |  03 |  09 | SCL1         | #05 || #06 |          GND |     |     |       
       |  04 |  07 | GPCLK0       | #07 || #08 |    UART0_TXD | 15  | 14  |       
       |     |     | GND          | #09 || #10 |    UART0_RXD | 16  | 15  |       
       |  17 |  00 | GPIO_0       | #11 || #12 | PCM_CLK/PWM0 | 01  | 18  | CLK   
       |  27 |  02 | GPIO_2       | #13 || #14 |          GND |     |     |       
       |  22 |  03 | GPIO_3       | #15 || #16 |       GPIO_4 | 04  | 23  | Dout  
       |     |     | 3v3          | #01 || #18 |       GPIO_5 | 05  | 24  | Din   
       |  10 |  12 | SPI0_MOSI    | #19 || #20 |          GND |     |     |       
       |  09 |  13 | SPI0_MISO    | #21 || #22 |       GPIO_6 | 06  | 25  | CS    
       |  11 |  14 | SPI0_CLK     | #23 || #24 |   SPI0_CS0_N | 10  | 08  |       
       |     |     | GND          | #25 || #26 |   SPI0_CS1_N | 11  | 07  |       
       |     |  30 | SDA0         | #27 || #28 |         SCL0 | 31  |     |       
       |  05 |  21 | GPCLK1       | #29 || #30 |          GND |     |     |       
       |  06 |  22 | GPCLK2       | #31 || #32 |         PWM0 | 26  | 12  |       
       |  13 |  23 | PWM1         | #33 || #34 |          GND |     |     |       
       |  19 |  24 | PCM_FS/PWM1  | #35 || #36 |      GPIO_27 | 27  | 16  |       
       |  26 |  25 | GPIO_25      | #37 || #38 |      PCM_DIN | 28  | 20  |       
       |     |     | GND          | #39 || #40 |     PCM_DOUT | 29  | 21  |       
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       | BCM | wPi | Name         |  Physical  |         Name | wPi | BCM |
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
Value range: ADC=0 => V=0.0, ADC=1023 => V=15.0

As you can see, you can use the parameters -miso=, -mosi=, -clk=, -cs=.
Let me know if that works for you...
Thanks!

Hi @OlivierLD , thanks very much for going above and beyond on this. I have tested this but I'm afraid it's not working for me, see exception below:

pi@raspberrypi:~/raspberry-pi4j-samples/ADC $ sudo ./battery.monitor -min=486:6.82 -max=674:9.64 -miso=22 -mosi=23 -clk=21 -cs=24 -debug=y
Read an ADC
Parameters are:
  -calibration or -cal
  -debug=y|n|yes|no|true|false - example -debug=y        (default is n)
  -ch=[0-7]                    - example -ch=0           (default is 0)
  -min=minADC:minVolt          - example -min=280:3.75   (default is    0:0.0)
  -max=maxADC:maxVolt          - example -min=879:11.25  (default is 1023:15.0)
  -tune=ADC:volt               - example -tune=973:12.6  (default is 1023:15.0)
  -scale=y|n                   - example -scale=y        (default is n)
  -simulate=y|n                - example -simulate=y     (default is n)
  -log=[log-file-name]         - example -log=[batt.csv] (default is battery.log)

  -miso=XX                     - example -miso=4         (default is GPIO_04)
  -mosi=XX                     - example -mosi=5         (default is GPIO_05)
  -clk=XX                      - example -clk=1          (default is GPIO_01)
  -cs=XX                       - example -cs=6           (default is GPIO_06)

 -min & -max are required if -tune is not here, and vice versa.
Prms: ADC Channel:0, MinADC:486, MinVolt:6.82, MaxADC:674, maxVolt:9.64
Reading MCP3008 on channel 0
 Wiring of the MCP3008-SPI (without power supply):
 +---------++-------------------------------------------------+
 | MCP3008 || Raspberry PI                                    |
 +---------++------+--------------+------+---------+----------+
 |         || Pin# | Name         | Role | GPIO    | wiringPI |
 |         ||      |              |      | /BCM    | /PI4J    |
 +---------++------+--------------+------+---------+----------+
 | CLK (13)|| #40  | PCM_DOUT     | CLK  | GPIO_21 | 29       |
 | Din (11)|| #16  | GPIO_4       | MOSI | GPIO_23 | 04       |
 | Dout(12)|| #15  | GPIO_3       | MISO | GPIO_22 | 03       |
 | CS  (10)|| #18  | GPIO_5       | CS   | GPIO_24 | 05       |
 +---------++------+--------------+-----+----------+----------+
Raspberry PI is the Master, MCP3008 is the Slave:
- Dout on the MCP3008 goes to MISO on the RPi
- Din on the MCP3008 goes to MOSI on the RPi
Pins on the MCP3008 are numbered from 1 to 16, beginning top left, counter-clockwise.
       +--------+
* CH0 -+  1  16 +- Vdd
  CH1 -+  2  15 +- Vref
  CH2 -+  3  14 +- aGnd
  CH3 -+  4  13 +- CLK
  CH4 -+  5  12 +- Dout
  CH5 -+  6  11 +- Din
  CH6 -+  7  10 +- CS
  CH7 -+  8   9 +- dGnd
       +--------+
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       | BCM | wPi | Name         |  Physical  |         Name | wPi | BCM |
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       |     |     | 3v3          | #01 || #02 |          5v0 |     |     |     
       |  02 |  08 | SDA1         | #03 || #04 |          5v0 |     |     |     
       |  03 |  09 | SCL1         | #05 || #06 |          GND |     |     |     
       |  04 |  07 | GPCLK0       | #07 || #08 |    UART0_TXD | 15  | 14  |     
       |     |     | GND          | #09 || #10 |    UART0_RXD | 16  | 15  |     
       |  17 |  00 | GPIO_0       | #11 || #12 | PCM_CLK/PWM0 | 01  | 18  |     
       |  27 |  02 | GPIO_2       | #13 || #14 |          GND |     |     |     
  Dout |  22 |  03 | GPIO_3       | #15 || #16 |       GPIO_4 | 04  | 23  | Din 
       |     |     | 3v3          | #01 || #18 |       GPIO_5 | 05  | 24  | CS  
       |  10 |  12 | SPI0_MOSI    | #19 || #20 |          GND |     |     |     
       |  09 |  13 | SPI0_MISO    | #21 || #22 |       GPIO_6 | 06  | 25  |     
       |  11 |  14 | SPI0_CLK     | #23 || #24 |   SPI0_CS0_N | 10  | 08  |     
       |     |     | GND          | #25 || #26 |   SPI0_CS1_N | 11  | 07  |     
       |     |  30 | SDA0         | #27 || #28 |         SCL0 | 31  |     |     
       |  05 |  21 | GPCLK1       | #29 || #30 |          GND |     |     |     
       |  06 |  22 | GPCLK2       | #31 || #32 |         PWM0 | 26  | 12  |     
       |  13 |  23 | PWM1         | #33 || #34 |          GND |     |     |     
       |  19 |  24 | PCM_FS/PWM1  | #35 || #36 |      GPIO_27 | 27  | 16  |     
       |  26 |  25 | GPIO_25      | #37 || #38 |      PCM_DIN | 28  | 20  |     
       |     |     | GND          | #39 || #40 |     PCM_DOUT | 29  | 21  | CLK 
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       | BCM | wPi | Name         |  Physical  |         Name | wPi | BCM |
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
Volt [6.82, 9.64]
ADC  [486, 674]
a=0.013605343, b=0.46999928
Value range: ADC=0 => V=0.46999928, ADC=1023 => V=14.388266
Created log-file [battery.log]
^C
Shutting down
java.lang.Throwable
        at adc.sample.BatteryMonitor.lambda$main$0(BatteryMonitor.java:389)
        at java.lang.Thread.run(Thread.java:748)
Closing log file
Shutting down the GPIO ports...

However I have also configured the adafruit example:

 GNU nano 2.2.6             File: simpletest.py
# Simple example of reading the MCP3008 analog input channels and printing
# them all out.
# Author: Tony DiCola
# License: Public Domain
import time
# Import SPI library (for hardware SPI) and MCP3008 library.
import Adafruit_GPIO.SPI as SPI
import Adafruit_MCP3008
# Software SPI configuration:
CLK  = 05
MISO = 06
MOSI = 13
CS   = 19
mcp = Adafruit_MCP3008.MCP3008(clk=CLK, cs=CS, miso=MISO, mosi=MOSI)

And I see the following reading on Channel 1:

pi@raspberrypi:~/Adafruit_Python_MCP3008/examples $ sudo python simpletest.py   Reading MCP3008 values, press Ctrl-C to quit...
|    0 |    1 |    2 |    3 |    4 |    5 |    6 |    7 |
---------------------------------------------------------
|  608 |    0 |    0 |    0 |    0 |    0 |    6 |   15 |
|  609 |    0 |    0 |    0 |    1 |    1 |    0 |    0 |
|  607 |    0 |    0 |    0 |   10 |   20 |   30 |   31 |
|  608 |    0 |    0 |    0 |    3 |    0 |    1 |    1 |
|  608 |    0 |    0 |    0 |    0 |    0 |    0 |   10 |
|  607 |    0 |    0 |    0 |   21 |   23 |   18 |    9 |
|  608 |    0 |    0 |    0 |    0 |    1 |    1 |    0 |
|  609 |    0 |    0 |    0 |   17 |   26 |   30 |   31 |
|  607 |    0 |    0 |    0 |    0 |    1 |    1 |    1 |
|  608 |    0 |    0 |    0 |    0 |    3 |   12 |   21 |
|  608 |    0 |    0 |    0 |   16 |   12 |    6 |    0 |
|  608 |    0 |    0 |    0 |    0 |    0 |    0 |    0 |
^CTraceback (most recent call last):
  File "simpletest.py", line 39, in <module>
    time.sleep(0.5)
KeyboardInterrupt

The following all appear to have pin references and I was wondering if they would all need modification?
ADC\src\adc\ADCObserver.java
ADC\src\analogdigitalconverter\ADCReader.java
ADC\C\mcp3008reader.c
ADC\src\analogdigitalconverter\mcp3008\MCP3008Reader.java

Thanks again, Doug

I should add I was also getting this error when I wasn't able to specify the SPI values on the previous release which makes me think they aren't being applied everywhere needed.

I actually just manually modified the GPIO values to miso=22 -mosi=23 -clk=21 -cs=24 in the following files:
ADC\src\adc\ADCObserver.java
ADC\src\analogdigitalconverter\ADCReader.java
ADC\src\analogdigitalconverter\mcp3008\MCP3008Reader.java

recompiled and Executed:
sudo ./battery.monitor -min=486:6.82 -max=674:9.64

And all appears to be working well. Just need to hook up the potentiometer and calibrate!

2018-05-19 06:23:38.733;609;59;08.76
2018-05-19 06:23:42.968;580;56;08.36
2018-05-19 06:23:45.585;606;59;08.71
2018-05-19 06:23:46.591;0;0;00.47
2018-05-19 06:23:52.523;601;58;08.65
2018-05-19 06:23:53.928;578;56;08.33
2018-05-19 06:23:54.931;547;53;07.91

Thanks for the guidance. The pin mapping was the bit I wasn't sure on until your previous post.

Ah yes, pin numbers..., always a mess. There are the physical numbers, BCM numbers, WiringPi numbers, and pin names...
Are the pin numbers used by the Adafruit Python the BCM ones?
In that case, have you tried to run the soft like this? :

 $ ./battery.monitor -miso=6 -mosi=13 -clk=5 -cs=19

It gives an output like that:

 Read an ADC
+- IMPORTANT -----------------------------------+
| For miso, mosi, clk & cs, use BCM pin numbers |
+-----------------------------------------------+
Parameters are:
  -calibration or -cal
  -debug=y|n|yes|no|true|false - example -debug=y        (default is n)
  -ch=[0-7]                    - example -ch=0           (default is 0)
  -min=minADC:minVolt          - example -min=280:3.75   (default is    0:0.0)
  -max=maxADC:maxVolt          - example -min=879:11.25  (default is 1023:15.0)
  -tune=ADC:volt               - example -tune=973:12.6  (default is 1023:15.0)
  -scale=y|n                   - example -scale=y        (default is n)
  -simulate=y|n                - example -simulate=y     (default is n)
  -log=[log-file-name]         - example -log=[batt.csv] (default is battery.log)

  -miso=XX                     - example -miso=4         (default is GPIO_04)
  -mosi=XX                     - example -mosi=5         (default is GPIO_05)
  -clk=XX                      - example -clk=1          (default is GPIO_01)
  -cs=XX                       - example -cs=6           (default is GPIO_06)

 -min & -max are required if -tune is not here, and vice versa.
Prms: ADC Channel:0, MinADC:0, MinVolt:0.0, MaxADC:1023, maxVolt:15.0
Reading MCP3008 on channel 0
 Wiring of the MCP3008-SPI (without power supply):
 +---------++-------------------------------------------------+
 | MCP3008 || Raspberry PI                                    |
 +---------++------+--------------+------+---------+----------+
 |         || Pin# | Name         | Role | GPIO    | wiringPI |
 |         ||      |              |      | /BCM    | /PI4J    |
 +---------++------+--------------+------+---------+----------+
 | CLK (13)|| #29  | GPCLK1       | CLK  | GPIO_05 | 21       |
 | Din (11)|| #33  | PWM1         | MOSI | GPIO_13 | 23       |
 | Dout(12)|| #31  | GPCLK2       | MISO | GPIO_06 | 22       |
 | CS  (10)|| #35  | PCM_FS/PWM1  | CS   | GPIO_19 | 24       |
 +---------++------+--------------+-----+----------+----------+
Raspberry PI is the Master, MCP3008 is the Slave:
- Dout on the MCP3008 goes to MISO on the RPi
- Din on the MCP3008 goes to MOSI on the RPi
Pins on the MCP3008 are numbered from 1 to 16, beginning top left, counter-clockwise.
       +--------+ 
* CH0 -+  1  16 +- Vdd 
  CH1 -+  2  15 +- Vref 
  CH2 -+  3  14 +- aGnd 
  CH3 -+  4  13 +- CLK 
  CH4 -+  5  12 +- Dout 
  CH5 -+  6  11 +- Din 
  CH6 -+  7  10 +- CS 
  CH7 -+  8   9 +- dGnd 
       +--------+ 
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       | BCM | wPi | Name         |  Physical  |         Name | wPi | BCM |
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       |     |     | 3v3          | #01 || #02 |          5v0 |     |     |       
       |  02 |  08 | SDA1         | #03 || #04 |          5v0 |     |     |       
       |  03 |  09 | SCL1         | #05 || #06 |          GND |     |     |       
       |  04 |  07 | GPCLK0       | #07 || #08 |    UART0_TXD | 15  | 14  |       
       |     |     | GND          | #09 || #10 |    UART0_RXD | 16  | 15  |       
       |  17 |  00 | GPIO_0       | #11 || #12 | PCM_CLK/PWM0 | 01  | 18  |       
       |  27 |  02 | GPIO_2       | #13 || #14 |          GND |     |     |       
       |  22 |  03 | GPIO_3       | #15 || #16 |       GPIO_4 | 04  | 23  |       
       |     |     | 3v3          | #01 || #18 |       GPIO_5 | 05  | 24  |       
       |  10 |  12 | SPI0_MOSI    | #19 || #20 |          GND |     |     |       
       |  09 |  13 | SPI0_MISO    | #21 || #22 |       GPIO_6 | 06  | 25  |       
       |  11 |  14 | SPI0_CLK     | #23 || #24 |   SPI0_CS0_N | 10  | 08  |       
       |     |     | GND          | #25 || #26 |   SPI0_CS1_N | 11  | 07  |       
       |     |  30 | SDA0         | #27 || #28 |         SCL0 | 31  |     |       
   CLK |  05 |  21 | GPCLK1       | #29 || #30 |          GND |     |     |       
  Dout |  06 |  22 | GPCLK2       | #31 || #32 |         PWM0 | 26  | 12  |       
   Din |  13 |  23 | PWM1         | #33 || #34 |          GND |     |     |       
    CS |  19 |  24 | PCM_FS/PWM1  | #35 || #36 |      GPIO_27 | 27  | 16  |       
       |  26 |  25 | GPIO_25      | #37 || #38 |      PCM_DIN | 28  | 20  |       
       |     |     | GND          | #39 || #40 |     PCM_DOUT | 29  | 21  |       
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
       | BCM | wPi | Name         |  Physical  |         Name | wPi | BCM |
       +-----+-----+--------------+-----++-----+--------------+-----+-----+
Value range: ADC=0 => V=0.0, ADC=1023 => V=15.0

If you have time, would you let me know what the expected wiring should be?
What RPi pins are MCP3008's CLK, Dout, Din and CS supposed to go on?
I'd like to get it right...

Hi @OlivierLD I copied the wrong execute command before. For the adafruit it's the BCM pins, correct, yes, but for your application I did translate them to PI4J numbers:

Adafruit= BCM: clk GPIO05; miso GPIO06; mosi GPIO13; cs GPIO19
The above translates to PI4J

pi@raspberrypi:~/raspberry-pi4j-samples/ADC $ sudo ./battery.monitor -cal -min=486:6.82 -max=674:9.64 -miso=22 -mosi=23 -clk=21 -cs=24
Read an ADC
Parameters are:
-calibration or -cal
-debug=y|n|yes|no|true|false - example -debug=y (default is n)
-ch=[0-7] - example -ch=0 (default is 0)
-min=minADC:minVolt - example -min=280:3.75 (default is 0:0.0)
-max=maxADC:maxVolt - example -min=879:11.25 (default is 1023:15.0)
-tune=ADC:volt - example -tune=973:12.6 (default is 1023:15.0)
-scale=y|n - example -scale=y (default is n)
-simulate=y|n - example -simulate=y (default is n)
-log=[log-file-name] - example -log=[batt.csv] (default is battery.log)

-miso=XX - example -miso=4 (default is GPIO_04)
-mosi=XX - example -mosi=5 (default is GPIO_05)
-clk=XX - example -clk=1 (default is GPIO_01)
-cs=XX - example -cs=6 (default is GPIO_06)

-min & -max are required if -tune is not here, and vice versa.
Prms: ADC Channel:0, MinADC:486, MinVolt:6.82, MaxADC:674, maxVolt:9.64
Reading MCP3008 on channel 0
Wiring of the MCP3008-SPI (without power supply):
+---------++-------------------------------------------------+
| MCP3008 || Raspberry PI |
+---------++------+--------------+------+---------+----------+
| || Pin# | Name | Role | GPIO | wiringPI |
| || | | | /BCM | /PI4J |
+---------++------+--------------+------+---------+----------+
| CLK (13)|| #40 | PCM_DOUT | CLK | GPIO_21 | 29 |
| Din (11)|| #16 | GPIO_4 | MOSI | GPIO_23 | 04 |
| Dout(12)|| #15 | GPIO_3 | MISO | GPIO_22 | 03 |
| CS (10)|| #18 | GPIO_5 | CS | GPIO_24 | 05 |
+---------++------+--------------+-----+----------+----------+
Raspberry PI is the Master, MCP3008 is the Slave:

  • Dout on the MCP3008 goes to MISO on the RPi
  • Din on the MCP3008 goes to MOSI on the RPi
    Pins on the MCP3008 are numbered from 1 to 16, beginning top left, counter-clockwise.
    +--------+
  • CH0 -+ 1 16 +- Vdd
    CH1 -+ 2 15 +- Vref
    CH2 -+ 3 14 +- aGnd
    CH3 -+ 4 13 +- CLK
    CH4 -+ 5 12 +- Dout
    CH5 -+ 6 11 +- Din
    CH6 -+ 7 10 +- CS
    CH7 -+ 8 9 +- dGnd
    +--------+
    +-----+-----+--------------+-----++-----+--------------+-----+-----+
    | BCM | wPi | Name | Physical | Name | wPi | BCM |
    +-----+-----+--------------+-----++-----+--------------+-----+-----+
    | | | 3v3 | #1 || #2 | 5v0 | | |
    | 02 | 08 | SDA1 | #3 || #4 | 5v0 | | |
    | 03 | 09 | SCL1 | #5 || #6 | GND | | |
    | 04 | 07 | GPCLK0 | #7 || #8 | UART0_TXD | 15 | 14 |
    | | | GND | #9 || #10 | UART0_RXD | 16 | 15 |
    | 17 | 00 | GPIO_0 | #11 || #12 | PCM_CLK/PWM0 | 01 | 18 |
    | 27 | 02 | GPIO_2 | #13 || #14 | GND | | |
    Dout | 22 | 03 | GPIO_3 | #15 || #16 | GPIO_4 | 04 | 23 | Din
    | | | 3v3 | #1 || #18 | GPIO_5 | 05 | 24 | CS
    | 10 | 12 | SPI0_MOSI | #19 || #20 | GND | | |
    | 09 | 13 | SPI0_MISO | #21 || #22 | GPIO_6 | 06 | 25 |
    | 11 | 14 | SPI0_CLK | #23 || #24 | SPI0_CS0_N | 10 | 08 |
    | | | GND | #25 || #26 | SPI0_CS1_N | 11 | 07 |
    | | 30 | SDA0 | #27 || #28 | SCL0 | 31 | |
    | 05 | 21 | GPCLK1 | #29 || #30 | GND | | |
    | 06 | 22 | GPCLK2 | #31 || #32 | PWM0 | 26 | 12 |
    | 13 | 23 | PWM1 | #33 || #34 | GND | | |
    | 19 | 24 | PCM_FS/PWM1 | #35 || #36 | GPIO_27 | 27 | 16 |
    | 26 | 25 | GPIO_25 | #37 || #38 | PCM_DIN | 28 | 20 |
    | | | GND | #39 || #40 | PCM_DOUT | 29 | 21 | CLK
    +-----+-----+--------------+-----++-----+--------------+-----+-----+
    | BCM | wPi | Name | Physical | Name | wPi | BCM |
    +-----+-----+--------------+-----++-----+--------------+-----+-----+
    Volt [6.82, 9.64]
    ADC [486, 674]
    a=0.013605343, b=0.46999928
    Value range: ADC=0 => V=0.46999928, ADC=1023 => V=14.388266
    Created log-file [battery.log]
    ^C
    Shutting down
    java.lang.Throwable
    at adc.sample.BatteryMonitor.lambda$main$0(BatteryMonitor.java:389)
    at java.lang.Thread.run(Thread.java:748)
    Closing log file

Since the above wasn't working for me I went back to the backup folder of the previous release manually modified the GPIO values the PI4J values miso=22 -mosi=23 -clk=21 -cs=24 in the following files:
ADC\src\adc\ADCObserver.java
ADC\src\analogdigitalconverter\ADCReader.java
ADC\src\analogdigitalconverter\mcp3008\MCP3008Reader.java

The above setup is all because the board I bought pre-build had a different wiring to that on your board, which apparently is ok to do.

I would add from a few posts I've seen and the standard adafruit setup the standard / most common wiring setup is actually your default i.e. BCM CLK=18; MISO=23; MOSI=24; CS=25 > PI4J CLK=01; MISO=04; MOSI=05; CS=06.

Thanks,

Doug

Ah so I see, you made it so I didn't need to translate them to PI4J, the following BCM numbers work!:
./battery.monitor -miso=6 -mosi=13 -clk=5 -cs=19. Therefore I guess your default values should be updated to the BCM ones CLK=18; MISO=23; MOSI=24; CS=25.
Thanks, Doug

Ok, I've set the default (in BatteryMonitor) to the value that work (-miso=6 -mosi=13 -clk=5 -cs=19). This way, there is no need to override them.
Cheers!

  • Olivier

Hi @OlivierLD , thanks for that. I was thinking that you would keep your defaults in line with your wiring tutorial but just change the printed defaults from PI4J values to the more standard BCM ones CLK=18; MISO=23; MOSI=24; CS=25.

-miso=XX - example -miso=4 (default is GPIO_04)
-mosi=XX - example -mosi=5 (default is GPIO_05)
-clk=XX - example -clk=1 (default is GPIO_01)
-cs=XX - example -cs=6 (default is GPIO_06)

to
-miso=XX - example -miso=4 (default is GPIO_23)
-mosi=XX - example -mosi=5 (default is GPIO_24)
-clk=XX - example -clk=1 (default is GPIO_18)
-cs=XX - example -cs=6 (default is GPIO_25)

Obviously defaulting to the values I need is slightly easier for me but I'm concerned other who follow will be confused.

Cheers,

Doug

20180527_190128
Thanks again @OlivierLD , the finished product attached.

Very nice! Congratulations!