Pick largest of several voltages with analogue comparators
Clash Royale CLAN TAG#URR8PPP
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;
up vote
4
down vote
favorite
This is not an XY problem. I have already decided that the best way to handle the actual application is to use a multiplexer and ADC/MCU to measure all the voltages.
However, I am always keen to find a neat new way to hook up opamps or comparators. This is an 'does this configuration exist in a neat way' question? I've not managed to find one yet through the normal search routes.
Inputs - 6 or so positive signals in the 1v to 2v range
Outputs - one amplifier or comparator output per signal, where that corresponding to the largest (or equivalently the smallest) voltage has a unique, perhaps high output, and all the others have a low and similar output, such that they are already logic-usable levels, or can be compared against a simple threshhold to give logic levels.
Ignore input voltage offsets as being insignificant with respect to the input voltages. Hysteresis is optional. Scalable to any (reasonable) number of inputs.
It's relatively easy to output true for all the signals that are above the average of the inputs. Just form the average with an equal resistor network, then use this voltage for the reference input to each comparator.
What I feel should be possible is some sort of diode feedback, like in an absolute value circuit, where the gain of an amplifier reduces the diode drop to insignificance, and the 'winning' amplifier/comparator silences all the others. However, I've not managed to find a simple configuration yet.
What's a simple configuration? One amp per input, with at most two additional shared ones. One diode, or at a stretch two, per amp, with at most 4 resistors per amplifier, and a few extra shared, with as few as possible needing matched values.
Any thoughts?
(edit)
I have the outline of a solution which involves an integrator which controls a common reference level. This level ramps down if no inputs exceed it, and ramps up when any input exceeds it. The level will tend to hunt around the largest level, with the comparator output corresponding to the largest flicking on and off. Replacing the comparators with amplifiers and paying attention to stability may result in a steady output that's suitable.
op-amp comparator
add a comment |Â
up vote
4
down vote
favorite
This is not an XY problem. I have already decided that the best way to handle the actual application is to use a multiplexer and ADC/MCU to measure all the voltages.
However, I am always keen to find a neat new way to hook up opamps or comparators. This is an 'does this configuration exist in a neat way' question? I've not managed to find one yet through the normal search routes.
Inputs - 6 or so positive signals in the 1v to 2v range
Outputs - one amplifier or comparator output per signal, where that corresponding to the largest (or equivalently the smallest) voltage has a unique, perhaps high output, and all the others have a low and similar output, such that they are already logic-usable levels, or can be compared against a simple threshhold to give logic levels.
Ignore input voltage offsets as being insignificant with respect to the input voltages. Hysteresis is optional. Scalable to any (reasonable) number of inputs.
It's relatively easy to output true for all the signals that are above the average of the inputs. Just form the average with an equal resistor network, then use this voltage for the reference input to each comparator.
What I feel should be possible is some sort of diode feedback, like in an absolute value circuit, where the gain of an amplifier reduces the diode drop to insignificance, and the 'winning' amplifier/comparator silences all the others. However, I've not managed to find a simple configuration yet.
What's a simple configuration? One amp per input, with at most two additional shared ones. One diode, or at a stretch two, per amp, with at most 4 resistors per amplifier, and a few extra shared, with as few as possible needing matched values.
Any thoughts?
(edit)
I have the outline of a solution which involves an integrator which controls a common reference level. This level ramps down if no inputs exceed it, and ramps up when any input exceeds it. The level will tend to hunt around the largest level, with the comparator output corresponding to the largest flicking on and off. Replacing the comparators with amplifiers and paying attention to stability may result in a steady output that's suitable.
op-amp comparator
I am a bit confused, your title states to pick the largest output (that is, one analogue output, N analogue inputs), and your question seems to state you want a digital result (N analogue inputs, N digital outputs).
â PlasmaHH
Aug 10 at 11:56
@PlasmaHH clarified
â Neil_UK
Aug 10 at 12:49
You are looking for a "winner take all" circuit. That will prove a useful search term. Easily done with a hardware neural net, but also with comparator trees -- sciencedirect.com/science/article/pii/S0925231204002796
â Scott Seidman
Aug 10 at 13:21
Interesting circuit... if you're able to and don't mind sharing, what's the application?
â Shamtam
Aug 10 at 17:12
add a comment |Â
up vote
4
down vote
favorite
up vote
4
down vote
favorite
This is not an XY problem. I have already decided that the best way to handle the actual application is to use a multiplexer and ADC/MCU to measure all the voltages.
However, I am always keen to find a neat new way to hook up opamps or comparators. This is an 'does this configuration exist in a neat way' question? I've not managed to find one yet through the normal search routes.
Inputs - 6 or so positive signals in the 1v to 2v range
Outputs - one amplifier or comparator output per signal, where that corresponding to the largest (or equivalently the smallest) voltage has a unique, perhaps high output, and all the others have a low and similar output, such that they are already logic-usable levels, or can be compared against a simple threshhold to give logic levels.
Ignore input voltage offsets as being insignificant with respect to the input voltages. Hysteresis is optional. Scalable to any (reasonable) number of inputs.
It's relatively easy to output true for all the signals that are above the average of the inputs. Just form the average with an equal resistor network, then use this voltage for the reference input to each comparator.
What I feel should be possible is some sort of diode feedback, like in an absolute value circuit, where the gain of an amplifier reduces the diode drop to insignificance, and the 'winning' amplifier/comparator silences all the others. However, I've not managed to find a simple configuration yet.
What's a simple configuration? One amp per input, with at most two additional shared ones. One diode, or at a stretch two, per amp, with at most 4 resistors per amplifier, and a few extra shared, with as few as possible needing matched values.
Any thoughts?
(edit)
I have the outline of a solution which involves an integrator which controls a common reference level. This level ramps down if no inputs exceed it, and ramps up when any input exceeds it. The level will tend to hunt around the largest level, with the comparator output corresponding to the largest flicking on and off. Replacing the comparators with amplifiers and paying attention to stability may result in a steady output that's suitable.
op-amp comparator
This is not an XY problem. I have already decided that the best way to handle the actual application is to use a multiplexer and ADC/MCU to measure all the voltages.
However, I am always keen to find a neat new way to hook up opamps or comparators. This is an 'does this configuration exist in a neat way' question? I've not managed to find one yet through the normal search routes.
Inputs - 6 or so positive signals in the 1v to 2v range
Outputs - one amplifier or comparator output per signal, where that corresponding to the largest (or equivalently the smallest) voltage has a unique, perhaps high output, and all the others have a low and similar output, such that they are already logic-usable levels, or can be compared against a simple threshhold to give logic levels.
Ignore input voltage offsets as being insignificant with respect to the input voltages. Hysteresis is optional. Scalable to any (reasonable) number of inputs.
It's relatively easy to output true for all the signals that are above the average of the inputs. Just form the average with an equal resistor network, then use this voltage for the reference input to each comparator.
What I feel should be possible is some sort of diode feedback, like in an absolute value circuit, where the gain of an amplifier reduces the diode drop to insignificance, and the 'winning' amplifier/comparator silences all the others. However, I've not managed to find a simple configuration yet.
What's a simple configuration? One amp per input, with at most two additional shared ones. One diode, or at a stretch two, per amp, with at most 4 resistors per amplifier, and a few extra shared, with as few as possible needing matched values.
Any thoughts?
(edit)
I have the outline of a solution which involves an integrator which controls a common reference level. This level ramps down if no inputs exceed it, and ramps up when any input exceeds it. The level will tend to hunt around the largest level, with the comparator output corresponding to the largest flicking on and off. Replacing the comparators with amplifiers and paying attention to stability may result in a steady output that's suitable.
op-amp comparator
edited Aug 10 at 12:49
asked Aug 10 at 11:52
Neil_UK
69k272152
69k272152
I am a bit confused, your title states to pick the largest output (that is, one analogue output, N analogue inputs), and your question seems to state you want a digital result (N analogue inputs, N digital outputs).
â PlasmaHH
Aug 10 at 11:56
@PlasmaHH clarified
â Neil_UK
Aug 10 at 12:49
You are looking for a "winner take all" circuit. That will prove a useful search term. Easily done with a hardware neural net, but also with comparator trees -- sciencedirect.com/science/article/pii/S0925231204002796
â Scott Seidman
Aug 10 at 13:21
Interesting circuit... if you're able to and don't mind sharing, what's the application?
â Shamtam
Aug 10 at 17:12
add a comment |Â
I am a bit confused, your title states to pick the largest output (that is, one analogue output, N analogue inputs), and your question seems to state you want a digital result (N analogue inputs, N digital outputs).
â PlasmaHH
Aug 10 at 11:56
@PlasmaHH clarified
â Neil_UK
Aug 10 at 12:49
You are looking for a "winner take all" circuit. That will prove a useful search term. Easily done with a hardware neural net, but also with comparator trees -- sciencedirect.com/science/article/pii/S0925231204002796
â Scott Seidman
Aug 10 at 13:21
Interesting circuit... if you're able to and don't mind sharing, what's the application?
â Shamtam
Aug 10 at 17:12
I am a bit confused, your title states to pick the largest output (that is, one analogue output, N analogue inputs), and your question seems to state you want a digital result (N analogue inputs, N digital outputs).
â PlasmaHH
Aug 10 at 11:56
I am a bit confused, your title states to pick the largest output (that is, one analogue output, N analogue inputs), and your question seems to state you want a digital result (N analogue inputs, N digital outputs).
â PlasmaHH
Aug 10 at 11:56
@PlasmaHH clarified
â Neil_UK
Aug 10 at 12:49
@PlasmaHH clarified
â Neil_UK
Aug 10 at 12:49
You are looking for a "winner take all" circuit. That will prove a useful search term. Easily done with a hardware neural net, but also with comparator trees -- sciencedirect.com/science/article/pii/S0925231204002796
â Scott Seidman
Aug 10 at 13:21
You are looking for a "winner take all" circuit. That will prove a useful search term. Easily done with a hardware neural net, but also with comparator trees -- sciencedirect.com/science/article/pii/S0925231204002796
â Scott Seidman
Aug 10 at 13:21
Interesting circuit... if you're able to and don't mind sharing, what's the application?
â Shamtam
Aug 10 at 17:12
Interesting circuit... if you're able to and don't mind sharing, what's the application?
â Shamtam
Aug 10 at 17:12
add a comment |Â
4 Answers
4
active
oldest
votes
up vote
3
down vote
It turns out I could smell the solution. It's interesting to see how long it took to get there, needed me to post a question to make it happen, and my thought process went via the intermediate ramping integrator edit to my question.
simulate this circuit â Schematic created using CircuitLab
It's intended that all channels are identical. However, I've drawn channels 1 and 2 as the simplest possible, and left channel n to receive embellishments.
Consider all inputs except input 1 low. Amplifier 1 works as a follower, with its output a diode D1 drop above its negative input, R1 pulling a modest current through the diode. All other amplifier outputs will be at the negative rail, with their diodes reverse biassed.
As input 2 increases in voltage, it will eventually exceed the common reference voltage on R1, OA2 output will go high, pulling the common reference up to its input voltage, which will send amplifier 1 output low.
If we assume a sufficiently low impedance driving the inputs, I've shown on channel n how a sniff of hysteresis can be applied to the input.
The active output is a diode drop above the input voltage. The inactive outputs are near the negative rail.
To make this easily discriminated by logic, the inputs need to be guaranteed to stay some reasonable voltage above the negative rail. This will happen automatically if the inputs are strictly positive, and the amplifiers receive a negative rail.
With sufficient positive rail available, the diodes could be replaced by elements with a larger voltage drop, for instance several series diodes, or a LED, to increase the voltage excess of the output over the input. Using LEDs would make a nice self-indicating circuit, as long as the LED reverse breakdown was not exceeded, or they were protected by a proper diode in series. If they were inputs to optocouplers, they could be used to drive logic easily.
In an effort to get better logic levels out of the system, I've added Qn. It works as a cascode, transferring the amplifier output current to R1, but only when the output voltage is about 2 diode drops above the logic high reference voltage. Dn could be omitted, as long as the reverse VBE limit, usually around 5v or so for silicon, is not exceeded when the output is low. This now ensures that the outputs are nearly negative rail for low, and logic high reference + 1.4v for high. It does increase the loop gain of the system, so might compromise stability. I'd need to think about that. A resistor in series with Qn emitter would control the gain, and while it would destroy the relatively constant output high voltage, at least the output high voltage is guaranteed to be above a certain voltage, regardless of how low the winning input voltage is.
An essentially identical scheme can be configured to select the smallest input voltage.
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
add a comment |Â
up vote
2
down vote
simulate this circuit â Schematic created using CircuitLab
Something similar to this as a single stage may work when repeated multiple times.
The relay can likely be replaced with a transistor based switch.
A comparator may work better in this circuit than a plain op-amp.
The bottom part shows a way to combine the individual stages for multiple signals. For N inputs, you need N-1 stages with this configuration
3
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
add a comment |Â
up vote
1
down vote
So, in the end, you could use $binomN_in2$ comparators to compare all pairs of voltages. That'd give you a $binomN_in2$-bit value, and you could convert that to the info "highest is input $n$" with but a simple LUT.
So, we'd need a set of $binom62=15$ comparators. Ugly? Sure, but you know who's good at comparing voltages (and fast at that)?
Differential line receivers.
In fact, for example, TI has 24 bit LVDS serializers. But you're probably happier with a simpler part like the 16 differential input -> 16 LVTTL output SM65LVDS386. If you're oldschool, you then add logical gates to implement the LUT.
An output like "is $n$ the highest input?" (i.e. one-hot) would even be easier. It would just be an "AND" of all the outputs that involve $n$.
add a comment |Â
up vote
0
down vote
Thinking aloud....
simulate this circuit â Schematic created using CircuitLab
A common "max voltage bus" (with signals B & C) that is compared against one signal (A). Summing of all others is done with diodes. D1 is used to introduce the same voltage drop to signal A as to the other signals.
Assumption: all diodes are identical and linear enough (diodes... linear...).
How it scales? Badly... for every signal a max voltage signal of all the other signals is needed.
add a comment |Â
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
3
down vote
It turns out I could smell the solution. It's interesting to see how long it took to get there, needed me to post a question to make it happen, and my thought process went via the intermediate ramping integrator edit to my question.
simulate this circuit â Schematic created using CircuitLab
It's intended that all channels are identical. However, I've drawn channels 1 and 2 as the simplest possible, and left channel n to receive embellishments.
Consider all inputs except input 1 low. Amplifier 1 works as a follower, with its output a diode D1 drop above its negative input, R1 pulling a modest current through the diode. All other amplifier outputs will be at the negative rail, with their diodes reverse biassed.
As input 2 increases in voltage, it will eventually exceed the common reference voltage on R1, OA2 output will go high, pulling the common reference up to its input voltage, which will send amplifier 1 output low.
If we assume a sufficiently low impedance driving the inputs, I've shown on channel n how a sniff of hysteresis can be applied to the input.
The active output is a diode drop above the input voltage. The inactive outputs are near the negative rail.
To make this easily discriminated by logic, the inputs need to be guaranteed to stay some reasonable voltage above the negative rail. This will happen automatically if the inputs are strictly positive, and the amplifiers receive a negative rail.
With sufficient positive rail available, the diodes could be replaced by elements with a larger voltage drop, for instance several series diodes, or a LED, to increase the voltage excess of the output over the input. Using LEDs would make a nice self-indicating circuit, as long as the LED reverse breakdown was not exceeded, or they were protected by a proper diode in series. If they were inputs to optocouplers, they could be used to drive logic easily.
In an effort to get better logic levels out of the system, I've added Qn. It works as a cascode, transferring the amplifier output current to R1, but only when the output voltage is about 2 diode drops above the logic high reference voltage. Dn could be omitted, as long as the reverse VBE limit, usually around 5v or so for silicon, is not exceeded when the output is low. This now ensures that the outputs are nearly negative rail for low, and logic high reference + 1.4v for high. It does increase the loop gain of the system, so might compromise stability. I'd need to think about that. A resistor in series with Qn emitter would control the gain, and while it would destroy the relatively constant output high voltage, at least the output high voltage is guaranteed to be above a certain voltage, regardless of how low the winning input voltage is.
An essentially identical scheme can be configured to select the smallest input voltage.
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
add a comment |Â
up vote
3
down vote
It turns out I could smell the solution. It's interesting to see how long it took to get there, needed me to post a question to make it happen, and my thought process went via the intermediate ramping integrator edit to my question.
simulate this circuit â Schematic created using CircuitLab
It's intended that all channels are identical. However, I've drawn channels 1 and 2 as the simplest possible, and left channel n to receive embellishments.
Consider all inputs except input 1 low. Amplifier 1 works as a follower, with its output a diode D1 drop above its negative input, R1 pulling a modest current through the diode. All other amplifier outputs will be at the negative rail, with their diodes reverse biassed.
As input 2 increases in voltage, it will eventually exceed the common reference voltage on R1, OA2 output will go high, pulling the common reference up to its input voltage, which will send amplifier 1 output low.
If we assume a sufficiently low impedance driving the inputs, I've shown on channel n how a sniff of hysteresis can be applied to the input.
The active output is a diode drop above the input voltage. The inactive outputs are near the negative rail.
To make this easily discriminated by logic, the inputs need to be guaranteed to stay some reasonable voltage above the negative rail. This will happen automatically if the inputs are strictly positive, and the amplifiers receive a negative rail.
With sufficient positive rail available, the diodes could be replaced by elements with a larger voltage drop, for instance several series diodes, or a LED, to increase the voltage excess of the output over the input. Using LEDs would make a nice self-indicating circuit, as long as the LED reverse breakdown was not exceeded, or they were protected by a proper diode in series. If they were inputs to optocouplers, they could be used to drive logic easily.
In an effort to get better logic levels out of the system, I've added Qn. It works as a cascode, transferring the amplifier output current to R1, but only when the output voltage is about 2 diode drops above the logic high reference voltage. Dn could be omitted, as long as the reverse VBE limit, usually around 5v or so for silicon, is not exceeded when the output is low. This now ensures that the outputs are nearly negative rail for low, and logic high reference + 1.4v for high. It does increase the loop gain of the system, so might compromise stability. I'd need to think about that. A resistor in series with Qn emitter would control the gain, and while it would destroy the relatively constant output high voltage, at least the output high voltage is guaranteed to be above a certain voltage, regardless of how low the winning input voltage is.
An essentially identical scheme can be configured to select the smallest input voltage.
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
add a comment |Â
up vote
3
down vote
up vote
3
down vote
It turns out I could smell the solution. It's interesting to see how long it took to get there, needed me to post a question to make it happen, and my thought process went via the intermediate ramping integrator edit to my question.
simulate this circuit â Schematic created using CircuitLab
It's intended that all channels are identical. However, I've drawn channels 1 and 2 as the simplest possible, and left channel n to receive embellishments.
Consider all inputs except input 1 low. Amplifier 1 works as a follower, with its output a diode D1 drop above its negative input, R1 pulling a modest current through the diode. All other amplifier outputs will be at the negative rail, with their diodes reverse biassed.
As input 2 increases in voltage, it will eventually exceed the common reference voltage on R1, OA2 output will go high, pulling the common reference up to its input voltage, which will send amplifier 1 output low.
If we assume a sufficiently low impedance driving the inputs, I've shown on channel n how a sniff of hysteresis can be applied to the input.
The active output is a diode drop above the input voltage. The inactive outputs are near the negative rail.
To make this easily discriminated by logic, the inputs need to be guaranteed to stay some reasonable voltage above the negative rail. This will happen automatically if the inputs are strictly positive, and the amplifiers receive a negative rail.
With sufficient positive rail available, the diodes could be replaced by elements with a larger voltage drop, for instance several series diodes, or a LED, to increase the voltage excess of the output over the input. Using LEDs would make a nice self-indicating circuit, as long as the LED reverse breakdown was not exceeded, or they were protected by a proper diode in series. If they were inputs to optocouplers, they could be used to drive logic easily.
In an effort to get better logic levels out of the system, I've added Qn. It works as a cascode, transferring the amplifier output current to R1, but only when the output voltage is about 2 diode drops above the logic high reference voltage. Dn could be omitted, as long as the reverse VBE limit, usually around 5v or so for silicon, is not exceeded when the output is low. This now ensures that the outputs are nearly negative rail for low, and logic high reference + 1.4v for high. It does increase the loop gain of the system, so might compromise stability. I'd need to think about that. A resistor in series with Qn emitter would control the gain, and while it would destroy the relatively constant output high voltage, at least the output high voltage is guaranteed to be above a certain voltage, regardless of how low the winning input voltage is.
An essentially identical scheme can be configured to select the smallest input voltage.
It turns out I could smell the solution. It's interesting to see how long it took to get there, needed me to post a question to make it happen, and my thought process went via the intermediate ramping integrator edit to my question.
simulate this circuit â Schematic created using CircuitLab
It's intended that all channels are identical. However, I've drawn channels 1 and 2 as the simplest possible, and left channel n to receive embellishments.
Consider all inputs except input 1 low. Amplifier 1 works as a follower, with its output a diode D1 drop above its negative input, R1 pulling a modest current through the diode. All other amplifier outputs will be at the negative rail, with their diodes reverse biassed.
As input 2 increases in voltage, it will eventually exceed the common reference voltage on R1, OA2 output will go high, pulling the common reference up to its input voltage, which will send amplifier 1 output low.
If we assume a sufficiently low impedance driving the inputs, I've shown on channel n how a sniff of hysteresis can be applied to the input.
The active output is a diode drop above the input voltage. The inactive outputs are near the negative rail.
To make this easily discriminated by logic, the inputs need to be guaranteed to stay some reasonable voltage above the negative rail. This will happen automatically if the inputs are strictly positive, and the amplifiers receive a negative rail.
With sufficient positive rail available, the diodes could be replaced by elements with a larger voltage drop, for instance several series diodes, or a LED, to increase the voltage excess of the output over the input. Using LEDs would make a nice self-indicating circuit, as long as the LED reverse breakdown was not exceeded, or they were protected by a proper diode in series. If they were inputs to optocouplers, they could be used to drive logic easily.
In an effort to get better logic levels out of the system, I've added Qn. It works as a cascode, transferring the amplifier output current to R1, but only when the output voltage is about 2 diode drops above the logic high reference voltage. Dn could be omitted, as long as the reverse VBE limit, usually around 5v or so for silicon, is not exceeded when the output is low. This now ensures that the outputs are nearly negative rail for low, and logic high reference + 1.4v for high. It does increase the loop gain of the system, so might compromise stability. I'd need to think about that. A resistor in series with Qn emitter would control the gain, and while it would destroy the relatively constant output high voltage, at least the output high voltage is guaranteed to be above a certain voltage, regardless of how low the winning input voltage is.
An essentially identical scheme can be configured to select the smallest input voltage.
edited Aug 10 at 13:59
answered Aug 10 at 13:21
Neil_UK
69k272152
69k272152
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
add a comment |Â
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
niceeeee So, I just misread your question; my answer basically just leaves out the part you're solving here.
â Marcus Müller
Aug 10 at 13:47
add a comment |Â
up vote
2
down vote
simulate this circuit â Schematic created using CircuitLab
Something similar to this as a single stage may work when repeated multiple times.
The relay can likely be replaced with a transistor based switch.
A comparator may work better in this circuit than a plain op-amp.
The bottom part shows a way to combine the individual stages for multiple signals. For N inputs, you need N-1 stages with this configuration
3
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
add a comment |Â
up vote
2
down vote
simulate this circuit â Schematic created using CircuitLab
Something similar to this as a single stage may work when repeated multiple times.
The relay can likely be replaced with a transistor based switch.
A comparator may work better in this circuit than a plain op-amp.
The bottom part shows a way to combine the individual stages for multiple signals. For N inputs, you need N-1 stages with this configuration
3
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
add a comment |Â
up vote
2
down vote
up vote
2
down vote
simulate this circuit â Schematic created using CircuitLab
Something similar to this as a single stage may work when repeated multiple times.
The relay can likely be replaced with a transistor based switch.
A comparator may work better in this circuit than a plain op-amp.
The bottom part shows a way to combine the individual stages for multiple signals. For N inputs, you need N-1 stages with this configuration
simulate this circuit â Schematic created using CircuitLab
Something similar to this as a single stage may work when repeated multiple times.
The relay can likely be replaced with a transistor based switch.
A comparator may work better in this circuit than a plain op-amp.
The bottom part shows a way to combine the individual stages for multiple signals. For N inputs, you need N-1 stages with this configuration
edited Aug 10 at 13:10
answered Aug 10 at 12:33
uglyoldbob
1094
1094
3
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
add a comment |Â
3
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
3
3
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
How would you extend this to N voltages?
â Autistic
Aug 10 at 12:56
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
That's really out of the box thinking! Perhaps not an industrial solution, but thought-provoking.
â winny
Aug 10 at 13:51
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
nice but not solving the edited OP's problem
â aaaaaa
Aug 10 at 18:35
add a comment |Â
up vote
1
down vote
So, in the end, you could use $binomN_in2$ comparators to compare all pairs of voltages. That'd give you a $binomN_in2$-bit value, and you could convert that to the info "highest is input $n$" with but a simple LUT.
So, we'd need a set of $binom62=15$ comparators. Ugly? Sure, but you know who's good at comparing voltages (and fast at that)?
Differential line receivers.
In fact, for example, TI has 24 bit LVDS serializers. But you're probably happier with a simpler part like the 16 differential input -> 16 LVTTL output SM65LVDS386. If you're oldschool, you then add logical gates to implement the LUT.
An output like "is $n$ the highest input?" (i.e. one-hot) would even be easier. It would just be an "AND" of all the outputs that involve $n$.
add a comment |Â
up vote
1
down vote
So, in the end, you could use $binomN_in2$ comparators to compare all pairs of voltages. That'd give you a $binomN_in2$-bit value, and you could convert that to the info "highest is input $n$" with but a simple LUT.
So, we'd need a set of $binom62=15$ comparators. Ugly? Sure, but you know who's good at comparing voltages (and fast at that)?
Differential line receivers.
In fact, for example, TI has 24 bit LVDS serializers. But you're probably happier with a simpler part like the 16 differential input -> 16 LVTTL output SM65LVDS386. If you're oldschool, you then add logical gates to implement the LUT.
An output like "is $n$ the highest input?" (i.e. one-hot) would even be easier. It would just be an "AND" of all the outputs that involve $n$.
add a comment |Â
up vote
1
down vote
up vote
1
down vote
So, in the end, you could use $binomN_in2$ comparators to compare all pairs of voltages. That'd give you a $binomN_in2$-bit value, and you could convert that to the info "highest is input $n$" with but a simple LUT.
So, we'd need a set of $binom62=15$ comparators. Ugly? Sure, but you know who's good at comparing voltages (and fast at that)?
Differential line receivers.
In fact, for example, TI has 24 bit LVDS serializers. But you're probably happier with a simpler part like the 16 differential input -> 16 LVTTL output SM65LVDS386. If you're oldschool, you then add logical gates to implement the LUT.
An output like "is $n$ the highest input?" (i.e. one-hot) would even be easier. It would just be an "AND" of all the outputs that involve $n$.
So, in the end, you could use $binomN_in2$ comparators to compare all pairs of voltages. That'd give you a $binomN_in2$-bit value, and you could convert that to the info "highest is input $n$" with but a simple LUT.
So, we'd need a set of $binom62=15$ comparators. Ugly? Sure, but you know who's good at comparing voltages (and fast at that)?
Differential line receivers.
In fact, for example, TI has 24 bit LVDS serializers. But you're probably happier with a simpler part like the 16 differential input -> 16 LVTTL output SM65LVDS386. If you're oldschool, you then add logical gates to implement the LUT.
An output like "is $n$ the highest input?" (i.e. one-hot) would even be easier. It would just be an "AND" of all the outputs that involve $n$.
edited Aug 10 at 13:10
answered Aug 10 at 12:54
Marcus Müller
28.3k35386
28.3k35386
add a comment |Â
add a comment |Â
up vote
0
down vote
Thinking aloud....
simulate this circuit â Schematic created using CircuitLab
A common "max voltage bus" (with signals B & C) that is compared against one signal (A). Summing of all others is done with diodes. D1 is used to introduce the same voltage drop to signal A as to the other signals.
Assumption: all diodes are identical and linear enough (diodes... linear...).
How it scales? Badly... for every signal a max voltage signal of all the other signals is needed.
add a comment |Â
up vote
0
down vote
Thinking aloud....
simulate this circuit â Schematic created using CircuitLab
A common "max voltage bus" (with signals B & C) that is compared against one signal (A). Summing of all others is done with diodes. D1 is used to introduce the same voltage drop to signal A as to the other signals.
Assumption: all diodes are identical and linear enough (diodes... linear...).
How it scales? Badly... for every signal a max voltage signal of all the other signals is needed.
add a comment |Â
up vote
0
down vote
up vote
0
down vote
Thinking aloud....
simulate this circuit â Schematic created using CircuitLab
A common "max voltage bus" (with signals B & C) that is compared against one signal (A). Summing of all others is done with diodes. D1 is used to introduce the same voltage drop to signal A as to the other signals.
Assumption: all diodes are identical and linear enough (diodes... linear...).
How it scales? Badly... for every signal a max voltage signal of all the other signals is needed.
Thinking aloud....
simulate this circuit â Schematic created using CircuitLab
A common "max voltage bus" (with signals B & C) that is compared against one signal (A). Summing of all others is done with diodes. D1 is used to introduce the same voltage drop to signal A as to the other signals.
Assumption: all diodes are identical and linear enough (diodes... linear...).
How it scales? Badly... for every signal a max voltage signal of all the other signals is needed.
answered Aug 10 at 14:15
filo
4,8551828
4,8551828
add a comment |Â
add a comment |Â
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2felectronics.stackexchange.com%2fquestions%2f390355%2fpick-largest-of-several-voltages-with-analogue-comparators%23new-answer', 'question_page');
);
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
I am a bit confused, your title states to pick the largest output (that is, one analogue output, N analogue inputs), and your question seems to state you want a digital result (N analogue inputs, N digital outputs).
â PlasmaHH
Aug 10 at 11:56
@PlasmaHH clarified
â Neil_UK
Aug 10 at 12:49
You are looking for a "winner take all" circuit. That will prove a useful search term. Easily done with a hardware neural net, but also with comparator trees -- sciencedirect.com/science/article/pii/S0925231204002796
â Scott Seidman
Aug 10 at 13:21
Interesting circuit... if you're able to and don't mind sharing, what's the application?
â Shamtam
Aug 10 at 17:12