Kategori: Kameror
Vattenmätning med Raspberry Pi och webkamera
finkman förbarmar sig över oss med ännu ett intressant hembygge af rang! 😀
Det är inte mycket som står utan övervakning hemma längre, så för att mätta mätbegäret så fick vattenmätaren ställa upp denna gång!
En kollega pratade på jobbet om denna artikel i Ny Teknik. När jag till slut slaktade det förra projektet (bilspegel…) så hade jag helt plötsligt all nödvändig hårdvara över. Basen till mjukvaran hade Göran Lundquist vänligt nog delat med sig av på mysensors.org, och på Görans Youtube-klipp såg vi ut att ha likadana vattenmätare! Vad väntar jag på? 🙂
Dags att snickra lite hårdvara..
För att kameran ska få lite ljus så behövs dioder. Jag hittade en påse med vita 3mm-dioder hemma, jag tror det var såna här. Jag anslöt dem iallafall efter den specen, 3,3v, 20mA, och de såg ut att må rätt bra. Nu behöver jag ju inte maxa dioderna, och det lyste skapligt trots att jag tog lite högre motstånd och anslöt bägge dioder genom bara ett motstånd.. På bilden använder jag ett 10 Ohm-motstånd. Dioderna är parallellkopplade för att få ut samma spänning till de båda, men båda två är kopplade i serie med motståndet för att begränsa strömen till båda dioderna. Man måste hålla reda på polariteten här också, katoden, det korta benet på lysdioderna, ska anslutas till minus. Här har jag båda korta ben lödda till den vita kabeln.
Så, hur ska jag spänningsmata dioderna i drift då? Visst finns det väl en 3,3v-pinne på Raspberryns GPIO? Jepp! Pinne nummer ett! Max 50mA last får anslutas till 3,3v-pinnen, men mina dioder mätte in på bara 22mA tillsammans.
Snyggast här hade varit att använda typ sånahär kablar med fin-kontakt , en lite mindre GPIO-ribbon eller liknande, men jag hade ingen sån. Jag bröt ur några hylsor ur en lite bredare breadboarding-sladd med fyra parallella sladdar i kontakten, och satte krympslang runt de enskilda metallhylsorna.
Därefter så löd-skarvade jag på de gråa kablarna på den partvinnade brun-vita och kopplade i. Långa benen på dioderna till +3,3v på pinne 1, korta benen på dioderna till jord på pinne 5 på GPIO-pinheadern. Varde ljus!!
Raspberryn är helt i standard-setup. Ni får kolla på mina tidigare blogginlägg eller så om ni vill ha detaljer på hur installera Raspbian, konfigurera WLAN och sånt. Inget annat krävs egentligen, bara en grundinstallation, koppla upp med trådbundet nätverk eller WLAN, och koppla i en webcam i USBn. Jag använder denna, som funkar utmärkt för ändamålet. Det gick till och med att ställa skärpan på kameran genom att vrida på linsen, vilket var mycket bra eftersom kameran kommer sitta bara ett par centimeter från mätartavlan. Ta det dock försiktigt när ni ställer fokus på kameran! Jag tror jag lyckades knäcka min när jag satte i kameran i hållaren, men efter en stund av pillande så verkade den ta gäng igen och jag fick skärpa.
Kamerahållaren.. Det här tog ett par prototyper. Göran i Ny Teknik-artikeln använde sig av avloppsrör och konstruerade en hållare, vilket ser väldigt snyggt ut. Jag hade inget avloppsrör i rätt storlek, så mitt första test blev att såga av en PET-flaska. Det funkade iofs bra, men jag fick inte till passformen helt rätt, vilket gjorde att flaskan kunde röra sig några millimeter mot glaset. Inget större problem kan tyckas, men det blev uppenbart sen när jag började prova mjukvaran att kameran måste stå still. Att flytta kameran någon millimeter gjorde nämligen att mätarnålen som kameran kikar på hamnade på fel ställe i bilden, nog för att stoppa mätningen.. Tillbaka till Ritbordet.
Första prototypen, PET-flaska.
Mycket mer stabilt!
Drömen att ha en 3d-skrivare infann sig här. Man hade kunnat skriva ut en måttanpassad hållare till kameran som styrde upp situationen direkt.
Istället så började jag söka runt i huset efter saker som kunde passa i denna 56mm-mässingscylinder. Efter någon timmes mätande så hittade jag en sprayflaska med startgas från OK, vars lock passade perfekt i mätaren. Jag sågade av locket så den blev c:a 2,5-3cm hög, och borrade sedan ett 16mm hål med en stegborr vid den ena kanten på locket. Stegborr är grymt till sånthär eftersom det blir så fina snitt i plast, hålet hamnar på rätt plats direkt utan att man behöver förborra ett mindre hål, och man kan prova sig fram till vilken storlek på hålet som blir perfekt, ett steg i taget.
I PET-prototypen så hade jag liksom Göran borrat hål i plasten och tryckt igenom dioderna. På det vita locket så tyckte jag att det blev jättebra ljus när jag satte dioderna på utsidan, så jag tog fram limpistolen och limmade fast dem mot kanten, riktade innåt-uppåt. Det visade sig senare vara lite flimmer på dioderna som störde bilden, men det löste sig genom att rikta upp dioderna lite mer så de inte lyste så direkt rakt in genom plasten. En annan tänkbar lösning skulle kunna vara en kondensator parallellt med dioderna, men kan det verkligen vara så mycket rippel på 3,3v-pinnen?
Nåja. På med ljuset och igång med mjukvaran! .
Mjukvaran
För att förklara konceptet så har jag lagt upp en film här: https://www.youtube.com/watch?v=eY8Oq6jhPGk
Dags att borsta av gymnasie-kunskaperna i C-kod.. Bleh, det var ett tag sen. Men det är ändå mycket, mycket lättare att förstå och ändra befintlig kod än att skriva hela från grunden själv, det hade jag nog inte klarat. Åter igen ett stort tack till Göran som la upp sin programvara! Det primära som behövde göras var att ta bort beroendet till Mosqitto-message brokern som Göran använder, eftersom jag inte har en sån själv. Jag slog till med några andra små ändringar också, däribland stöd för att logga den uppmätta liter-siffran till en rrd-databas.
För att få igång programvaran för vattenmätningen så krävs en förberedelse, installera detta paket på Raspberryn:
sudo apt-get install libsdl1.2-dev
Vidare så laddade jag hem och installerade det senaste RRDtool under /opt/rrdtool-1.5.4 , för att kunna använda den nya datatypen DCOUNTER i databasen, som COUNTER, fast man kan använda decimaler. RRDtool-paketet som följer med i Raspbian är ganska gammalt, och mycket nya funktioner finns i senare versioner.
Kort för att ladda hem och installera RRDtool:
sudo apt-get update
sudo apt-get install libpango1.0-dev libxml2-dev
wget http://oss.oetiker.ch/rrdtool/pub/rrdtool-1.5.4.tar.gz
tar -xvzf rrdtool-1.5.4.tar.gz
cd rrdtool-1.5.4
./configure --prefix=/opt/rrdtool-1.5.4
make
sudo make install
Medans vi ändå håller på, passa på att skapa biblioteket “water” i pis hemkatalog:
cd
mkdir water
Ladda sedan hem och kompilera min modifierade avläsningsmjukvara här: water-meter1.1.tar.gz
wget http://blog.m.nu/wp-content/uploads/2015/10/water-meter1.0.tar.gz
tar -xvzf water-meter1.0.tar.gz
cd water-meter
<här finns utrymme att kolla i koden (framförallt water-meter.c),
kolla så att alla sökvägar stämmer osv. För att kompilera, kör sedan:>
make
Om jag inte har glömt något nu, så borde koden kompilera snällt och en binär bör dyka upp, “water-meter”, utan något suffix.
För att kalibrera träffpunkterna och testa mjukvaran så har Göran lagt in ett läge där man kan se bilderna och träffpunkterna från kameran i mjukvaran. Denna når man genom att köra:
./water-meter -di
För att göra detta så behöver du antingen köra i grafiskt läge i Raspberryn, eller göra som jag och använda Putty och VcxSrv för att få upp Raspberryns grafiska appar på min Windows-dator. I grova drag, installera VcxSrv på Windowsdatorn (gärna en laptop, underlättar att kunna vara nära kameran för att göra kalibreringen), starta VccSrv på Windowsdatorn och koppla sedan upp till Raspberryn via ssh med Putty, med dessa iställningar ifyllda:
Därefter bör det gå att få upp det water-meters grafiska läge på Windows-PCn!
Om du inte har någon X-server till förfogande, varken Raspberryns grafiska läge, VcxSrv eller liknande, så gör applikationen en “segmentation fault” och dör direkt när du försöker starta ./water-meter -di.
Iallafall… När du har fått igång det grafiska läget, så bör det se ut ungefär som i början på denna video (texterna “Running..” och “Got camera!” visas inte längre, de tog jag bort efter inital debugging).
Den enda skillnaden på din bild är att de gröna rutorna säkert inte kommer att matcha den röda mätaren på bilden, om du inte har lyckats positionera kameran preciiiis som jag. Att flytta de gröna rutorna åtgärdas genom att editera i REGION-blocket i water-meter.c. Enklast tyckte jag var att göra en printscreen, klistra in bilden i Microsoft Paint, zooma in, flytta bilden så webkamerans bild hamnade precis i det övre vänstra hörnet, sen föra muspekaren över bilden och kolla på pixel-siffrorna nere i vänstra hörnet på Paint. Därefter mata in positionerna i water-meter.c , kompilera om med “make”, starta “./water-meter -di” igen, göra samma sak och finjustera. Justja, för att döda water-meter, tryck ctrl+z för att få tillbaka skalet, kör “ps” i skalet, kör sedan kill -9 <processnumret för water-meter>.
Mätaren vi siktar in oss på är 0,0001-snurran, dvs ett varv motsvarar en liter. Åtta punkter runt den mätaren ger alltså en upplösning på 0,125l, rätt bra tycker jag! Om man är äventyrslysten och lyckas placera kameran riktigt nära mätaren så kanske det går att klämma in fler punkter, vilket det verkar finnas stöd för i koden (ändra konstanten NUM_REGIONS). Om kameran hamnar långt ifrån mätaren och mätaren blir pytteliten i bild så kanske det är läge att minska till fyra punkter.
Hu, nu blev det mycket text. Vi tar en paus till bilden som visar hur jag limmade fast kameran i hållaren när allt började kännas bra. Ett par spritpenna-streck mellan fästet och mätaren också för att kunna få tillbaka locket i rätt position om man vill kolla till mätaren manuellt nån gång ibland:
Sådärja, nu är vi nästan där! Om allt känns bra, och mätaren träffar de röda prickarna i rätt följd när den snurrar, så är det dags att gå vidare med loggningen. Förresten så tyckte jag det var bra att spola vattnet sakta för att prova in träffpunkternas positioner, då var det mycket lättare att se studsar mellan träffpunkter och sånt. Om det strular, prova att flytta isär punkterna ett par pixlar och försök igen.
När allt är intrimmat med kameran, starta “./water-meter” utan “-di” för att skippa det grafiska läget. Då kan man koppla ner från Raspberryn och mätningen fortsätter. Om man vill ha den exakta litersiffran i loggen så kan man starta ./water-meter med argumentet -start_value, “./water-meter -start_value 610595” i mitt fall, baserat på mätarställningen på mätaren längst upp till höger i detta blogginlägg. Startvärdet läggs därefter till totalen i loggfilen, /home/pi/water/water-meter-total.log , som uppdateras och läses in automatiskt vid nästa start, så vid nästa start ska man alltså inte ange -start_value igen.
Som en sista grej på mjukvaran kan nämnas att det ligger lite startscript och grejor med i tar-filen ovan. T.ex. så finns Görans (lätt modifierade) water-meter.sh i mappen, som kör water-meter i en loop utifall den skulle krascha, med en reset av usb-webbkameran inklämd innan den startar water-meter igen. Det har inte hänt så ofta, men ibland när jag startat water-meter så har det bara kommit upp brus på bilden, något som tydligen Göran också hade problem med eftersom han skrev verktyget “usbreset”. Init-scriptet (water-meter.init.d) har jag inte testat, det lär behöva lite handpåläggning för att funka.
Att skapa rrd-filen
cd
cd water
/opt/rrdtool-1.5.4/bin/rrdtool create water.rrd \
-O -s 60 DS:water:DCOUNTER:120:0:U \
RRA:AVERAGE:0.5:1:43200 \
RRA:AVERAGE:0.5:30:175200
Här kan man alltså tänka sig att skippa decimalerna om man inte är så noga, och då byta ut DCOUNTER mot COUNTER, och därigenom slippa installera RRDtool manuellt som beskrivet ovan.
Detta bör ge en water.rrd i /home/pi/water/ , vilket lämpligt nog är sökvägen som står förifylld i konstanten WATER_LOG_RRD_FILE längst upp i water-meter.c
När water-meter sedan kör, så kommer programmet att anropa rrdtool update en gång i minuten med det senaste total-litervärdet. Om du vill verifiera att allt kör, kolla t.ex. med ls -al att timestampen på filen water.rrd uppdateras varje minut, eller gör en rrdtool dump för att kolla att värdena kommer in i databasen.
Graferna då?
Här är det inte lika självklart som annars var man vill ha, det beror nog lite på vad mätningen är tänkt till. Jag var lite nyfiken på att se hur mycket olika saker i hemmet gör av med, och för det mesta så har vi noll vattenflöde. Därför så är min primära graf en halvtimme lång (för att få hög upplösning på förbrukningen) och graderad i liter per minut. Noggrannheten i min setup står ännu oprövad efter bara ett par timmar helt igång, men det lär väl ge sig efter en stund hur bra det blir, hittills så ser det ut att träffa inom ett par procent iaf.
Här ser man tex. på de högra staplarna att jag spolade vatten i tre minuter, första minuten i ~1,5l/minut, andra minuten i ~0.4l/minut och sen ökade jag upp till 2,6l/minut. Totalt 4,5l på den omgången alltså.Den här grafen är skapad såhär:
/opt/rrdtool-1.5.4/bin/rrdtool graph /var/www/water_usage_30min.png \
-E \
--imgformat PNG \
--start -30m \
--end now \
--width 600 \
--height 400 \
--title "Water usage, litres/minute, 30min" \
--vertical-label 'l' \
-X 0 \
-l 0 \
DEF:water_value=/home/pi/water/water.rrd:water:AVERAGE \
CDEF:water=water_value,60,* \
AREA:water#0099FF \
LINE1:water#000000 \
VDEF:sum=water_value,TOTAL \
GPRINT:sum:"Total usage\: %0.2lfl\n"
Graferna lägger jag direkt i webb-roten /var/www/ , så kommer de direkt ut på Raspberryns webserver (sudo apt-get install apache2) Vidare så skulle man kunna tänka sig en graf över ett dygns förbrukning på samma sätt, fast denna gång utan CDEF-räkningen i mitten, så i det här fallet så blir graderingen liter per sekund:
/opt/rrdtool-1.5.4/bin/rrdtool graph /var/www/water_usage_24h.png \
-E \
--imgformat PNG \
--start -24h \
--end now \
--width 600 \
--height 400 \
--title "Water usage, litres/second, 24h" \
--vertical-label 'l' \
-X 0 \
-l 0 \
DEF:water=/home/pi/water/water.rrd:water:AVERAGE \
AREA:water#0099FF \
LINE1:water#000000 \
VDEF:sum=water,TOTAL \
GPRINT:sum:"Total usage\: %0.2lfl\n"
I RRDtool är det bara fantasin och tiden man orkar lägga på manualläsning och Reverse Polish Notation som sätter gränserna. Man kan tänka sig att grafa kubikmeter i timmen eller vad som helst, det är bara köra en uträkning med CDEF och grafa. Min fantasi tog stopp ungefär här, så om någon provar detta och kommer på en bra graf, säg gärna till! Mina (mycket tråkiga, vi använder tydligen jättelite vatten) grafer finns på http://vatten.nykil.net. Jag önskar att jag hade haft denna lösning i somras när jag glömde droppslangen till en nyplanterad buske igång över natten, och spolade ut förmodligen några kubik över grannskapet.. Där är en grej som man skulle kunna spinna vidare på, Göran Lundquist nämnde i artikeln med Ny Teknik, han hade precis det som jag hade behövt då, ett larm som varnade om hög vattenförbrukning hemma.
Men det får bli en annan dag det!
Hälsningar,
Jim
Raspberry Pi med kameramodul som övervakning
Uppdatering: Denna funkar fint som övervakningskamera på Home Center Lite / 2! Se intruktioner längst ner för hur man lägger till den.
Ett billigt alternativ till “riktiga” övervakningskameror är att använda sig av Raspberry Pi. Innan kameramodulen släpptes var det klurigt att veta vilka webbkameror som fungerade, men å andra sidan fanns bra mjukvara att använda för att streama bilden från kameran (t.ex. Motion, som har inbyggd rörelsedetektion). Nu är problemet det omvända, kameramodulen till Raspberry Pi fungerar väldigt bra men stöds inte av Motion.
Som tur är har en kodare vid namnet dozencrows släppt en hemmaknackad version av Motion, byggd speciellt för Raspberry Pi:s kameramodul. Så det ska vi titta på i detta inlägg!
Github-sida för projektet i fråga: https://github.com/dozencrows/motion/tree/mmal-test
Enligt utsago innehåller dessvärre inte denna Github all kod som krävs för att själv bygga projektet, men den senaste testversionen finns färdigkompilerad och körklar här: https://www.dropbox.com/s/jw5r1wss32tdibb/motion-mmal-opt.tar.gz
De två viktigaste delarna för detta bygge är en RPi (helst B eller B+ eftersom de har inbyggt nätverk och tillräckligt med USB-portar), och kameramodulen (funkar även med NoIR men det har vi inte testat). Andra tillbehör är t.ex. USB-Nano-WiFi, om man vill ha trådlöst. Alla tillbehör man kan behöva finns i paketkonfiguratorerna!
https://www.m.nu/raspberry-pi-raspberry-pi-c-97_96.html
https://www.m.nu/camera-module-for-raspberry-pi-p-848.html
Innan vi kan köra Motion måste kameramodulen anslutas och aktiveras. För att vara på den säkra sidan börjar vi med att uppdatera mjukvaran:
sudo apt-get update
sudo apt-get upgrade
Kameraporten är tydligt utmärkt på B+, men är du osäker på hur man ansluter den finns det massor av guider på internet.
Att sedan aktivera den görs genom att köra sudo raspi-config och välja alternativet Enable Camera. Därefter väljer man Enable och avslutar konfigurationsprogrammet och startar om Pi:n.
För att alla applikationer som Motion är beroende av ska installeras, installerar vi helt enkelt den vanliga versionen av Motion, tillsammans med libjpeg62 (annars klagar motion vid uppstart):
sudo apt-get install motion libjpeg62
Vi kommer aldrig använda denna version av Motion, utan laddar istället ner och packar upp den modifierade versionen ovan. I mitt fall packade jag upp den i /home/pi/motion. Vill man göra detta från terminalen kan man skriva följande:
cd ~
wget https://www.dropbox.com/s/jw5r1wss32tdibb/motion-mmal-opt.tar.gz
tar -zxvf motion-mmal-opt.tar.gz
cd motion-mmal
Nu hamnar vi i undermappen som skapas. Innan vi kör igång vill vi modifiera inställningarna för programmet för att passa våra behov. Detta gör vi genom att dubbelklicka på filen motion-mmalcam.conf eller från terminalen:
leafpad motion-mmalcam.conf
Vad man nu vill använda för inställningar får man prova sig fram till, men ha i åtanke att RPi har begränsad prestanda så begränsa inställningarna därefter. Motion har stöd för olika typer av streaming baserat på rörelsedetektion, ljusförändringar med mera så det finns massor av inställningar att leka med om man vill. Jag anser att följande rader är av intresse, och har angett de värden som jag testat med (sök efter strängen för att hitta lätt, och ändra till värdet till höger):
width 352
height 288
framerate 2
output_pictures off
target_dir /home/pi/motion-video
logfile /home/pi/motion/motion.log
Anledningen till den låga frameraten är att vid högre frekvens fick jag vissa problem med streaming till Firefox, där webbläsaren till och med kraschade vid ett tillfälle. Den villige kan såklart experimentera fritt med dessa inställningar, antagligen kan man få ut högre framerate.
Innan vi börjar köra Motion vill vi försäkra oss om att vi inte råkar starta den normala versionen, som också är installerad, istället för den RPi-anpassade. Därför döper vi om den exekverbara filen från motion till motion-mmal, vilket görs med F2 i utforskaren, eller kommandot “mv motion motion-mmal” om man står i mappen i terminalen.
Nu kan vi provköra! Från terminalen, kör följande:
./motion-mmal -c motion-mmalcam.conf
Vi behöver specificera konfigurationsfilen, som synes. Nu startar applikationen och spottar förhoppningsvis inte ut några fel, och om vi besöker RPi:ns IP-adress på port 8081 från webläsare på en annan dator bör vi kunna se vad kameran fångar upp! Strömmen skickas ut på port 8081, så för att se denna skriver man http://IPADRESS:8081 där IPADRESS är den lokala IP-adress RPi:n har på nätverket.
Uppdatering Fibaro Home Center:
Att sedan lägga till kameran som övervakningskamera i Home Center Lite var inga som helst problem, man lägger helt enkelt till en ny kamera, väljer “Other model”, och fyller i samma adress (utan http://) under “IP Address”. Så här ser det ut när det är färdigt:
Mycket nöje!

Kul att du gillar vår blogg!
Skriv upp dig på vår maillista för att få allt det senaste från m.nu - Nya produkter, kampanjer och mycket mer!
Wohoo! Du är nu med på maillistan!