
So what is an R2R ladder?
Well, it is just a cleverly arranged set of resistors that gives you the unique action of turning binary signals into an analogue output voltage. It works by the principle of superposition where switching on binary inputs adds more voltage at the output.
Here is a diagram of one showing binary inputs and analogue output.
The above ladder is just 4 bits long but you can extend it to any length (the limiting factor is the accuracy of the resistors).
Using a ladder network is a common way of creating an 8 bit DAC (Digital to Analogue Converter) as each control bit contributes to a binary weighted output voltage. However, for a highly accurate DAC, the resistors will be laser trimmed and located inside a chip.
The ladder is still a useful construct to use as you can create a very cheap 8 bit DAC if you are not too worried about accuracy ( using 1% resistors will allow fairly good output).
It uses Kirchhoffs current law which states that the sum of currents entering a node must be equal to the sum of the currents leaving a node. In the ladder, at each node, the current is split in half. By switching the currents into each node the total current flowing is binary weighted.
Using the principle of superposition when you add more current into a resistance the total voltage appearing is the sum of the voltages caused by all the individual currents i.e. as each bit is activated so the voltage increases at the output.
Another clever thing about the R2R ladder, and the reason that it works is that if you look to the left you always see the same impedance:
Using Thévenin's theorem you can work out the voltage
contribution of each bit. A Thévenin circuit is the
equivalent of a network of resistances and voltage sources (and current
sources). You can replace the network with a Thévenin
equivalent circuit and it will work in exactly the same way as the
original network.
To use the Thévenin theorem replace all voltage sources with
open circuits and all current sources with short circuits  calculate
the resistance looking into the port for the Thévenin
resistance Rth. For the Thévenin voltage calculate the no
load output voltage.
Contribution if bit 3 is active (the MSB):
Contribution if bit 2 is active (the MSB):
Contribution if bit 1 is active (the MSB):
When each bit is active it contributes a binary weighted voltage to the output Vo.
These are the two main uses. There are probably more that you can use it for.
As I described earlier the primary use of the binary weighted resistor ladder is for digital to analogue conversion as a DAC.
The other useful, and related function, is to implement a key detector feeding the analogue voltage to an ADC pin inside a microcontroller.
The primary advantage of this key input method is that since each key is connected to one control pin of the ladder, each input key generates a binary weighted current and therefore a binary weighted output voltage.
This means you can determine whichever set of keys have been pressed even if they are pressed at the same time as another key!
Note: Use 1% resistors to ensure the ladder works correctly.
Practical limits of achievable linearity/accuracy.
According to US patent: 7362253
"Practical circuit implementations of the D/A converter utilizing R2R ladders are 1) scaling the switch sizes in a binaryweighted fashion and 2) decoding the MSBs into segments of resistor value R. Even with these techniques, the best D/A converters still only achieve 12 to 13 bits linearity accuracy." (in a 16 bit DAC).
Extract from : http://www.freepatentsonline.com/7362253.html
The R2R ladder is a current operating device, so the binary inputs can be connected directly to the outputs of the port either a discrete device or a microcontroller.
When the ground referenced ladder has an input bit that is set to 0V then no current flows so it contributes nothing to the output and conversely, current flows when +V is applied.
Also when using the ladder as a multiple key press detector you can connect only (pushtomake) to +V (Current flows) and leave no connection for zero (No current flows).
Summary : It generates a binary weighted output current that by superposition becomes a binary weighted voltage.
Jun 17, 17 07:56 AM
Use an Hitachi HD44780 as a simple display for any project.
May 11, 17 01:38 AM
How to make a Pulse Rate Sensor using a simple single opamp circuit with an Arduino and a few other components.
May 11, 17 01:38 AM
74HC595 : How to add nearly unlimited outputs to any microcontoller.