If you want to build something using a Raspberry Pi, you'll probably use resistors. For this exercise, you need to know two things about them:
To get around this problem, manufacturers print color-coded bands onto the resistors to denote their resistance values. Each band has a position and a numeric value.
The first 2 bands of a resistor have a simple encoding scheme: each color maps to a single number. For example, if they printed a brown band (value 1) followed by a green band (value 5), it would translate to the number 15.
In this exercise you are going to create a helpful program so that you don't have to remember the values of the bands. The program will take color names as input and output a two digit number, even if the input is more than two colors!
The band colors are encoded as follows:
From the example above: brown-green should return 15, and brown-green-violet should return 15 too, ignoring the third color.
You need to implement the function
value :: (Color, Color) -> Int
that only accepts two colors and produces the resistor's numeric value component of its resistance.
Bonus - Property Testing:
This exercise is a good opportunity to write some property tests. If you haven't written any before here are some resources:
We have provided one sample QuickCheck property test in the test file.
Examples of properties that can be tested:
value (x, y) >= 10
for all (x, y)
where x
isn't Black
Calling show
on value (x, y)
produces the reverse
String of calling show
on value (y, x)
.
All colors have unique names. (For any two colors, if the colors are different, so are their names.)
Sign up to Exercism to learn and master Haskell with 107 exercises, and real human mentoring, all for free.