Fast Forward AG "FAST EnergyCam" - “Der zum Patent angemeldete optische Sensor mit Kamera und OCR-Erkennungsalgorithmus erfasst den aktuellen Zählerstand und übermittelt die Daten per Funk oder drahtgebunden zur Weiterverarbeitung”.
“Ich habe mich mit einem System beschäftigt, das aus einem RaspberryPI mit einer Kamera (USB-WebCam oder RaspiCam) besteht. Die Kamera wird am Zähler so befestigt, dass die Zählerwerk aufgenommen werden kann. Die Bilder werden mit OpenCV vorverarbeitet und dann wird der Zählerstand mit einem schnellen, einfachen und effizienten Algo digitalisiert (kein Tesseract). Pro Durchlauf braucht PI aktuell um die 1-1,5 Sek (die meiste Zeit wird für Bildaufnahme benötigt)”.
“Da ich zuerst nicht ausreichend genug rechechiert hatte, dachte ich, dass es sich nur ein paar Bastler mit solchen Themen beschäftigen. Nun habe ich u.A. euch entdeckt. Die Sache ist, dass ich meine Lösung später kommerzialisieren wollte. Meine Recherche hat aber ergeben, dass es seit ca. 2007 einige Unternehmen gibt, die ähnliche Lösungen anbieten (OCR). Manche haben sogar eigene Kamera-Sensoren dafür entwickelt. Da anscheinend die Nachfrage nicht vorhanden ist...”.
“Zurzeit wird der Zählerstand problemlos (bis auf ein paar Kleinigkeiten) erkannt (ich habe meine Software mit einem Strom- sowie mit einem Gaszähler getestet). Es gibt aber einige Sachen, die noch ausgebessert werden könnten, dazu erzähle ich bei Bedarf mehr. Desweiteren habe ich einige Ideen bzgl. des Sensors, der an einem Stromzähler befestigt wird, um die Umdrehungen des Rads zu zählen. Ich wollte eine komplette Lösung anfertigen, die aus einem Sensor besteht, der über eine Funk-Schnittstelle (RFM12+Atmel oder Arduino oder gar WiFi) den Stand an den Server weiterleitet. Leider ist die Nachfrage ziemlich gering”.
The product to be developed, a smart meter will collect data from the mechanical metering devices for water, gas, electric power, and put it in an building automation network, or even in the cloud.
As permanent device, e.g. at private households or public / industry buildings. If you connect it by magnets, think about if the untility company which owns the meter would like this: Magnets might disturb electrical, electronics or mecanical meters in ins proper operation.
As portable device.
To give you the clue for another application of the technology, think about low-skilled people who have to go to meter devices in a customer's ( private, public, industry ) building, to read and to document the data by writing down the values on paper or typing the numbers on a computer, manually. They might now get a portable device -our product - and just record the data by buttonclick.
Project approach is to do rapid-prototyping of prototypes with different aspects, in different programming languages on different platforms, to become familar with the problem and to find a solution. The solution must not be on the level of a true deliverable product useful for customers.
College student teams might also join, as the college lecturer might ask the college students to do own implementation of the tasks, even in different programming languages on different platforms.
First step is that the project participants ( e.g. the college students ) take their smartphones or digital photo cams, and photograph their own meters at home, and take the photos to the project. So the project particpants document something from their daily life - here the front picture of their meters in their flats, and then process the item by self-written software.
Most of the meters are same in looking? Yes, as energy monitoring for private households is a regulated industry. I.e. a unity company or the state defines which devices are acceptable, or even distributes the devices.
By that the project participants will first realize problems to take a single static snapshot: The problems with little light where meters are attached, problems with flash of smartphone cams and regular digital cams ect.
Now there are 3 implementation aspects of the project.
Create applications to take photos on different hardware platforms ( smartphone, desktop/notebook pc, embedded device ) and different software platforms ( Windows/Linux desktop including embedded devices, Android OS on Android smartphones / iOS on iPhone smartphones, bare-metal implementations on embedded devices ).
So “My first smartphone app for Android in Java” would be a good starting sub-project - To use the camera software of the smarthone to take a photo and to store it.
Image processing ( e.g. with OpenCV, or commercial tools by National Instruments “NI Vision” at colleges or companies with some budget ). Further thinking is required:
Lighting: Normal lighting causes reflections at glas, which might make photo unusable. I was told by experts, that Infrared lighting causes much less or even no reflections at glas.
Preprocessing of images:
Take a series of photos, instead of just 1 image. The “difference” between the images, especially if taken by a cam hold in hand, might be used to enable or improve the image processing.
Display window.
Contrast.
Reduction of color debth to 1 bit. Be aware of meter numbers in different colors ( most numbers are black / white, but there is always the lowerst number which is in red ).
On Android where the apps are typicall written in Java, or on Windows Apps for Desktop or WinPhone, its not so easy to integrate a true C library. No problem on Windows or Linux Desktop.
But as the image quality might be so limited, and the device weight is a limiting factor ( a prototype device beyond the project might be glued by vacuum cup to the glas of the metering device display ), its a question if the image processing should be done on the device, or later in the network or in the cloud.
OpenCV is C, but you can do development in most other languages too, and there is no need for Object-orientation ect. e.g. with the “Visual Studio” IDE, or there is a Python interface.
So first step would be “take a photo of the meters at home, and make recognition of the serial number and the current data of the device, with help of OpenCV. But the project participants need little knowledge about software programming, the resulting developed software are just simple linear programs with maybe some loops.
Rapid prototyping means using frameworks and ready-made tools, and to add just few %s of own work, to get a working solution. So the pattern recognition is either the topic of the sub-project ( requireing just very basic programming skills ), or the sub-project might be an introductory computer programming course where the pattern recognition is to be taken as magic and not really taught in detail.
You may even skip the pattern recognition totally. Without pattern recognition, it is the task to create an application which take a series of photos ( not really necessary to be a video stream ) and to transfer the photos to the cloud. Then of course you will have massive bandwidth and storage problems.
The transfer of the data to the cloud, using cloud provider for metering data ( with free entry-level accounts ), or own cloud solution. E.g. on IBM Bluemix, Heroku,..
Wifi and (proprietary) WAGO Industrial Bluetooth are the usual wireless options to communicate with PLCs.
As of 2015: The (proprietary) Industrial Bluetooth has an extended range (e.g. 1000m ) and needs a special Android app by WAGO to access data on a smartphone.
In 2016, the market might change if WAGO develops its CodeSys3-based “e!Cockpit” development and runtime solution.
There are some normed communication protocols ( e.g. Wireless M-Bus ) many other (proprietary) wirless communication solutions of smart meters with its PCLs and distributed ( building ) control systems.
About the result of an end customer survey for the prefered user interface of a smartphone app which displays smart metering information: The smartphone app with the photo of a traditional non-smart meter was prefered, over a just-numberic interface, and an interface with a progression / trend display .
End customers prefer experienceable measurement ( “°C”,.. ) instead of technical values ( “KWh”, “KW”, “m3” ).
Tip by a photographer: Put a piece of white paper in front of the flash, to improve the image quality when doing near shots ( here: if there is a low distance between cam and mechanical meter display, to get a full resolution image of the display ).