- this circuit is distributed by UNDERSCORES - an open video hardware label : it is available to purchase - as a pcb, kit or assembled unit - at underscores.shop
- the schematic for the circuit can be found here
- the pcb gerber files for the lastest version can be found here
- interactive BOM is here
- link to latest rpi image is here
- link to FAQ/TROUBLESHOOTING page can be found here
- consider donating to the underscores project to help us continue creating for the commons
recurBOY is a stand-alone digital video synthesizer and sampler. it can trigger clips and run shaders to create and manipulate sd video.
- outputs sd video over composite or hdmi
- 2 source modes to generate video : sampler and shaders
- process any source with additional FX
- control shader/fx parameters directly with 4x knobs or externally with 4x cv inputs
- all inputs also controllable via usb-midi
- process external video through compatible usb capture cards / web-cams
background
recurBOY was originally designed in 2019 by tim & guergana to be built together with others in group workshop soldering sessions - the design is a spinoff from r_e_c_u_r an existing project tim created and maintains. r_e_c_u_r is simple to assemble but more complex to operate due to its scope and customizablity. recurBOY distills the best parts, aiming to be simpler and more beginner friendly. it uses cheaper parts and runs on a raspberry pi zero which can be a fraction the price of the pi3 used in r_e_c_u_r.
this project is fully open-source hardware - all the files required to build it are included in this repo for free. if you have the time and/or skill you can contribute back by collaborating on / testing new designs, improving these docs, making demo videos/other creative content etc. you can also support the project financially by donating directing, or purchasing through the web shop.
depending on whether you are going fully diy or buying an assembled and tested unit, some of the following guides will be relavent to you. the flow would be:
parts sourcing guide (w/ notes on pcb fabracation ) - start here if you are building fully from scatch or have purchased a pcb
i try to source all the parts i can from either:
- tayda ; cheaper for common parts like resistors etc, also good for mechanical parts like switches and buttons
- mouser ; has lots more options, speciality video ic's, can sometimes cost more (free shipping on orders over 50euros)
- other ; ocationally there will be parts which will need to be sourced elsewhere - usaully either aliexpress, ebay or amazon etc...
take a look at the full_bom for this project to see where i am sourcing each part from
-
go to the tayda quick order and in bottom corner choose add from file
-
select the file tayda_bom.csv in the BOM folder (you will have to download it first or clone this repo)
-
after importing select add to cart
-
NOTE: the minimum value for resistors is 10, so you may need to modify these values to add to cart (or if they are already modified here you will need to see the full_bom for actual part QTY)
-
OPTIONAL: it is a good idea to add some dip-ic sockets and 2.54pin headers/sockets to your tayda order if you dont have them around already
- go to mouser bom tool and click upload spreadsheet
- select the file mouser_bom.csv in this folder (you will have to download it first or clone this repo), then upload my spreadsheet and next
- ensure that Mouser Part Number is selected in the dropdown above the first row, then next, process
- if everything looks correct can now put add to basket
the recurBOY has a few less common parts that can not be found at either tayda or mouser.
i use the cuiisw on aliexpress - however there are many different brands with compatable products, both on ali, amazon and ebay etc...
to tell if a display you are looking at is compatable, check for the following things:
- 1.8inch in size (128x160px), rgb and tft - not oled etc
- uses ST7735S driver over SPI
- pins order match the cuiisw one: GND | VDD | SCL | SDA | RST | DC | CS | BLK
for example, i can tell that the waveshare version is NOT compatable, since although the size and type and driver all match, the pin order is different (they break the pins out to: BL | RST | DC | CS | CL | DIN | GND | VCC )
(this is a shame since i usually recommend waveshare as a reliable supply for these kinds of things if people are less happy to source through ali)
to save space on the interface we used this 5 way tact switch (10x10mm through hole) - also sourced from aliexpress - you can find these on other places such as amazon and ebay aswell.
main thing to look for here is that they are the right size, and the switch is through hole (tht) - as there are other surface mount versions around too.
- 2x20 pin header from tayda if your rpi_zero doesnt come with this, + strip of header pins you can cut two from to solder onto the tv_out pins,
- caps for the 12x12mm switches can be found on tayda in a few differnt colours. also can be got on ali/elsewhere
- caps for the 5way tact switch can also be found on aliexpress or elsewhere Diameter: 8.5 MM * 10.5 MM high Inner hole: 3.1 * 3.1 MM
- the raspberry pi zero itself - see here
you can support this project by buying individual pcbs from the shop. if you would rather have pcbs fabricated from gerbers directly the file you need is here
- i get my pcbs fabricated from jlcpcb - 5 is the minumum order per design
- upload the zip file with the
add gerber file
button - the default settings are mostly fine - set the PCB Qty and PCB Color settings (you can check that the file looks correct with pcb veiwer)
- it may be best to combine orders with other pcbs you want to have fab'd since the shipping can cost more than the items - also orginising group buys is a good way to distribute the extra pcbs /costs
i often use jlcpcb because they are reliable, cheap and give you an option of colours. remember though that the cheapest Chinese fab houses are not always the most ethical or environmently friendly - if you can afford it consider supporting local companies.
assembly guide - start here if you have purchased a diy kit
follow this link to view the interactive BOM
-
remember to heat pad first (2-3seconds), then add solder, then continue to heat (1-2seconds)
-
Checkout the web-comic soldering is easy for more soldering advice
start by placing the resistors and diodes. it is important that the diodes are placed in the correct direction ! for resistors it does not matter.
there are two parts that need to be placed from the bottom. this is so the raspberry pi can be attached underneath. turn the board over and find j8 - the 2x20 pin socket will connect to the pi0 gpio pins. it is very important that these are soldered on straight. next to this is j6 – a double pin socket that will connect to the pi0 tv out.
flip back to the front. now you can solder the ic and buttons. use the ic socket. also try to make sure the 5-way button is straight before soldering all the pins
for screen make sure the included 8x1 pin header is soldered to it first - with short pin end to the screen. then you can solder the screen - with long header pin ends through the recurBOY pcb.
next solder the top row of jacks and the RCA connector
now you can solder the potentiometers.
you may need to also solder the 2x20 gpio-header to the raspberry pi and a 1x2 pin-header for the tv-out - then your raspberry pi should slot into the bottom of the pcb.
you can flash the recurBOY image to a sd card if you didnt get one from me, or to update its firmware. download the lastest image here and install an image-flashing program like etcher - select the downloaded zip file and sdcard in the program and let it flash
sourcing and preparing the raspberry pi zero
unless you purchase a raspberry pi zero from underscores along-side your assembled and tested recurBOY unit you will need to source and prepare the raspberry pi zero yourself:
recurBOY was designed to work with the first generation of reaspberry pi zeros:
- Raspberry Pi Zero (2015) - no csi port, not needed for recurBOY
- Raspberry Pi Zero v1.3 (2016) - same as above but with csi port
- Raspberry Pi Zero W (2017) - added wifi and bluetooth - wifi can be useful for transfering files wirelessly but not needed
- Raspberry Pi Zero WH (2018) - same as above but with the 2x20 header pre-soldered
with all of these versions you will need to solder a 2x1_pin_header to the tv_out pins on the rpi (in line with the gpio header) - this then connects to the recurboy pcb with 2x1_pin_socket soldered on underside of the board:
in 2021 rpi launched Raspberry Pi Zero 2 W - this is an upgrade to the original series of pi zeros. I have tested these with recurBOY and they work very well - runs faster / smoother than with the original.
one difference with this new version however is that they no longer break out the tv_out to pins. for this version you will need to solder jumper wires onto the tv_out pads, which are on the bottom of the board, next to the hdmi port.
i recommend using an angled 2x1_pin_header and placing it first into the socket on the recurBOY - then take care to solder the correct wires (tv_out + gnd ) to the angled pins and pads under pi_zero2 - in this picture BLACK is GND and RED is TV_OUT
once soldered you can twist the pi_zero, attach the main gpio headers and tuck the wires under the protruding rca jack to keep them hidden:
operating guide - start here if you have purchased an assembled unit
recurBOY has 2 source modes : sampler
& shaders
. pressing the MODE
button will cycle through these modes. you can tell which mode is selected by looking at the title and colour of the display.
the nav_button can be pressed UP , DOWN , LEFT, RIGHT and IN. we will not use the IN button for now. pressing UP and DOWN lets you scroll through the list of content - either samples or shaders depending on the MODE. pressing SELECT on a row will start playing it. the playing content will be highlighted on the display and the
pressing the play/pause button will toggle this state. when the content is stopped the ⏹ will be displayed.
to safely turn off recurBOY hold down the play/pause button for 5 seconds. it is not recommended to remove your usb-drive while recurBOY is operating.
the content list while in sampler MODE comes from the ~/Videos
folder on the pi's SD card and the /Videos
folder on top level of an attached usb-drive. any .mp4, .mkv, .avi or .mov file will be shown although it is not guaranteed it will work with the player - we find sd h264 mp4 to be most reliable.
the content list while in the shaders MODE comes from the ~/Shaders
folder on the pi and in the /Shaders
folder on top level of an attached device.
while the display is in SHADER mode you can use the 4 knobs or CV inputs to manipulate the shader parameters. each shader has 3 parameters mapped to input 0, 1 and 2. input 3 always controls the speed.
from any source mode (SAMPLER or SHADERS) you can press the RIGHT nav_button to enter FX mode. This mode applies effects or filters to the media that is currently playing. Once you enter FX mode, you can navigate the same way as in SAMPLER or SHADERS with UP, DOWN and start the effect with SELECT. pressing LEFT will return to the previous screen.
these shaders need to be stored at ~/Fx
folder on the pi and /Fx
folder on top level of attached usb drive. pressing the FX button will toggle the selected effect on and off. this effect will process whichever of the sources is selected.
the 4 knobs / cv inputs will control parameters of the effect when source SHADERS mode is not selected.
if recurBOY is powered up with a compatible usb-capture card/web-cam plugged into the OTG data_usb input then a third SOURCE MODE will appear when MODE BUTTON is cycled through. within this mode you can start the capture which will take video from this external device and send it through the FX MODES for processing
switching between pal and ntsc
- to switch the video format that your recurBOY uses, power down the device and put the sd card into a computer.
- now inside the
boot
partition look for a file calledconfig.txt
- open it with any text editor and search for
sdtv_mode
- here you can switch between
0
for normal ntsc and2
for normal pal - save the file, safely eject the sd and put it back into the pi
- see docs here for more settings
what are shaders anyway?
shaders are small text files of code that tell a graphics card what to draw. they use a language called glsl to communicate what colour a pixel should be and where. you don't have to understand every line to begin playing around with them.
in recurBOY we use shaders in two places - the SHADERS mode is used for launching shaders that generate video. these shaders take no video inputs. we also use shaders in the FX mode. here we are selecting shaders that process video. these take one video source as input and pass it through the fx shader.
the type of shader recurBOY can play is called GLES. this is the shader language used for embedded systems, including raspberry pi's and mobile phones.
thanks to Erogenous Tones - a modular synth company who have a mature and very powerful shader-playing video instrument called STRUCTURE - we now also have a web-based environment for browsing, modifying and creating shaders to perform with.
go to glsl.erogenous-tones.com - if you select any example you will see the code used to create the patch. try changing some of the numbers - modifying the input parameters is especially interesting.
when you are happy with the results select the save as .glsl file. Now copy this file onto your USB in the correct folder - /Shaders and connect to recurBOY
for more information on understanding and writing shaders yourself check out The Book of Shaders by Gonzalez Vivo.
how the circuit works
we can use some of the GPIO pins on the raspberry pi to know when a button is pressed. one side of the button is connected to the pin and the other is connected to ground. on the raspberry pi we tell these pins to pull up. this means they are HIGH by default. when the button is pressed however the circuit connecting the pin to ground is completed and the pin becomes LOW. in the code we ask the state of a GPIO pin and if LOW we know the button is pressed.
digital pins - HIGH/LOW are good for discrete inputs like button presses which can only be OFF/ON. however we also want to have continuous inputs for example from knobs which can be set to any amount between LOW and HIGH. this kind of input is called analog - the reading is analogous to the voltage on the pin. since raspberry pi has no analog GPIO pins we need to introduce a new part - the MCP3008. this type of ic is called an analog to digital converter or adc for short. it has 8 analog pins which read the voltage applied to them and converts it to digital information. this information can be understood by the raspberry pi's digital pins. in this case using a digital protocol called SPI.
four of the MCP3008 channels are connected to potentiometers which in this circuit act as voltage dividers. one side of the pot is connected to +5V and the other to GND. The output is always some voltage between these. after passing through the adc this voltage value between GND and +5V is converted to a number between 0 and 1024
the other four MCP3008 channels are connected to 3.5mm jacks. this allows the voltage to be set by external devices - this kind of interaction between instruments is called Control Voltage or CV each of the CV inputs also use a resistor and two diodes - these are to protect the IC from incoming voltages above +5V or below GND
the raspberry pi also connects to the display screen with GPIO pins - this time the pins are used as outputs, telling the screen which pixels to colour - again the protocol used here is SPI - but we dont need to worry about how exactly this works - there is a python library that is used to describe what the screen should show
contributing guide
if you would like to contribute back to these projects in some way but dont know how the best thing (for now) would be to reach out to me directly ( tim@cyberboy666.com or @cyberboy666 on scanlines forum) - i will be happy to help
This circuit is distributed through UNDERSCORES – open video hardware label – visit underscores.shop for more info
The pcb was designed using KICAD
Everything from gerbers, cad files, panels and documentation is freely available online and distributed under CC-BY-SA / open-source licenses – help us contribute to the commons !
Ask any questions or start discussions related to this project on the scanlines.xyz forum – an online community space dedicated to diy av / electronic media art
You can contact me directly at tim (at) cyberboy666 (dot) com Please get in touch if you are interested in hosting a workshop !
Thanks to Guergana Tzatchkova for all the love put into creating this project, and the design inspiration used across my work. to Bastien Lavaud for circuit advice, always. To Ben Caldwell for project advice. To everyone who has or will contribute ♥♥♥