2

I am working with Bruce Abbott's awesome level shifter here.

Level transformation 0/+5 V TTL logic to +/-9V how to maximize gain and frequency range (DC to 4 MHz)

schematic

simulate this circuit – Schematic created using CircuitLab

he clearly describes the circuit as follows:

Q1 is configured in Common Base mode with a bias voltage of 2.5 V. When the TTL signal pulls down below ~1.8V the transistor turns on and (almost) the same current flows through both R3 and R4, causing the voltage at R4 to go down from 9 V to ~5 V. This then turns Q2 on via R5, causing it to pull the voltage at R6 up from -9 V to +9 V.

It's a simple circuit, but getting good performance at 4 MHz is tricky. Parasitic capacitances in Q2 cause charge to build up on the Base, which normally prevents it from turning on and off quickly. This problem is solved by adding C3, which bypasses R5 at high frequencies to get charge in and out of the Base quicker. This also requires that R4 (and therefore R3) have a low value.

R6 has a low value to improve the output fall time. R5 has a high value to avoid turning Q2 on too hard, as this would cause more charge to accumulate on the Base, slowing down the turn-off time.

Although this circuit is 'TTL compatible' it requires about 18 mA of driver sink current, so you may need to pass your logic signal through a high current buffer if you driver isn't strong enough.

and in the testing I did, especially head to head with the 75188 line driver IC, it has performed much better:

enter image description here

However, I need to improve it. It is really stretched to its limits on the 4 MHz frequency and it also is having problems with the output impedance matching to my scope's Z-input, which is what it is for. I can measure the nice still rectangular performance with the 10x probe alone, but when I hook up the Z-input it already starts breaking down. I had built this circuit 3 times on the bread board now and this time I have more difficulty than before, but it is anyway at its limits, and I want to increase the frequency to 16 MHz soon, as I change from 256 x 256 to 512 x 512 resolution.

The specification of that Z-axis input are

  • impedance 33 kΩ
  • maximum voltage 30 V (DC + AC peak), MAX AC 1kHz
  • band width DC to 2 MHz.

OK, that means with 4 MHz I am already stretching it, and 16 would take it too far, but then I might have a different scope. Maybe I get myself a Tektronix 2246 that says it's usable up to 10 MHz.

So, what could be done to get it better? I guess given that R6 is low, the 33 kOhm on the Z-axis input should not really be a problem, but still on the 10x probe I see a major decay when connecting the Z-axis input.

Parasitic capacitance on the base of Q2. What if we were using a MOSFET? 2N7000 n-channel and BS250 p-channel MOSFET is what I have here. The inverting isn't critical, as I might anyway want to route the input signal through a buffer, so might just as well route it through an inverter. But I guess now the question is how to do the level shifting with -12V with that, can it be done?

UPDATE: I found another circuit right here, which helped me understand better the way to build the complementary side, but also how to change the BJTs to MOSFETs. But still it won't do 16 MHz: TTL to +/- 12V conversion - what's a better way?

The proposed solution I first simulate like this:

enter image description here

here is its performance at its bandwidth limit at 400 kHz.

enter image description here

So now I checked if I could build it with the MOSFETs I have available, BS250 for p-channel and BS170 or 2N7000 for n-channel. But the original contributor of the schematics only gave verbal description of the MOSFET transformation:

Since this answer was posted, I changed the design to use MOSFETs for speed. On the "left" pair the gate (formerly base) bias resistors are 0Ω, and there's a 10kΩ pull-up to +5 to protect against floating input (during controller reset). On the "right" pair, each gate has a 1kΩ resistor to source and a 10kΩ resistor resistor to the previous stage's drain. This makes each secondary MOSFET turn off quicker than turn on, which reduces transient current. The result is < 1µs rise/fall time to 90%

I wasn't clear about the resistors and couldn't get a decent result, so I removed all the resistors except two which I could ascertain needed to remain albeit at very low value. Here is the result:

enter image description here

and the response at 4 MHz is adequate:

enter image description here

blue is the drain of M1, red drain of M2 and then cyan the output between M3 and M4. This is very educational.

Now let's see this at 16 MHz, first double to 8:

enter image description here

that's already getting stressed, and now at 16 MHz:

enter image description here

it breaks down.

So, this won't work for me even in this ideal simulated case with no parasitic resistances and capacitances.

Here one more view of the 4 MHz circuit with the currents to see if it's feasible. Peaking at 1.5 A to supply that big swing, but I supposed a good bypass capacitor can provide that.

enter image description here

When I built it, I immediately blew M1 in smoke. So I figured I need a few more resistors.

enter image description here

and here is the simulation, the currents are more reasonably limited now:

enter image description here

but now R4 still got fried. And I am frankly worried that with this circuit if M1 or M2 get fried to bridge between + or - 12V and the 5V TTL power rail, I might blow more chips, if not the entire setup. So a complete separation would be better. And I wonder, could one use an opto-coupler for a level shifter or would that be too sluggish again?

Gunther Schadow
  • 1,441
  • 7
  • 22
  • what's the capacitance of the Z input? – Jasen Слава Україні Sep 19 '20 at 23:03
  • 1
    At 16 MHz, you only have 62.5 ns per cycle. If you decide to allow 10% of that for rise and fall times (I'm just throwing mud at the wall, right now, to see what sticks for you), then you have almost 4000 volts per microsecond or needing almost 4 A just to drive a mere 1 nF of capacitance. That may be what's informing Jasen's question, an hour back. It's important. – jonk Sep 20 '20 at 00:21
  • 1
    Also, if you are serious about discrete designs (you seem to be, but I'm not sure), then RF PNPs are kind of hard to come by. More-so with the voltages you are swinging around. You may require a class-A design, not class-AB or class-B, so you can just use NPN BJTs and run this hot enough to drive whatever Zload/Zin you seek to drive. 16 MHz for a discrete design isn't a walk in the park. Especially slugging between -12 V and +12 V. – jonk Sep 20 '20 at 00:45
  • 1
    If you were serious about this, you'd *start over* using a circuit topology which could *actively drive* in both directions, instead of rely on a pulling resistor. – Chris Stratton Sep 20 '20 at 00:59
  • Those are all good points. It works with 4 MHz and I didn't yet think about the issue with the 16 MHz and 4000 V/us ~ 4A (although a bypass capacitor should be able to do that, no?) all those are good points. I was going to just prototype this on the breadboard and then move to a PCB ... although I should make myself a serious one with a ground plane baked in I guess. – Gunther Schadow Sep 20 '20 at 02:07

2 Answers2

2

[error corrected 17:20GMT Sept 20]

Suggestions on this speedup

  • you are breadboarding a circuit intended to switch (at the input) 2v/100 = 20mA in 5 nanosecond. In 4" of wire (100nH), the VDD sag if poorly bypassed will be V = L * dI/dT = 100nH * 20mA/5nanoSec = 2000/5 * milli = 0.4 volts. Thus Ground plane and VDD bypassing (1/4" wide VDD strip) are suggested

  • that 40 nanosecond delay, from Input going Low, to output starting high, is puzzling. There should be no stored charge in that pre-transition quiescent state: both transistors being OFF

  • I agree with Chris Stratton about having a strong pulldown also. So take the existing circuit, mirror it with opposite polarity transistors, connect the new common_base's base to GROUND, have 68 ohms in the emitter, replace the output resistor with the new NPN pulldown collector. [had been PNP pulldown]

  • use Baker Clamps in both common_emitter Inverting devices, to avoid saturation

analogsystemsrf
  • 33,703
  • 2
  • 18
  • 46
  • When you say a "opposite polarity transistor" to the existing Q2 PNP then wouldn't that be an NPN? But in the end you say "with the new PNP pulldown collector"? – Gunther Schadow Sep 20 '20 at 04:45
2

Here's what did to improve it when I designed the original circuit (showing my LTspice schematic because I don't have the patience to redraw it in Circuitlab). I simply added a complementary Emitter-follower output stage to increase drive current and reduce capacitive loading on R1.

enter image description here

enter image description here

The graph is at 4 MHz. LTspice thinks it will work at 16 MHz, but with some asymmetry.

Bruce Abbott
  • 55,540
  • 1
  • 47
  • 89
  • Thank you once again, only that it isn't actually improving the frequency response in my case. In practice it works better for me just leaving it as it is. Weird. – Gunther Schadow Sep 21 '20 at 20:26
  • That is weird. In simulation it shows a clear improvement, and LTspice is usually pretty accurate. Are you sure the output transistors were wired correctly? – Bruce Abbott Sep 21 '20 at 22:42