Sunday, April 5, 2015

Reducing the Number of Colors (Part II)

A while ago I made an algorithm in Matlab to reduce the number of grayscales in a black&white image (link). And after that I tried to do the same with a color image (link) which didn't work out that well.

Image of flowers with only 12 colors


I was kinda busy with a lot of things, but the wish to try again was always somewhere in the back of my head. A couple of weeks ago I reviewed an online course I followed on Coursera on Machine Learning. This is probably the one of the best courses I have followed, but like with all things, if you don't use the skills learned frequently you loose the skills. But still I remembered some of the topics and what I in particular wanted to learn again was clustering.

In the topic of clustering you let the algorithm you make search for groups of points lying close together. I don't want to explain the whole subject here, and since the course explains it so perfectly I would suggest to watch the movies there.
I believe they have opened the course in such a way now that you can follow it at any moment now and don't have to wait for a new session to start. If you ever want to learn about fitting data, computer learning, Matlab/Octave programming this is a great place to start.

Back to my small project.

Finding Clusters in RGB space

The colors in an image have three values red,green and blue for every pixel. I view these as point in a cube which has sides going from 0 to 255. If there is i.e. a lot of sky in an image there will be lot of points with a light blue color close to each other in this cube. I want to find that cluster of points.
Time for an example.

original picture
picture with only 12 colors

In the pictures you can see the result of my algorithm. I have looked for clusters in the RGB cube, 12 in this case. In the end every pixel belongs to one of the clusters and the original color is replaced with the mean color of the cluster.
The result looks pretty good in my opinion. I could make a nice paint by numbers picture with this :)
But how does it preform on other images? And does it always give the same result?
That second question is not a trivial one. I choose my start point (the average point of the clusters) at random by taking points from the image (the RGB value of pixels in the original image).

Example 2: Room for improvement


The top image is the original image and the three images after that are from three different runs. When you inspect them closely you notice that they are quite different. Why is this happening?
First of all, I only let the algorithm run for a short time, and I'm not even checking if it has in any way finished. With finished I mean that a new step in the calculation doesn't change the answer.
Second of all the starting point determine the outcome. I would have do do this calculation a lot of times and then take a sort of average of the end results and maybe throw away bad results.

Hope to come back soon with a Part III to this topic. 







Friday, April 3, 2015

Handschoen Richtingaanwijzer

In Maakbare Wereld van de Volkskrant van zaterdag 4 april heb ik geschreven over mijn handschoenen die ik heb uitgerust met een richtingaanwijzer voor als je aan het fietsen bent.

Hiervoor heb ik een Adafruit GEMMA gebruikt en een Neopixel. Informatie hierover kun je bijvoorbeeld hier vinden. Het mooie van dit product is dat je het op een stof kunt naaien met geleidend draad en daardoor hoef je vaak niks te solderen. Het programmeren is redelijk eenvoudig, hiervoor heb je de Arduino programmeeromgeving nodig. Ik heb hiervoor de aangepaste versie gebruikt die je kunt vinden op de Adafruit website, klik hier. Download de versie die bij je computer past en volg de instructies goed.
Ik had hier verder geen problemen mee, maar dat kwam denk ik ook omdat ik al eerder een Trinket (zie hier) van dezelfde fabrikant had gebruikt en daardoor er geen driver problemen meer waren.

Mijn code is te vinden onder Code Examples. De code kun je ook gewoon lezen in een tekstverwerker. (Word, notepad, wordpad, notepad++)

Ik wil nog maar eens benadrukken dat de GEMMA of de grotere FLORA hele eenvoudige en betaalbare apparaten zijn en waar een heel arsenaal aan sensoren bij beschikbaar zijn, zoals GPS, licht, geluid, versnelling en nog wat.

Als iemand vragen heeft, aarzel niet om ze te stellen. En ik vind het leuk om te horen als iemand zelf iets gemaakt heeft.


Succes met bouwen!
korte video demo


EDIT (21 april): Hier is de illustratie die Bier & Brood hebben gemaakt bij het artikel. Beter dan ik het kan uit tekenen. De weerstand van 10 kOhm tussen D2 en GND is erg belangrijk. 

Illustratie van Bier&Brood