02-07-2023 03:01 PM - edited 02-07-2023 03:01 PM
I adapted the pi3g library for reading the values of a sensor with a raspberry pi. To do so I changed the BSEC_SAMPLE_RATE_HIGH_PERFORMANCE to BSEC_SAMPLE_RATE_SCAN and the BSEC_OUTPUT_COMPENSATED_GAS was commented out in the switch and removed from the virtual sensor array (also shifted the last virtual sensor of 1 position because of that).
After that I installed everything following the pi3g instruction but when running the program to take samples to then pass to the bme ai studio software in goes into segmentation fault. I checked the issue on github and updated the amount of memory allocated for the process and the number of core as suggested there, but nothing seems to change.
After that i tried to check what the Raspberry Pi 400 runs and it seems that the architecture is an ARMV8, so i tried to change the configuration of the setup.py to use the PiThree_ARMV8 instead of the default PiThree_ARMV6 and now i'm stuck on this compilation problem:
/usr/bin/ld: BSEC_2.2.0.0_Generic_Release_30052022/algo/normal_version/bin/RaspberryPi/PiThree_ArmV8/libalgobsec.a(GasHumidityBaselineTracker.o)(.text+0x20e4): unresolvable R_ARM_CALL relocation against symbol `truncf@@GLIBC_2.4'
/usr/bin/ld: final link failed: symbol needs debug section which does not exist
collect2: error: ld returned 1 exit status
error: command 'arm-linux-gnueabihf-gcc' failed with exit status 1
Checking on stack overflow it seems like some flags are missing for the gcc so i'll try that, but in the meantime i'd like to know if someone faced the same issue i'm facing and was able to overcome it.
Solved! Go to Solution.
03-01-2023 09:55 AM
Hi Prop4et,
Could we know detailed information about your host architecture?
03-07-2023 10:19 AM
Hi Prop4et,
Could you give further feedback? Thanks.
03-07-2023 10:51 AM - edited 03-07-2023 10:52 AM
It compiles the pithree version and by forcing a call to the library function it starts to record data that is kinda real. I stuck to that because the problem i'm facing is now related to loading the data into bme ai studio, eventhough the format is right, the software doesn't seem to load the whole duration (about 4 hours) but only an hour of sampling.
Because of that i bought a development kit to at least be able to create an algorithm and i manage to do so.
When i have to get back to the pi i'll let you know everything
03-08-2023 09:17 AM
Hi Prop4et,
Do you mean you changed you hardware platform to others and BSEC2 software had been worked well on you new platform?
03-08-2023 11:43 AM
I mean i am still using the same raspberry pi 4B that i was using at the beginning, but i changed the version of the library. The library i am using is the one compiled for the PiThree_ArmV6. This one is compiled by the raspberry pi and it runs. The only issue i have with this is that if i want to read values from the bsec library i need to force a call to a library function before starting the get data process used for sampling by the pi3g code. Otherwise i have TPH readings that are fakes (for example H is always 100). I know they can be ignored when generating the algorithm, but i was wondering why there is this behaviour.
If i try and compile the PiFour_ArmV8 i get an error telling me that it can't be compiled, and by searching the internet it seems like the error is returned when the hardware is not correct for the library (.a file) i am using.