Difference between revisions of "Out of Water Turbidity"

From BoSL Wiki
Jump to navigation Jump to search
Line 301: Line 301:
 
File:Big standing.bmp|new gradation pattern, standing water
 
File:Big standing.bmp|new gradation pattern, standing water
 
File:Big turbulence .bmp|new gradation pattern, turbulent water
 
File:Big turbulence .bmp|new gradation pattern, turbulent water
 +
</gallery>
 +
 +
When the intensities of the vertical strip in the turbulent water are plot, the follows graphs are obtained.
 +
 +
 +
<gallery>
 +
File:00 dist.png|0 NTU
 +
File:10 dist.png|4 NTU
 +
File:22 dist.png|16 NTU
 +
File:24 dist.png|33 NTU
 +
File:26 dist.png|55 NTU
 +
File:28 dist.png|82 NTU
 +
File:30 dist.png|185 NTU
 +
File:32 dist.png|245 NTU
 
</gallery>
 
</gallery>

Revision as of 03:09, 21 July 2022

10 June 2020

In addition to turbidity it would be interesting to test if velocity could be measured using the sensor by tracking the motion of objects on the surface of the water.

The first step is to investigate if the idea is viable. To do this it would be good to gather raw data on what a camera would see when in a drain. From this we will be able to see how turbidity levels affect the image and determine ways to determine to extract the turbidity component using the small processing ability of the ATmega328p or a similar micro-controller.

The ArduCam module was tested as it is likely to form the backbone of the out of water turbidity sensor. Its standard library was downloaded and it was wired to an Arduino Uno on 5V. This worked well, and photos were able to be taken. Next the power supply was changed to 3.3 V. This also worked well and the camera appeared to still be working normally.

When it was attempted to be connected to a BoSL board. It raised the error of not being able to detect the camera. Currently the 8MHz speed of the ATmega on the BoSL board is the suspect. Plugging in the I2C lines of the device in addition to the SPI lines allow the camera to work somewhat on the BoSL board. The connection is unreliable though, and photos will commonly not transmit. It seems that this issue is mostly due to bad quality wires used in the connection. Holding them down while trying to take a photo mostly solves the issue. The baud rate of the serial port was also decreased to 115200.

13 June 2020

Instead of a BoSL board, initially a Arduino MKR zero will be used to connect to the Arduino CAM in the drain. This is because it has an integrated SD card for storing photos, additional processing power, and is much smaller and compact. It also has an RTC which can be used to set the time of the photos.

It was found that the Ardu CAM code compiled on the MKR zero with no adjustments needed. The camera performance was about the same as on the 3V3 BoSL board: some photos were corrupted however it is thought that this is more to do with the cabling than the powering of the device off 3V3 volts itself.

14 July 2020

The SPI clock speed was adjusted on the Arduino MKR zero to get maximum reliability from the ArduCam, it was found that a clock speed of 1MHz provided the optimal stability.

When logging to SD card the ArduCAM is much more reliable. However an issue is had with the auto exposure system. Taking one frame at a time solved this issue.

The power consumption of the Arduino MKR Zero wsa measured, it was found that the operation used 150 mA, of which the SD card took about 30 mA. Putting the ArduCAM module into low power mode reduced the current consumption by 70 mA.

The SAMD21 also has low power modes. It was difficult to be able to get these to work, and issues were had with activating the serial port after sleep.

The native usb serial port is not able to easily be reactivated once the MCU goes into low power mode. An alternative is to use the Serial1 port. This requires an external USB-ttl converter however the USB is only needed for development so it is a viable work around.

In full sleep mode the whole setup uses 62mA, 57 mA of which are drawn by the camera module. This is when its in its lowest sleep state. A transistor may be needed to switch on an off the module to achieve suitability low power consumption.

20 July 2020

In order to reduce current to acceptable levels during sleep, it was experimented if it was possible turning off the supply voltage to the device. Two BC557 PNP transistors were used in parallel to control the VCC to the arduCAM. This did have the effect of reducing the voltage of the VCC pin to aobut 2.9 volts when on, however this didn't seem to affect the performance of the camera, which still worked well. What was found to be an issue was that the camera did not want to re-initiate once the VCC was powered again.

The above issue was fixed by reinitialize the camera from the library every time it was powered on. In sleep mode the whole setup now uses 5mA. Not completely ideal however significantly better than before.

Work was also done to get the image output in BMP, this was less trivial than assumed, the current version is limited to QVGA in BMP mode. Additionally, the BMP files are quite large 150 kB and so take some time (about 2 seconds) to transfer to the SD card and store. It is potentially possible to throw away pixels and decrease the resolution of the image to make this process faster.

It was found how to set the white balance of the camera. By default this is set to auto on the ArduCam however I have now set it in the script to the predetermined 'Sunny' setting. This should ensure more consistency in the colors recorded by the sensor, critical if we wish to use this to determine turbidity.

21 June 2020

Code was written to upload the time photos were taken on the ArduCam to the cloud. The idea is that the ArduCam could be installed with a turbidity sensor. Comparing the turbidity measurements to the photos should allow us to see if there is a good method of determining turbidity from the image taken.

Above is a basic schematic diagram of the setup. The arduino MKR zero and the arducam will be located in the drain and connected via a cat 5 cable to the bosl on the surface.

22 June 2020

A case was printed for the ArduCam. Since in the prototype version the arducam is connected via jumper leads the case needs to be large to accommodate the run of these cables.

The case turned out a bit large, and it was found that a smaller one would still have room to fit all the components. This will be designed now.

24 June 2020

A new box was printed to better accommodate the size of the ArduCam and Arduino. They fit quite well. A lid is still to be printed.

Issues were had with the wire used to connect to the BoSL. The ArduCam requires about 100 mA. It was found that the CAT5 cable had a resistance of 4 Ω over 10 meters. This meant that significant voltage drop occured over the length of the cable causing power instability issues. A fix was found by powering the device with VBAT instead of 3V3 and adding a 100 μF capacitor between the voltage rails on the sensor side. It is noted that this will have implications for longer cables when used on the BoSL Bus notably maximum current draws particularly on longer cables.

With the lid attache the final enclosure looks like this: Note it is not waterproof and should be kept dry.

To wire up the sensor the following connections are to be made to a BoSL board.

Sensor BoSL
GREEN VBAT
HALF GREEN GND
BROWN D9
BLUE D8
HALF ORANGE D7

The BoSL code is: File:BoSL Host out of water turbidity.ino
And Arduino MKR zero code: File:Turbidity out of water.ino

The function of the logging setup is to take 5 pictures spaced 2 seconds every 2 minutes. These are saved to the onboard SD card along with the a timestamp. The timestamps are also then uploaded to the BoSL testing site (http://www.bosl.com.au/IoT/testing/a.php) under site name: TURBID_TEST

19 November 2021

In the year and a bit since the last work on this project was done, new sensor technologies may have come out. Therefore, we will investigated if there now exist any better implementations for an low power/cost camera system.

The current solution of using the Arduino Cam is unideal for a few reasons. The first being that module was not designed for ultra low power operations, hence the changes and usage needed to add low power features cause the system to be buggy, additionally the sensor has a very high resolution of sever megapixels. This is more data than we need to detect the tubudity of the water and more data than is reasonably processable on a microcontroller.

Some new solutions include:

    https://www.digikey.com.au/en/products/detail/sparkfun-electronics/SEN-15570/10819696

This is small self contained imaging module which has a sensor resolution of 320 by 320. It is addressable by I2C, operates off 3.3V and requires on the order of milliamps of current in operation. Many other similar devices appear to be available at: https://www.uctronics.com/1/9-ov7675-standalone-vga-coms-camera-module.html and here https://www.arducam.com/compact-camera-module-oem-odm/

The ideal set of qualities we are looking for in the image sensor module is:

  • Low Cost
  • Low Power (mA) on 3.3V supply
  • ~QVGA resolution and RGB colour
  • easy to interface (I2C, SPI preferable)
  • infinity focus
  • small (TBD)
  • suitable physical connection interface (TBD)

Following investigating the different products available, the arducam OV7670 (https://www.uctronics.com/arducam-ov7670-camera-module-vga-mini-ccm-compact-camera-modules-compatible.html) looks to be the best suited camera for our application. It fits the cost requirement at $4, the current requirement, VGA, it operates through the SCCB bus, which I haven't had as much experience in, but looks reasonable. However the field of view of the camera is a bit small at 45 degrees.

14 January 2022

Performing some further research it seems that the OV7670 is deprecated, it might therefore be worthwhile to use the OV7675, which is the updated version of the OV7670. Specifically the differences are that the newer sensor uses a slightly smaller sensor, has greater standby current. (60 μΑ vs 20 μA), and has a greater sensitivity to light. Both seem to be support by this arduino library https://github.com/arduino-libraries/Arduino_OV767X, so switching between the two later if needed should not require substantial reworking of the design.

20 April 2022

To experiment with these different camera modules and gain an understanding of how they operate, first we will test the camera modules with the Arducam ESP32S UNO PSRAM development board. This board is an arduino which has the OV2640 camera connected onto it. Arducam provides starter scripts to begin working with the camera. Following their guide photographs were able to be captured and stored on the SD card. A typical image from the camera is shown below.

Typical photo from development board

It was found that changing the resolution of the image did not affect the field of view of the image. This allows us greater freedom in choosing a camera with a higher resolution than needed as if downsampling of the image is needed for memory of processing constraints this will not need to crop the image. A quick measurement confirms that this field of view is about 60 degrees.

The example script gives the needed functions to adjust all the key camera parameters (white balance, exposure, contrast, gamma, etc) these will likely need to be set manually for the out of water turbidity sensor as we want a consistent conditions to match images to colours of turbidity. Looking at the code it seems that the setting of these values occurs through setting corresponding bits in the registers mentioned in the datasheet. The manual white balance was a bit difficult the script gave only 4 presets none of which worked very well in the indoor lighting conditions.

27th April 2022

In addition to choosing the correct camera, a lighting system will also be needed for when there is no light in the water system. Using a camera flash is one option, however this will likely need to be a pre-built flash module due to the high voltages involved. An alternate option is using LEDs with a longer exposure time. To see if this is viable we note that the sensitivity of the camera is 1.8 V/(Lux s) and the dark current is 10 mV / s.

Assuming that the led light is co-located with the the camera, then once can calculate that the needed exposure time to get a 50% grey is:

Flash luminosity.png

Where Texp is the needed exposure time, Vexp is the 50% grey voltage (~1 volt for our use cases), η is the reflectivity of the water surface, σ is the sensitivity of the camera (~1.8 V/(lux s) for the types of cameras we are using), Icd is the luminous intensity the leds used, θv the half the field of view of the camera, and H the height of the camera and led above the water. For a higher power white led with luminous intensity of about 33 candela and a distance to the water surface of 3 m this gives, a 20% reflection of the water surface and the OV7675 camera module this gives an exposure time of about 7 seconds. This is probably just on the edge of a feasible exposure time, so with higher power or multiple LEDs, using LEDs to illuminate the water subject should be feasible.

Ideally we would want the colour temperature of the LEDs to match that of the sun so that the difference in the illumination conditions can be minimised. Additionally a narrow angle LED would be preferred so the light isn't wasted outside the field of view of the camera something like (https://cree-led.com/media/documents/C503C-WAS-WAN-1098.pdf) would be ideal. Such LEDs tend to find application in road signs or torches when illumination at a long distance is needed.

22nd June 2022

The OV7675 was now used with the Arducam Shield V2, images were captured in QVGA resolution in an RGB565 format into a bitmap. The last row did not have usable data so the resolution ended up being 320 by 239. A sample image of a test chart is shown: Using the arducam library function wrSensorReg8_8, various sensor registers could be controlled such as test patterns and auto-exposure.


A very long exposure could be achieved by turning off auto exposure and then adjusting the clock divider in the CLKRC register. Doing this it seem that an exposure of at least a half a second was able to be achieved.

23rd June 2022

The gain and white balance were also able to be controlled manually using appropriate registers. By setting all three to manual mode a consistent image could be taken regardless of the external lighting conditions. This will ensure repeatability when performing turbidity tests. A mounting is being design to attach the arducam shield to the edge of a tank for testing.

One idea to solve this was to place the paper in a plastic pocket inside the water. This somewhat worked, from some angles the gradations were visible while from others it was not. Below are images of the tank from the different angles.

30th June 2022

One measurement principle to test is the one described below:

Here a graduated paper is placed into the water, for a given turbidity the camera will only be able to distinguish the gradations to a certain depth before the solution becomes opaque, measuring this depth will give an indication of the turbidity. This depth should roughly be equivalent to the Secchi depth with the obvious difference that the viewing angle will not be directly vertical.

As a first test of this a page was printed with different gradation sizes, this was to be placed on the outside of a glass tank which a camera could image through. This does not work however because from the viewing angles of the camera the glass tank becomes reflective and anything behind it cannot be seen.


Based on these images, mounting the camera relatively high will enable clear view the gradation. This is ideal, as presumable this is how the sensor will be mounted once installed, at the top of the pipe.

Next are images of the tank from the camera at both no turbidity and after some soil has been mixed into the water creating a turbidity of 55 NTU.

It is noted that the frequency of the gradations increases underwater, this is due to the light's refraction. This might be very useful as it provides a way to distinguish where the water surface begins. It is also realised that only a small vertical slice of the image is needed. If so we can discard most of the vertical resolution in the image, this would allow us to have a higher horizontal resolution at the same processing cost. The simplest method of analysis is to plot a vertical section of the image. Or more precisely plot the horizontal integration of a small slice. This is done for the two sample images above.


From these histograms it is clearly seen where the water surface begins as the frequency of the oscillations increases and where the effect that the turbidity has on attenuating the oscillations. These should be fairly easy to measure with an MCU.

Some issues which will need to be through through

  • This water is very still, flowing water will not have an optically transparent surface.
  • It seems that low turbidities have a low visibility distance. This visibility distance will be constant regardless of the scale of the system. That is when this test is scaled up, the visibility will still be the same. This may require a very fine gradation.

1st July 2022

If the surface of the water is disturbed with ripples then this method has issues. As shown in the gallery below, once the surface is disturbed it is very difficult to view the gradations below the surface. The gradual attenuation of the gradations as seen for the still water are no longer present and now a sharp discontinuity occurs and the gradation oscillations suddenly disappear.


Given that most of the of the sites where the sensor will be installed will likely not have a unperturbed water surface most or all of the time. Using the visibility of the gradations under the surface is not going to be a very robust methodology for measuring turbidity. Perhaps however by placing this measurement system inside a rectangular tube or PCV pipe, the water surface will be able to be protected enough that the gradations will always be able to be seen.

4th July 2022

A test of the turbidity measurement system with more turbidity stops is going to be tested. The glass tank was first filled with 12 L of water. A small amount of sediment was added and then the turbidity was measured with a Thermo scientific Orion AQ4500 turbidity meter. Images were captured with the the camera and the process was repeated. The following turbidity values were found:

Sediment (g) Turbidity (NTU)
0 1
2 9
3 17
4 21
5 28
6 34
7 32
8 38
9 45
10 52
12 60
14 70
16 86
18 105
20 111

The gallery below show the level cross sections of the the images taken. It is seen that until about 30 NTU there is quite a nice relationship between the turbidity and the attenuation of the gradation oscillations. It is seen that the white level of the oscillations tends to remain stable while the black level of the oscillation is what increases with depth as the turbidity increases. Beyond about 30 NTU issues with visibility depth being very small and the water reflection overpowering transmission through the water become dominant. The red box in the images show where the level cross sections were taken over.

The first idea was to fit a decaying sinusoid to the data and extract the decay rate as the measure of the turbidity. This did not work as planned due to the perspective of the camera giving making the gradation period not constant. The second idea was to take the absolute value of the data about the oscillation and fit an exponential to this. This worked better and a graph below shows a fairly linear relationship between the fit constant and the turbidity at low NTU.

Based on the issues had with the gradation, I will a new target sheet which is just a solid colour. I think this may be easier to process with decay fitting.

21st July 2022

A new gradation was tested. Images are provided below for both when the water is standing, and when there is strong turbulence. As per the images, in still water all three lines, the black, which and alternating can be distinguished. Once the water becomes turbulent, the alternating gradation becomes a uniform grey, and the graduations cannot be distinguished. The black and white lines however, while they do become harder to see, a vertical line of either black and white can still be resolved. Hopefully this should enable some comparison between the the intensities of the black and white levels to determine the turbidity. A more detailed test of this will now be conducted.

When the intensities of the vertical strip in the turbulent water are plot, the follows graphs are obtained.