Difference between revisions of "PSD Sensor"

From BoSL Wiki
Jump to navigation Jump to search
Line 1: Line 1:
==Introduction==
+
    <h2>Introduction</h2>
 +
    <p>The PSD Sensor is a novel, low-cost camera-based sensor designed for near-continuous in-situ measurements of Particle Size Distribution (PSD) in stormwater. This sensor addresses the limitations of traditional PSD measurement methods, which are often expensive, labour-intensive, or unable to provide real-time data.</p>
 +
   
 +
    <h2>Key Features</h2>
 +
    <ul>
 +
        <li>Utilizes a self-developed and highly customised compact camera with a 25x macro lens</li>
 +
        <li>Employs image processing techniques for particle size estimation</li>
 +
        <li>Provides affordable (less than $100), low-power, and mini-sized solution</li>
 +
        <li>Capable of near-continuous measurements</li>
 +
        <li>Designed for field deployment in stormwater systems (work in progress)</li>
 +
    </ul>
 +
   
 +
    <h2>Methodology</h2>
 +
    <h3>Image Acquisition</h3>
 +
    <p>The core of the PSD sensor is the [[BoSLcam|BoSLCam]], a self-developed camera logger. Key features of the BoSLCam include:</p>
 +
    <ul>
 +
        <li>Custom-designed PCB measuring 70 mm by 15 mm</li>
 +
        <li>Powered by a single 3.7V Li-ion battery</li>
 +
        <li>OV7675 colour camera module capable of capturing VGA (640x480) resolution images</li>
 +
        <li>nRF9160 chip for main microcontroller functions and LTE-M1 cellular connectivity</li>
 +
        <li>GPS location and time data acquisition capability</li>
 +
        <li>23LCV1024 SRAM buffer for image data processing</li>
 +
        <li>SD card storage for captured images, and SIM card capability to upload images to FTP servers</li>
 +
        <li>Power-efficient design with sleep mode reducing current consumption to less than 400 µA</li>
 +
        <li>UART port for communication with external sensors and dataloggers</li>
 +
    </ul>
 +
   
 +
    <h3>Image Processing</h3>
 +
    <p>The image processing workflow consists of the following detailed steps:</p>
 +
   
 +
    <h4>1. Image Pre-Processing</h4>
 +
    <ol>
 +
        <li>RGB to Grayscale Conversion:
 +
            <ul>
 +
                <li>The RGB image is converted to grayscale using the following equation:
 +
                    <pre>Grayscale = 0.299 × Red + 0.587 × Green + 0.114 × Blue</pre>
 +
                </li>
 +
                <li>This equation is commonly used in camera-based measurement of turbidity.</li>
 +
            </ul>
 +
        </li>
 +
        <li>Fourier Transform and High-Pass Filter:
 +
            <ul>
 +
                <li>A Fast Fourier Transform (FFT) is applied to convert the image from the spatial domain to the frequency domain.</li>
 +
                <li>A high-pass filter with a cutoff frequency of 2 is used to mitigate background noise and enhance image contrast.</li>
 +
                <li>The process involves:
 +
                    <ol>
 +
                        <li>Applying 2D Fourier transform to the grayscale image</li>
 +
                        <li>Shifting the zero-frequency component to the center of the spectrum</li>
 +
                        <li>Creating a high-pass filter mask</li>
 +
                        <li>Applying the mask to the shifted Fourier transform</li>
 +
                        <li>Performing inverse Fourier transform to obtain the filtered image</li>
 +
                    </ol>
 +
                </li>
 +
            </ul>
 +
        </li>
 +
    </ol>
  
The rapid urbanization across the world has led to an increase in impervious surface areas, impeding natural water infiltration and contributing to the generation of stormwater runoff containing of various unwanted substances, including but not limited to pathogen, nutrient, and heavy metals. This stormwater runoff poses significant challenges to the urban water systems and health of human beings and ecosystems, necessitating continuous monitoring and assessment of stormwater. Continuous monitoring of stormwater quality plays a crucial role in informing researchers, practitioners, policymakers, and other stakeholders about the current state of urban stormwater system, enabling them to take appropriate actions to mitigate the degradation of stormwater and protect the ecosystem.
+
    <h4>2. Image Segmentation (Thresholding)</h4>
 +
    <ol>
 +
        <li>Threshold Determination:
 +
            <ul>
 +
                <li>A threshold grayscale value of 241 was determined to be adequate for the BoSLCam sample images.</li>
 +
                <li>This threshold distinguishes pixels representing particles (darker) from the background (brighter).</li>
 +
            </ul>
 +
        </li>
 +
        <li>Binary Image Creation:
 +
            <ul>
 +
                <li>The grayscale image is converted to a binary image where:
 +
                    <ul>
 +
                        <li>1 represents particle (foreground)</li>
 +
                        <li>0 represents background</li>
 +
                    </ul>
 +
                </li>
 +
            </ul>
 +
        </li>
 +
    </ol>
  
In-situ sensor is one of the important approaches in stormwater monitoring, as it enable the access to real-time information with spatial and temporal water quantity and quality data. With the ongoing development and application of different stormwater sensors, turbidity has become a commonly used water quality parameter, due to its relative ease and low cost of measurement. However, turbidity can only provide a simple and general representation of the level of sediment existence in water. But it does not capture the size fractions of these sediment particles, which are essential for understanding the composition and concentration of different pollutants present in stormwater. For instance, smaller sediment particles are often more environmentally concerning, due to its association with higher pollutant loading. This finding has been highlighted by many researchers, with studies covering heavy metals (Herngren, Goonetilleke, et al., 2005; Baum, Kuch, et al., 2021; Yao, Wang, et al., 2015), *Escherichia coli* (Wu, et al. 2019; Petersen, Hubbart, 2020),  and nutrients such as TP and TN (Vaze and Chiew, 2004). This problem is further emphasised when the finer particles remain suspended for longer periods due to slower settling velocities. On the other hand, when larger particles may carry less pollutant loading, there still pose problem to the natural water stream when the settlement and accumulation of large particles could smother natural habitats.  In addition, understanding the size fraction of the sediment particles in stormwater is important when designing maintaining a treatment system such as stormwater filter, because an adequate matching of sediment characteristics and filter media material could improve the treatment efficiency and increase the system lifespan. All these build up the reasons to measure Particle Size Distribution (PSD) in stormwater quality assessment.
+
    <h4>3. Feature Extraction</h4>
 +
    <ol>
 +
        <li>Connected Component Labelling:
 +
            <ul>
 +
                <li>8-connectivity is used to perform connected component labelling on the binary image.</li>
 +
                <li>This process identifies and labels patches of pixels that are grouped together, representing individual particles.</li>
 +
            </ul>
 +
        </li>
 +
        <li>Particle Size Estimation:
 +
            <ul>
 +
                <li>For each labeled pixel patch (particle):
 +
                    <ol>
 +
                        <li>The pixel size is multiplied by the theoretical area-per-pixel value (e.g., 30x30µm for BoSLCam).</li>
 +
                        <li>Assuming spherical particles, the equivalent spherical diameter is calculated.</li>
 +
                        <li>Particle surface area and volume are also calculated based on this diameter.</li>
 +
                    </ol>
 +
                </li>
 +
            </ul>
 +
        </li>
 +
    </ol>
  
The current method for measuring PSD is through traditional laboratory analysis using sophisticated equipment, such as laser particle size analysers (Charters, Cochrane, et al., 2015). However, uncertainties are inevitable as changes to sediment would occur throughout the “sampling-storage-transport-analysis” process. In addition, this approach is expensive, laborious, and most importantly, unable to provide continuous in-situ information about PSD dynamics. It would be beneficial if real-time sensing technology is also capable of measuring the PSD. Some studies have explored real-time PSD measurement techniques, such as Brown et al. (2012), who designed a laser particle analyser coupled with a peristaltic pump and filter/de-bubbler, and Yu et al. (2009), who proposed an image-based method in wastewater treatment facility scenario using a system comprising a digital camera, pump, light source, and computer. While these devices effectively measure PSD in real time, they are often expensive and require substantial space to accommodate all the necessary instruments, significantly limiting their potential to be deployed in the stormwater system, particularly if the monitoring and study of PSD in relatively large spatial scale is needed.
+
    <h4>4. Data Cleaning and Preparation</h4>
 
+
    <ul>
To address these limitations, this research project proposes a novel, low-cost camera-based sensor that offers an affordable, low-power, and small-sized solution for near-continuous measurements of PSD in stormwater. This page aims to present the methodology, preliminary test results, and discussions, as well as outline future work related to this proposed sensor.
+
        <li>Particles larger than 500 µm (exceeding the proposed detection range) are excluded.</li>
 
+
        <li>Histogram bins containing fewer than 2 particle counts are removed to mitigate potential noise effects, such as those caused by bubbles.</li>
== Methodology ==
+
    </ul>
 
+
   
The simple principle of the proposed PSD sensor is that when light beam encounters particles, it is either absorbed (Beer-Lambert Law/180-degree transmissive light (Parra, Rocher, et al., 2018; Yu, Chen, et al., 2009; Mora, Kwan, et al., 1998)) or scattered (Mie-Scattering Principle/usually 90 degrees from the incident light (Hussain, Ahamad, et al., 2016)) by the particle.  The levels of absorption/scattering of light beams in water samples with different sediment concentrations are different, and this principle is widely used for the current measuring and sensing technology of turbidity, TSS, and water clarity. Therefore, it is hypothesised that a camera, that is capable of capturing more and complicated information of the world, can also capture the detailed information of each sediment particle in the water. The basic idea is to capture images of water sample with a contrast (i.e., illuminated white or monochromatic) background, and sediment particles will appear as black dots on the images as they prevent lights from reaching the camera sensor. Processing and analyses of the captured sample images would result in the size information of each individual particle being captured, hence the PSD estimation. 
+
    <h3>PSD Analysis</h3>
 
+
    <p>The sensor produces the following outputs:</p>
The proposed workflow of this camera-based PSD sensor consists of image acquisition, image transmission, image pre-processing, image segmentation (thresholding), feature extraction, and data analysis. This section provides detailed explanations on each step of this workflow procedure.
+
    <ul>
 
+
        <li>Number-based (count-based) and volume-weighted particle size distribution histograms</li>
=== Image Acquisition ===
+
        <li>Cumulative distribution curves</li>
 
+
        <li>Statistical parameters such as D10, D50 (median diameter), and D90</li>
'''Preliminary Validation'''
+
    </ul>
 
+
   
The core of the proposed PSD sensor is the camera used for image capturing and how to make sure meaningful and analysable information of the sediment particles is captured. In the early stage of the preliminary validation, the iPhone X main camera was used to turn the concept into working procedure. In the later stage, BoSLCam was used to confirm the transferability of the proposed working procedure. It is also selected to be used in the end product of the PSD sensor due to its lower cost and compact size.
+
    <h2>Validation Results</h2>
 
+
    <p>Laboratory validation tests using standard particles of various sizes (38-355 µm) demonstrated:</p>
To capture the image of sediment particles in water sample, we first 3d-printed a black and closed (but openable) testing container and used it to set up the validation test. At the bottom of the container, a white LED backlight module (https://core-electronics.com.au/white-led-backlight-module-medium-23mm-x-75mm.html) was laid flat providing diffused backlights from below. Above it was a clear acrylic plate used to hold a shallow depth of water sample. The reason for examining only a shallow depth was twofold: to prevent the overlapping of particles located at different depths within the sample, and to mitigate the potential distortion caused by particles being at varying distances from the camera, which could lead to inaccurate size measurements. On the top of the testing container, an openable lid provided a window for the cameras to face down and capture the water sample images.
+
    <ul>
 
+
        <li>Strong linear relationships (R² > 0.99) between the sensor's measurements and those obtained by a traditional laboratory analyser for key PSD parameters (volume-weighted D10, D50, and D90)</li>
Note that the water samples in the preliminary validation are clean water, dosed with artificial particles with different standard size ranges: 38-45µm, 53-63µm, 75-90µm, 125-150µm, and 300-355µm.
+
        <li>No significant differences in central tendency measurements for most size ranges, with some limitations observed for very small (&lt;50 µm) and very large (>300 µm) particles</li>
 
+
    </ul>
==Development Log==
+
   
===04 July 2022===
+
    <h2>Future Work</h2>
The very first experiment...
+
    <p>Planned improvements and future research directions include:</p>
 
+
    <ul>
'''Camera'''
+
        <li>Trialing a 100x microscopy lens to improve measurement accuracy for smaller particles</li>
 
+
        <li>Optimizing the image processing algorithm and calibration method</li>
[https://www.arducam.com/ov2640/ OmniVision OV2640 Camera], 640*480, JPG output, default camera settings (automatic exposure, gain, and white balance), lens not changed. The camera is connected to a [https://www.arducam.com/product/b0051b0011-arducam-f-shield-v2-camera-module-shield-with-ov2640-for-arduino-uno-mega2560-due/ ArduCAM Arduino Shield] which is compatible with the Arduino Mega board. The board is set up using ArduCAM's [https://github.com/ArduCAM/Arduino/tree/master/ArduCAM Arduino Library]. When taking images, the Arduino Mega is connected directly to the PC, and the images are sent and saved on the PC directly, for now.
+
        <li>Investigating the underestimation issue for larger particle sizes</li>
 
+
        <li>Developing a field-ready sensor and testing with real-world stormwater samples</li>
[[File:Turb sensor lab experiment setup 1.jpg|thumb|Camera Turbidity Sensor Lab Experiment Setup]]
+
        <li>Exploring machine learning algorithms for improved particle detection</li>
'''Turbidity Solution'''
+
        <li>Investigating simultaneous measurement of other water quality parameters such as turbidity and TSS</li>
 
+
    </ul>
The tap water is mixed with natural silts to create the synthetic solution. The turbidity value ranges from 0 to 639 NTU in this experiment.
+
   
 
+
    <h2>References</h2>
'''Methods'''
+
    <p>For a complete list of references, please refer to the original research paper (currently not available, but contact Canwei if you are interested).</p>
 
 
First, put the synthetic turbidity solution into the 3d-printed black container, after measuring the actual turbidity (in the unit of NTU) using the Thermo Fisher turbidity meter. Then, light up the LED (from the top hole of the container lid) and take images (from the side window) of the solution at a 90-degree angle. This light scattering method is a common method used for turbidity measurement. Generally, when the water is more turbid, the increased particles in the water scatter more light beams in directions other than the straight direction, hence the light intensity received from the side directions (such as 90 degrees) will increase. The RGB (red, green, and blue) values of each pixel of the images are obtained using python script and converted into a single value - grayscale (0 - 255, completely black to completely white) using the Luma formula (Y = 0.299R + 0.587G + 0.114B). The average grayscale value of all pixels of each photo is calculated. Finally, plot the relationship between the average grayscale value of each image and its corresponding solution turbidity.
 
 
 
'''Results'''
 
 
 
[[File:20220708 Experiment result 1.png|500px|thumb|none|Results of the 1st Experiment]]
 
 
 
As shown in the plot, there is a linear relationship between the log(NTU) and average grayscale, with the squared-R = 0.8726. However, this result is not good at all, as the grayscale values almost plateau when the turbidity values go above 100 NTU. This may be attributed to the strength of the LED. To be more specific, the light intensity of the LED is too strong, hence when the turbidity reaches a certain value (more than 100 in this case), the particles in the water have already scattered too much light that the camera is not able to handle. Therefore, in future experiments, the LED intensity should be lowered. Another issue of this experiment is that the silts are so heavy that they settle down very quickly, thus the actual turbidity of the solution may also change quickly. Moreover, the container design should be improved so that the camera can be placed in a relatively fixed position near the "window".
 
 
 
===10 August 2022===
 
The second experiment with a great number of changes.
 
 
 
'''Camera'''
 
 
 
Camera changed to [https://www.arducam.com/products/camera-breakout-board/0-3mp-ov7675/ OmniVision OV7675 Camera] for better documentation, size changed to 320*240, format changed to BMP output, camera setting changed (automatic exposure, gain, and white balance are disabled), lens not changed. The connection and software of the new camera remain the same as previous one.
 
 
 
'''Turbidity Solution'''
 
 
 
To overcome the problem that the settlement of turbidity particles is too fast, the standard turbidity solution is used this time. 4000 NTU Formazin turbidity standard solution and DI water are used to make standard solutions with the following turbidity values: 0 (pure water), 25, 50, 75, 100, 200, 300, and 400 NTU. The actual turbidity of each solution is measured and differs from the "standard value". The actual turbidity values are used in the plotting.
 
 
 
'''Methods'''
 
 
 
Most of the processes remain the same with the following few exceptions. (1) The 3d-printed container design is improved, so the camera can be placed in a relatively fixed position. (2) In the previous experiment, the software provided in the ArduCAM library is used to take and save images. But this time a Python script is used to obtain the images, hence we can set the image format to bitmap (BMP). (3) Most importantly, the [https://www.jaycar.com.au/white-5mm-led-4000mcd-round-clear/p/ZD0190 white LED] used for the experiment is tested with 3 resistors (20, 470, and 4700 ohms) which can provide different levels of light intensity (strong, moderate, and weak).
 
 
 
'''Results'''
 
<gallery>
 
20220810 Experiment Result 1.png|1. All Data Points
 
20220810 Experiment Result 2.png|2. High Intensity - all data
 
20220810 Experiment Result 3.png|3. High Intensity - excluding 1 NTU
 
20220810 Experiment Result 4.png|4. Moderate Intensity - excluding 400 NTU
 
20220810 Experiment Result 5.png|5. Moderate Intensity - range 0-100 NTU
 
20220810 Experiment Result 6.png|6. Low Intensity - all data
 
20220810 Experiment Result 7.png|7. Low Intensity - range 100-400 NTU
 
</gallery>
 
High Intensity: If we look at the turbidity estimation ranging from 0 to 400 NTU, the LED with full brightness is not ideal, as there is no correlation found. However, the hypothesis is that high-intensity LED may be useful when the turbidity is in a low range, and the strong scattered light may be sensitive to the change of turbidity in that range. Further experiments are needed to test this hypothesis.
 
 
 
Moderate Intensity: The average grayscale values for 300 and 400 NTU are almost the same, the assumption is that the detection limit is also reached for this level of LED intensity. Excluding 400 NTU, we are able to find a good linear relationship (R2 = 0.9837). And surprisingly, the range below 100 NTU shows a nearly perfect linear relationship (R2 = 0.9994).
 
 
 
Low Intensity: Although the images taken are extremely dark and I could not distinguish them using naked eyes, the linear relationship looks not bad (R2 = 0.9641). It appears that the linear relationship for the NTU ranging above 100 looks better (R2 = 0.9891). A consistent hypothesis is that, with the low LED intensity, the camera may be able to estimate the very turbid solutions. Further experiments are needed to test beyond 400 NTU.
 
 
 
===19 August 2022===
 
The completely replication of the previous experiment.
 
 
 
'''Camera'''
 
 
 
Same as the previous experiment.
 
 
 
'''Turbidity Solution'''
 
 
 
Same as the previous experiment. The turbidity solution is the one used in the previous experiment, but the actual turbidity values are all re-measured.
 
 
 
'''Methods'''
 
 
 
Same as the previous experiment.
 
 
 
'''Results'''
 
 
 
<gallery>
 
20220819 Experiment Result 1.png|1. Comparison between Two Experiment Results
 
20220819 Experiment Result 2.png|2. Combination of Two Experiment Results
 
20220819 Experiment Result 3.png|3. Moderate Intensity - range 0-100 NTU
 
Turb sensor lab experiment setup 1.jpg|4. Experiment Setup
 
</gallery>
 
The results are very consistent with the previous one and prove the repeatability of the experiment. The squared-R values of the linear relationships in this experiment are slightly decreased, but the decrease is not significant. Nevertheless, the moderate-intensity LED shows a nearly perfect linear relationship for the turbidity values ranging from 0 to 100 NTU, again.
 
 
 
These two experiments are conducted based on the standard turbidity solutions to avoid the issue of fast settling of the particles, but this is only a temporary solution to the issue. In the subsequent experiments, I will change the solution back to the synthetic solutions, while trying to make the measurement more accurate.
 
 
 
===25 August 2022===
 
This experiment uses the solution synthesised with air-dry clay (used for DIY crafts).
 
 
 
'''Camera'''
 
 
 
Same as the previous experiment.
 
 
 
'''Turbidity Solution'''
 
 
 
The solution is changed from the standard turbidity solution to the air-dry clay solution. The air-dry clay is usually used for DIY crafts and is finer than the natural clay and silt. Hence, the finer clay in the solution will settle much less slowly than the natural clay and silt. It makes doing the experiment easier and the results more accurate. The actual turbidity value of the clay solution ranges from 0 to 450 NTU.
 
 
 
'''Methods'''
 
 
 
Same as the previous experiment.
 
 
 
'''Results'''
 
 
 
<gallery>
 
20220825 Experiment Result 1.jpg|1. Clay Solutions (400 and 100 NTU)
 
20220825 Experiment Result 2.png|2. Raw Experiment Data
 
20220825 Experiment Result 3.png|3. Result Comparision with Previously Used Standard Solution
 
20220825 Experiment Result 4.png|4. High Intensity (Range 0-50 NTU)
 
20220825 Experiment Result 5.png|5. Moderate Intensity (Range 0-150 NTU)
 
20220825 Experiment Result 6.png|6. Low Intensity (Range 50-450 NTU)
 
</gallery>
 
 
 
Overall: The general trends for the clay solution and standard solution are similar. But if having a closer look, we can see the linear relationships for clay solution are much weaker, and their trendline slopes are also less steep. 
 
 
 
High Intensity: The results approve the hypothesis that the LED in full brightness provides sensitive and accurate estimation for a lower range of turbidity value (R2 = 0.9959). Despite the fact that the material of the 3d-printed container is reflective and it may be a factor interfering with the image capturing, especially when the turbidity value is very low.
 
 
 
Moderate Intensity: A strong linear relationship existed for standard turbidity solution at a range from 0 NTU up to 400 NTU. But the strong linear relationship only exists for clay solution at a range from 0 NTU up to 150 NTU. (Figure 5 and figures in previous experiments)
 
 
 
Low Intensity: The results of this experiment are not very ideal due to the outliers at 200 NTU, for an unknown reason. If we ignore the outliers, the overall linear relationship is still relatively strong. Regardless, the sensibility (slope) of the relationship is extremely low (0.0067 grayscale per 1 NTU). According to Figure 6, it is consistent that at this level of light intensity, the images are totally dark when the turbidity value is lower than 50 NTU, and the linear relationship is good from 50 NTU all the way up to 400+ NTU if the outliers at 200 NTU are a pure error.
 
 
 
===13 September 2022===
 
This experiment uses the solution synthesised with natural clay, again.
 
 
 
'''Camera'''
 
 
 
Same as the previous experiment.
 
 
 
'''Turbidity Solution'''
 
 
 
The solution is changed from the standard turbidity solution to the natural clay.
 
 
 
'''Methods'''
 
 
 
Same as the previous experiment.
 
 
 
'''Results'''
 
 
 
<gallery>
 
20220913 Experiment Result 1.png|Experiment Result
 
</gallery>
 
 
 
No correlation is found in this experiment. It is later found that too many large particles were suspended in the water and the ones above the level of camera view had already blocked most of the light from the LED. Hence, the camera was not able to capture proper images.
 
 
 
 
 
===14 September 2022===
 
This experiment removes the large particles which settled immediately and the turbidity range is 0-100 NTU.
 
 
 
'''Camera'''
 
 
 
Same as the previous experiment, with the exception that the focus of the camera is adjusted to the position where LED light illuminates from right above. It is noted that the OV7675 camera is a fixed-focus camera, the focus is "adjusted" by screwing out the lens.
 
 
 
'''Turbidity Solution'''
 
 
 
This experiment uses the solution synthesised with natural clay, removing the large particles which settled immediately. The range of turbidity in this experiment is 0-100 NTU, aiming to test the sensitivity of the sensor.
 
 
 
'''Methods'''
 
 
 
Same as the previous experiment.
 
 
 
'''Results'''
 
 
 
<gallery>
 
20220914 Experiment Result 1.png|1. Raw Experiment Data
 
20220914 Experiment Result 2.png|2. High Intensity (Range 0-50 NTU)
 
20220914 Experiment Result 3.png|3. Moderate Intensity (Range 10-100 NTU)
 
</gallery>
 
 
 
This experiment further proves or refines the following hypothesis:
 
# The high-intensity LED (20 Ohm) provides accurate and sensitive turbidity prediction from 0 to 50 NTU.
 
# The medium-intensity LED (470 Ohm) provides good turbidity prediction from 10 NTU. Its prediction for solutions smaller than 10 NTU is not accurate and sensitive.
 
# The low-intensity LED (4700 Ohm) is not able to provide prediction, it should be abandoned or changed to a relatively higher light intensity (smaller resistor) in future experiments. It is still hypothesised that a low-intensity LED can provide prediction in a greater range of turbidity values.
 
 
 
 
 
===31 Janurary 2023===
 
An image-processing-based method has been proposed for PSD analysis. To undertake a validating experiment for the proposed method, a 3d-printed sample container has been designed: the bottom of the sample container is a transparent plastic plate, and a white LED light panel is put below the plate to work as a backlight for the water sample. A shallow depth of water sample with soil and silt is put into the container, and the sample image is captured by a phone camera from right above. The algorithms to perform the image analysis are written in python script, and the script runs in the following steps:
 
 
 
[[File:Proposed_image-processing-based_method_for_PSD_analysis.png|500px|thumb|Proposed Image-Processing-Based Method for PSD Analysis]]
 
 
 
#  crop the image to the area of interest.
 
#  convert the full-colour image to a grayscale image (convert RGB values of each pixel to a grayscale value, ranging from 0-255).
 
#  optional denoising of the image with a Gaussian filter.
 
#  automatically or manually set the grayscale threshold, any pixel with a grayscale value higher than the threshold is considered as a portion of a particle (black) and any pixel with a grayscale value lower than the threshold is considered as the background (white).
 
#  apply the threshold value to convert the grayscale image to a binary image.
 
#  use Connected Component Analysis to count the number of black dots (i.e., particles) and calculate how many pixels build up each particle.
 
#  using the number of particles and sizes of these particles (in pixels),  it is hypothesised that the distribution function can be compared to the actual PSD analysis performed by the PSD analyzer.
 
 
 
Today's trial experiment found that the distance between the camera and the sample is too short for the camera to focus well, hence the images are blurred. In the next experiment, the 3d-printed container will provide a sufficient focus distance (~7cm).
 

Revision as of 01:28, 2 October 2024

Introduction

The PSD Sensor is a novel, low-cost camera-based sensor designed for near-continuous in-situ measurements of Particle Size Distribution (PSD) in stormwater. This sensor addresses the limitations of traditional PSD measurement methods, which are often expensive, labour-intensive, or unable to provide real-time data.

Key Features

  • Utilizes a self-developed and highly customised compact camera with a 25x macro lens
  • Employs image processing techniques for particle size estimation
  • Provides affordable (less than $100), low-power, and mini-sized solution
  • Capable of near-continuous measurements
  • Designed for field deployment in stormwater systems (work in progress)

Methodology

Image Acquisition

The core of the PSD sensor is the BoSLCam, a self-developed camera logger. Key features of the BoSLCam include:

  • Custom-designed PCB measuring 70 mm by 15 mm
  • Powered by a single 3.7V Li-ion battery
  • OV7675 colour camera module capable of capturing VGA (640x480) resolution images
  • nRF9160 chip for main microcontroller functions and LTE-M1 cellular connectivity
  • GPS location and time data acquisition capability
  • 23LCV1024 SRAM buffer for image data processing
  • SD card storage for captured images, and SIM card capability to upload images to FTP servers
  • Power-efficient design with sleep mode reducing current consumption to less than 400 µA
  • UART port for communication with external sensors and dataloggers

Image Processing

The image processing workflow consists of the following detailed steps:

1. Image Pre-Processing

  1. RGB to Grayscale Conversion:
    • The RGB image is converted to grayscale using the following equation:
      Grayscale = 0.299 × Red + 0.587 × Green + 0.114 × Blue
    • This equation is commonly used in camera-based measurement of turbidity.
  2. Fourier Transform and High-Pass Filter:
    • A Fast Fourier Transform (FFT) is applied to convert the image from the spatial domain to the frequency domain.
    • A high-pass filter with a cutoff frequency of 2 is used to mitigate background noise and enhance image contrast.
    • The process involves:
      1. Applying 2D Fourier transform to the grayscale image
      2. Shifting the zero-frequency component to the center of the spectrum
      3. Creating a high-pass filter mask
      4. Applying the mask to the shifted Fourier transform
      5. Performing inverse Fourier transform to obtain the filtered image

2. Image Segmentation (Thresholding)

  1. Threshold Determination:
    • A threshold grayscale value of 241 was determined to be adequate for the BoSLCam sample images.
    • This threshold distinguishes pixels representing particles (darker) from the background (brighter).
  2. Binary Image Creation:
    • The grayscale image is converted to a binary image where:
      • 1 represents particle (foreground)
      • 0 represents background

3. Feature Extraction

  1. Connected Component Labelling:
    • 8-connectivity is used to perform connected component labelling on the binary image.
    • This process identifies and labels patches of pixels that are grouped together, representing individual particles.
  2. Particle Size Estimation:
    • For each labeled pixel patch (particle):
      1. The pixel size is multiplied by the theoretical area-per-pixel value (e.g., 30x30µm for BoSLCam).
      2. Assuming spherical particles, the equivalent spherical diameter is calculated.
      3. Particle surface area and volume are also calculated based on this diameter.

4. Data Cleaning and Preparation

  • Particles larger than 500 µm (exceeding the proposed detection range) are excluded.
  • Histogram bins containing fewer than 2 particle counts are removed to mitigate potential noise effects, such as those caused by bubbles.

PSD Analysis

The sensor produces the following outputs:

  • Number-based (count-based) and volume-weighted particle size distribution histograms
  • Cumulative distribution curves
  • Statistical parameters such as D10, D50 (median diameter), and D90

Validation Results

Laboratory validation tests using standard particles of various sizes (38-355 µm) demonstrated:

  • Strong linear relationships (R² > 0.99) between the sensor's measurements and those obtained by a traditional laboratory analyser for key PSD parameters (volume-weighted D10, D50, and D90)
  • No significant differences in central tendency measurements for most size ranges, with some limitations observed for very small (<50 µm) and very large (>300 µm) particles

Future Work

Planned improvements and future research directions include:

  • Trialing a 100x microscopy lens to improve measurement accuracy for smaller particles
  • Optimizing the image processing algorithm and calibration method
  • Investigating the underestimation issue for larger particle sizes
  • Developing a field-ready sensor and testing with real-world stormwater samples
  • Exploring machine learning algorithms for improved particle detection
  • Investigating simultaneous measurement of other water quality parameters such as turbidity and TSS

References

For a complete list of references, please refer to the original research paper (currently not available, but contact Canwei if you are interested).