This project details an open source water testing platform derived from the open-source colorimeter, which is made from open source electronics and 3-D printable components. This is part of a larger project to reduce the cost of scientific equipment using open-source hardware.Bas Wijnen, G. C. Anzalone and Joshua M. Pearce, Open-source mobile water quality testing platform. Journal of Water, Sanitation and Hygiene for Development, 4(3) pp. 532–537 (2014). doi:10.2166/washdev.2014.137 open access
Abstract[edit | edit source]
The developing world remains plagued by lack of access to safe drinking water. Although many low-cost methods have been developed to treat contaminated water, low-cost methods for water-quality testing are necessary to determine if these appropriate technologies are needed, effective, and reliable. This paper provides a methodology for the design, development, and technical validation of a low-cost, open-source (OS) water testing platform. A case study is presented where the platform is developed to provide both the colorimetry for biochemical oxygen demand/chemical oxygen demand and nephelometry to measure turbidity using method ISO 7027. This approach resulted in equipment that is as accurate, but costs between 7.5 and 15 times less than current commercially available tools. It is concluded that OS hardware development is a promising solution for the equipment necessary to perform water quality measurements in both developed and developing regions.
Keywords[edit | edit source]
Design[edit | edit source]
- Design files:
The device's firmware: https://github.com/mtu-most/colorimeter
BOM[edit | edit source]
Source Files[edit | edit source]
For the most up to date - see the github page: https://github.com/mtu-most/colorimeter
For 3D printing use:
For editing use:
For any libraries - again go to github for the MOST SCAD libraries.
Required Components[edit | edit source]
- Arduino Fio and a programmer board, if necessary
- AdaFruit LCD shield and a 3.3V LCD unit (Important: if you get a 5V LCD, you would need to power it from an external source when connecting to the Fio controller, by connecting the external directly to the shield pins for GND1/GND2 and VIN - as indicated on this link.
- 1x 860nm infra-red LED
- 1x 620nm orange LED (both standard T1 ¾ sizes)
- 3x light to frequency encoders (TSL235R)
- Wires, soldering iron and solder
- Filament for the 3D prints
Build Instructions[edit | edit source]
Solder the components of the AdaFruit shield and LCD following the tutorial on Adafruit's website. Test if all is correct with the LCD by running the AdaFruit code on the same tutorial page.
Connect the two LEDs, the LCD and the sensors to the Arduino Fio as shown in the schematic. Upload the firmware code to the Arduino and test whether everything is working correct. Important: to compile the firmware, you need the LcdMenu and DuplexFrequencyCounter libraries from another repository.
3D printing[edit | edit source]
In case you experience extensive warping (layers coming apart from each other), you can try to print the case in two parts, using separate models: the test vault with the sensors on the one hand, and the box for the LCD with the Arduino Fio, on the other hand.
Layout[edit | edit source]
When putting in the box, cut 3 PCBs the size of 200x350mm and solder each LED on a PCB with the encoder sensor looking at it (so each PCB will have a LED and a reference encoder). The final third encoder sensor goes on a PCB of its own. The following images show the layout inside the box:
When finished, you can close the box with screws and put the printed buttons in place.
Menu Items[edit | edit source]
The two tests are COD and Nephalometry. The menu offers the following options (listed in the order they are normally used):
- Zero – necessary to nullify values of the orange LED before measuring.
- Calibrate – calibration just returns the sensor value.
- Measure – measurement returns turbidity and other values.
- Re-calibrate – erases calibration.
- Calibrate – calibrate the samples. Normally, it is done with Formazin Turbidity Standard (400 NTU) diluted with distilled water. Example: Prepare solutions of 2, 4, 40, 100 and 200 NTU. Put a sample in the device and choose Nephalometry → Calibrate.
The Calibrate function returns "Calibration Read | More time needed" until five values are read, and "Calibration Read | Error: number after calibration was finished.
- Measure – measurement returns results in NTU and index. Index is simply a serial number for keeping track of measurements more easily – it increases by one after each measurement.
Warning[edit | edit source]
There are many aspects of water quality. COD and nephalometry are only two measurements of specific properties. Depending on the context which you are working and the questions you are trying to answer, these two measurements may or may not be enough!
Applications[edit | edit source]
See also[edit | edit source]
- Open-source colorimeter
- Open-source Lab
- Open-Source Photometric System for Enzymatic Nitrate Quantification
- Open source optics
- Building research equipment with free, open-source hardware
- Open source science
- Open source 3-D printing of OSAT
- Open-source hardware
In the News[edit | edit source]
- Open-Source Water Quality Tester - Hackaday
- Open Source Water Testing Platform is 3D Printed - Make Magazine
- 3D Printed Water Quality Testing Device Offers Affordability and Portability to Test Potability - 3D Print
- Open source 3D printed water quality tester- 3Ders
- Solar Water Disinfection - The Water Network
- 3D列印的開放原始碼水質測試平臺 - Make Taiwan
- Hack the Earth - Arquitecturas Colectivas (Spanish)
- Drukowany tester wody Open Source Swiatdruku3D (Polish)
References[edit | edit source]
- Open source lab
- Pearce, Joshua M. 2012. "Building Research Equipment with Free, Open-Source Hardware." Science 337 (6100): 1303–1304. 
- Brittney Dawney and Joshua M. Pearce, "Optimizing the solar water disinfection (SODIS) method by decreasing turbidity with NaCl", Journal of Water, Sanitation and Hygiene for Development 2(2) pp. 87-94 (2012). DOI Open access