Developed in collaboration with Ethan Zonca of protofusion, the PicoBuck is a small-size, triple-output, constant current LED driver. By default, each channel is driven at 330mA; that current can be reduced by either presenting an analog voltage or a PWM signal to the board. Version 12 of the board adds a solderable jumper that can be closed to increase the maximum current to 660mA. It also increased the voltage rating on the various components on the board, allowing the board to be used up to the full 36V rating of the AL8860 part.
It's important to note that the PicoBuck is designed for lighting either single LEDs or LEDs in series. Most LED strips are designed to be fed by a constant voltage and should not be used with the PicoBuck.
Here are some topics you should know before using the PicoBuck. Have a look if you need more information.
Since the PicoBuck is a constant current driver, the current drawn from the supply will drop as supply voltage rises. At 12V, the PicoBuck drives the three LEDs on our Luxeon Rebel Triple Play board at 350mA per LED while drawing less than 350mA total from the power supply. You can also use the board to drive any high power LED like the ones listed below. The PicoBuck is perfect for using with the triple output high power RGB LED or driving a few high power LEDs in series.
Three signal inputs are provided for dimming control. You can use the PWM signal from an Arduino or your favorite microcontroller to dim each channel individually, or you can tie them all to the same PWM for simultaneous dimming. A separate ground pin (labeled GND) is provided to reference against the controlling module for accuracy. The pin spacing for the two pairs of pins is 0.1", but the two pairs are slightly 0.2" apart, to allow for a 2.54mm pitch screw terminal pair to be used, or for a five-position standard 0.1" header with the middle pin removed.
Dimming can be done by an analog voltage (20%-100% of max current by varying voltage from 0.0V-2.5V) or by PWM (so long as PWM minimum voltage is less than 0.4V and maximum voltage is more than 2.4V but not more than 5V) for a full 0-100% range. Avoid analog voltages above 5V, as these may damage the part.
The power supply pads are sized for 3.5mm screw terminals as are the output pads.
3.5mm screw terminals or hookup wire can be used to connect to the pins depending on your personal preference.
The output pads are also sized for 3.5mm screw terminals. Each output is independent from the other two.
A small jumper is provided for each channel to allow you to increase the drive strength from 330mA to 660mA. More information on this can be found below.
It is possible to increase the maximum current of the PicoBuck board up to 1A per channel; to do so, replace the three current sense resistors with smaller values. To calculate the new value for the resistor, use this formula:
Thus, for a 1A current, you'd want a 0.1Ω resistor. Don't forget to be wary of current ratings. At 1A, the sense resistor will be dissipating 1/10W, so you probably want a resistor of at least 1/8W rating. The package is a standard 0805.
As you can see from the image above, the solder jumper doesn't need to be closed particularly neatly. All of the pads in its vicinity are connected to it anyway, so if you glob a little extra solder on, it's no big deal. Just be careful not to actually short the resistors, as in the rightmost circuit!
Two mounting holes for 4-40 or M3 screws are provided on either side of the board. They are perforated so they can be easily snapped off with a pair of pliers, if a smaller footprint is desired.
As mentioned earlier, the PicoBuck's three channels can be individually dimmed by either varying the input voltage of the channel from 0-2.5V or using a PWM signal. You could use a preprogrammed microcontroller like the capacitive touch potentioemter or custom control each channel using any microcontroller with PWM outputs.
If you are looking for a preprogrammed microcontroller with capacitive touch capabilities, check out the Touch Potentiometer. There is additional software that can be used to fine tune the settings of the capacitive touch potentiometer.
![]() |
Touch Potentiometer for PWM Lighting Controller |
Otherwise, the PWM signal from an Arduino board is also perfectly suited for this.
Here's a diagram showing how to connect the PicoBuck to an Arduino.
Note that each channel must be independently connected to the + and - connections of the LED it is to drive! Do not connect the + or - connections of any two channels together.
Multiple LEDs can be connected in series, as shown, and the supply voltage should be at least 2-3V higher than the sum of the forward voltages of the LEDs.
Multiple LEDs can be connected per channel; they should be connected in series, as shown above, and the power supply voltage must be at least 1-2V higher that the sum of the forward voltages of the LEDs.
For instance, our blue 3W LEDs have a forward voltage of 3.2V to 3.8V. To be on the safe side, use the highest voltage in the range. If you want to connect four of them, you'd need a power supply of ~17V or greater (3.8V + 3.8V + 3.8V + 3.8V = 15.2V; add 2V of "head room").
Since 17V is greater than the Arduino can tolerate on its input, we have to provide an external supply for the Arduino as well. This can be the standard 5V USB supply.
It's perfectly acceptable to mix colors either between channels or on one channel, so long as all of the LEDs can handle the current (330mA or 660mA, depending on the jumper setting). Just make sure that the power supply voltage is high enough to handle the sum voltages of the highest voltage string. There is also no requirement that the three strings of LEDs have the same forward voltage of LEDs across them; you could have one white LED on channel 1, two red LEDs on channel 2, and four green LEDs on channel 3.
Note: This example assumes you are using the latest version of the Arduino IDE on your desktop. If this is your first time using Arduino, please review our tutorial on installing the Arduino IDE.
Code for controlling this device is trivial; simply use the analogWrite()
function to adjust the brightness via PWM.
language:c
/**
* PicoBuck Breakout Example
* Mike Hord @ SparkFun Electronics
* Nov 5 2015
*
* A simple example showing how to control a PicoBuck with an Arduino.
*
* License: http://opensource.org/licenses/MIT
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
const int CHL_1 = 3;
const int CHL_2 = 5;
const int CHL_3 = 6;
void setup()
{
pinMode(CHL_1, OUTPUT);
pinMode(CHL_2, OUTPUT);
pinMode(CHL_3, OUTPUT);
}
void loop()
{
// Let's just step through a couple of values, so we can see how they look.
// Remember, LEDs are non-linear, so doubling the PWM output value won't
// necessarily double the apparent brightness.
analogWrite(CHL_1, 0);
analogWrite(CHL_2, 0);
analogWrite(CHL_3, 0);
delay(1000);
analogWrite(CHL_1, 64);
analogWrite(CHL_2, 64);
analogWrite(CHL_3, 64);
delay(1000);
analogWrite(CHL_1, 255);
analogWrite(CHL_2, 255);
analogWrite(CHL_3, 255);
delay(1000);
}
Thanks for reading. Below are all the documents and links you'll need to learn even more about the PicoBuck.
For more LED fun, check out these other SparkFun tutorials:
learn.sparkfun.com | CC BY-SA 3.0 | SparkFun Electronics | Niwot, Colorado