1

I am trying to make an 8x8 LED matrix (actually a bigger one, but for now it would be easier to discuss this more simplified version) and I have gotten too confused about a few things concerning the current I need to source or sink as well as the brightness of the LEDs.

For multiplexing I am using two 74HC595 parallel out shift registers each connected to the 8 rows (anodes) and 8 columns (cathodes) respectively. In the case where I have a walking bit (0) for the cathodes, meaning I ground each column at a time and give HIGH to the rows I need to light in that column, I need to sink the current for up to 8 LEDs in one pin. Since the 74HC595 can source/sink up to 25mA per pin and up to 70mA in total, it's not possible to sink the current for all 8 LEDs, neither can it source (to the rows) that current to 8 LEDs. For sinking the current I have found an IC, namely the ULN2803 darlington transistor array, which can sink up to 500mA. So that seems to be fine, considering each LED can handle up to ~20mA of "Continuous Forward Current".

Accordingly, for sourcing current to the rows, I could add a circuit to each of the 595's outputs, consisting of an NPN transistor and a shunt regulator (TLV431) as explained in this video.

This circuit can allow me to provide constant current at each row.

On the other hand there is the problem of LED brightness that comes with multiplexing. Since each column would be on just for 1/8 of the time (1/8 duty cycle) that means I would need to provide more current than the 20mA given for Continuous Forward Current to perceive the same brightness, and from what I've understood I would need to give it about 8 times as much (~160mA). In the specs of an LED there is the "Peak Forward Current" which, depending on the LED, could be ~150mA, but a note says "1/10 Duty Cycle, 0.1ms Pulse Width." The microcontroller I am using (Beaglebone Black with Bela cape) gives me a slow frequency of 2756.25Hz (for 8 bits), which means my pulse width would be 0.36ms 3-4 times more than specified, and also my duty cycle would be 1/8 instead of 1/10. That means that I shouldn't provide the peak current specified but something rather less (in order for the LED to be able to dissipate the heat). Even if it would be possible to provide 100mA to each LED, then the column should be able to sink up to 800mA even though the ULN2803 can sink up to 500mA.

  1. How much current do I need to provide each row so that I perceive a good brightness, considering the duty-cycle and pulse width of my application?

  2. Is the NPN & TLV431 circuit a good choice for supplying constant current or is there a better alternative?

  3. Do you think the ULN2803 is a good choice for sinking the current of 8 LEDs or would I need something to sink more current?

JYelton
  • 32,302
  • 33
  • 134
  • 249
tsambou
  • 13
  • 3
  • *500mA* for the ULN2803 is an *absolute max* rating. Do a heat dissipation survey, to see if it will overheat (I think it will). What DC voltage will the matrix be supplied?...+5V likely won't work - you probably need more. – glen_geek Nov 20 '19 at 15:28
  • @glen_geek Thanks for your reply. I didn't know voltage would be a consideration here. The microcontroller I am using can supply either 3.3 or 5 volts but maybe I could supply the chips with an external source if needed. – tsambou Nov 20 '19 at 15:39
  • It is possible to choose FET drivers that can handle 800% current @ 1/8th duty cycle, but the problem is the LED choice may not support thus ratio. The tradeoff is the gold wirebond must be thicker and more visible to support this current and not fuse open the wirebond. This is a difficult high-current MUX thermal-design issue. – Tony Stewart EE75 Nov 20 '19 at 16:16
  • @TonyStewartSunnyskyguyEE75 Thanks for your reply. Unfortunately I'm quite new to all this electronics stuff (all I am saying is from what I've understood reading threads etc) and cannot quite follow your thinking. What do you mean by "gold wirebond"? Is it that the wires connecting the components need to be thick enough to support this current? I am trying to design this on kiCad and have been using 0.75mm wire thickness on a 1mm copper board, even though at some points, because of the tight setup I am using 0.45mm. Do you think this is not enough to support this current? – tsambou Nov 20 '19 at 16:32
  • No it’s the internal Anode connection size that limits peak /Avg current ratios on LEDs is much lower than normal diodes due to need to not be visible. – Tony Stewart EE75 Nov 20 '19 at 17:28
  • @tsambou Are you planning to drive more than one *type* of LED? For example, some red, some green, and some blue or some RGB tricolor types? It changes the whole discussion in my mind, depending. And since you are trying to simplify the question, it's impossible to know where you are really headed. – jonk Nov 21 '19 at 02:06
  • @jonk No I am planning to drive LEDs of one color, specifically red. Typically such LEDs have a DC forward current of ~20mA and approximately 100-150mA of peak forward current (1/10 Duty Cycle, 0.1ms Pulse Width) as well as a typical forward voltage of ~2V – tsambou Nov 21 '19 at 15:08
  • @tsambou I doubt the 2 V figure when over driving them. So you have a measurement for their overdrive voltage? – jonk Nov 21 '19 at 18:05
  • @jonk No I haven't actually measured it. The specifications don't mention anything except a max forward voltage which is typically ~2.5V. – tsambou Nov 21 '19 at 18:53
  • @tsambou You ***should*** make some measurements. Use about 5 or 10 of them and use a current source (or less convenient methods) and drive those higher currents through them. Then measure the voltage across. It's kind of important. Or else, do you have a datasheet to link? – jonk Nov 21 '19 at 19:48
  • @jonk This is the datasheet of an LED I am considering (haven't bought it yet): https://www.tme.eu/Document/7b82d75a8e15e99e7df0baa2e1167ee1/L-113IDT.pdf Thanks for the info anyway, I will try measuring some LEDs and see their response – tsambou Nov 22 '19 at 16:53
  • @tsambou Thanks. I've not looked at it yet, but I appreciate that you found it. Before I do look, just want to make a suggestion. It would be helpful if you'd take factual information and a link to the datasheet and place them into the question itself. That way, it is all in one place and someone new isn't forced to read lots of comments to understand the details. It's just good consideration for the time of others. – jonk Nov 22 '19 at 19:35

1 Answers1

2

Short Answer First

The short answer to your general question is that you provide active switches on the anode side with active current mirror sinks on the cathode side to limit the current; or else you provide active switches on the cathode side with active current mirror sources on the anode side to limit the current. If all that makes total sense to you, then nothing more needs be said.

Slightly Longer Answer

There's plenty of information available for turning a MOSFET or a BJT into an active switch. You can use either for the purpose. Usually, the choice is determined by a host of factors that include the peak currents involved, availability of parts, features, manufacturer support, part variations that must be managed, cost, and more.

There's plenty of information available about current mirrors, too. And this is what's used inside of fancy ICs used to drive some LED displays. Again, a current mirror can be composed of MOSFETs or BJTs. And again, which you choose to use will depend. But since there are ICs out there, you should actually research the subject. If I were doing this kind of project, I'd probably avoid "going discrete" (unless I wanted to prove something) because a current mirror done on an IC is so much better than one done with discrete parts. That said, there are circumstances where you have no choice but to use discrete parts. So, like everything, there are no bright lines.

You should definitely look through all the IC offerings for driving LEDs. Don't limit yourself to serial-to-parallel shift registers! There are really good ICs available to provide settable current limits for your LED driving needs and that work very well for applications such as yours. If you haven't already done so, take a look and learn about the various ICs that are available to help. They often include the shift register, as well as many other useful features.

The TLV431 video you mentioned works for one LED. (Though, you can also use that approach with discrete BJTs or MOSFETs for a larger number of them, if you know how to mirror currents around with discrete parts.) But it's probably not nearly as good a solution as using ICs (so long as the ICs support the current range you need, of course.) And even for the one-LED approach, I think the TLV431 is over-kill. (I have thousands of various varieties of the TLV431 -- more than I'm likely to use in my remaining lifetime. I love the devices and use them. Just not in this way.)

Your LED

There's not a lot of data in that datasheet you provided. All it says is that if there is a forward current of \$20\:\text{mA}\$ then the voltage across the LED can be as much as about \$2.5\:\text{V}\$ with a more typical value of \$2.0\:\text{V}\$. (There's nothing on the lower limit, but I doubt it can get much lower than \$1.8\:\text{V}\$.) So that's probably my guess about this LED in continuous operation. And this wide voltage range means the parts are pretty much anything that comes out of the FAB and meets some very basic specs are sold without any further binning.

It may also be interesting to read what I wrote here about LED current regulation using a resistor. Given the percent voltage variations possible between LEDs, your desire to seriously over-drive them, and the fact that your IC choices suggest a \$5\:\text{V}\$ power rail voltage, I don't think you should just rely upon a resistor for the current-limiting purpose.

General Approach

In general, the multiplexing approach looks like this:

schematic

simulate this circuit – Schematic created using CircuitLab

(The above schematic shows high-side switches with low-side current sinks. It could just as well have been low-side switches with high-side current sources.)

The \$X_i\$ lines are switch-enable lines. No more than one of these should be enabled at a time. These switches must be able to carry the entire sum of the multiplexed, over-driven LED currents in their group, as you may enable zero, one or all of the \$Y_j\$ current-sink lines when a particular \$X\$-switch is turned on.

These \$X\$-switches have to support that maximum current sum and do it without dropping much voltage. There are two primary reasons for this.

  1. Keeping the switch voltage drop as small as possible allows you to use a lower voltage rail magnitude. This means a lower supported wattage for the power supply. Which means cheaper, easier, better, etc.
  2. Keeping the switch voltage drop as small as possible means less wasted dissipation in the switches (which means smaller heat sinks, less airflow required, cheaper parts, etc.) and in the current sink sections (which again means cheaper, easier, better.)

(The \$Y_i\$ lines are current-sink-enable lines, of course.)

The first thing you need to decide about is just how much current over-drive you can tolerate in the LEDs. Usually, if an LED is intended for multiplexing (or, at least, the manufacturer wants to widen its market for them) then the datasheet will include at least some information with an example case with higher currents that they recommend considering.

Your LED, Revisited

In your LED case, the manufacturer says "SUITABLE FOR LEVEL INDICATOR" and it says in the "ABSOLUTE MAXIMUM RATINGS" (at \$25^\circ\,\text{C}\$) that \$I_\text{F}\le 30\:\text{mA}\$. (That's continuous.)

They do add, in the "ABSOLUTE MAXIMUM RATINGS," that \$I_\text{F}\le 160\:\text{mA}\$. And yes, they do have a footnote about how they achieved that absolute maximum spec. But I don't interpret that to mean that you should actually operate the device anywhere near that absolute maximum spec. It is, after all, listed in the absolute maximum ratings section. Perhaps half that? But I'm guessing. If you want to find out, you should contact the manufacturer (directly, or through representation) and get an answer. You should also ask them if they have any detailed information about the voltage range of the LEDs when operated at higher-than-continuous pulse currents.

Even with an answer from the manufacturer, you should "trust, but verify." This means buying some and sitting down at a bench to run tests. If all you have is a voltmeter/ammeter, you can do all the testing required. In that case, perform short tests, so that you don't put the LED into unsafe operating temperatures. So only keep the LED active long enough to "get a reading" and then immediately shut it down and let it cool down before attempting another test.

You need information. And the datasheet doesn't really provide it for your use.

But don't design for the "absolute maximum rating" of a device. That's not good practice.

At this point, I have to stop any additional thoughts. I can't recommend an approach here as I don't have numbers to work with.

Note:

You mentioned 16 LEDrings / 16 Encoders Control Surface PCB as a similar project to yours. I think this is wonderful. It's very attractive but also useful and designed with human factors in mind. I like that. But did you also notice on that page a comment:

"Since Tk discovered a brightness problem with some rectangular 5x2x7mm LEDs, we found useful to create a list of LEDs wich are successfully or unsuccessfully tested."

Brightness perception is another complex topic. My experience is that different LEDs, even from the same batch, can have sufficiently different brightness perceptions in a darkened environment (or lightened, too) that they cannot be successfully operated at exactly the same current when you are using them in a single display. LED manufacturers creating 7-segment displays or other devices like that will go to some lengths to pre-bin their LEDs before assembling a single display. And where these displays may be used in combination, they will bin the entire display systems so that their customers can be assured that when they put display 1 next to display 2 in, say, an aircraft instrumentation panel, that the LEDs will all "look the same brightness" when operating. It turns out (or at least for those years I was involved about a decade ago) that FABs just aren't good enough to produce identical LEDs even on the same wafer. Human perception is very, very good and can detect subtle differences.

If you were really serious about producing beautiful LED display systems like this, you have a few options.

You can buy pre-binned LED devices (they exist) where the manufacturer has done all the work for you and all you need to do is supply the same pulse currents in your multiplexed system and all the LEDs will look very much the same and very professional. This is fine if you just build one display system. But suppose you have to build another one in a year's time? Will the manufacturer be able to give you the exact same binned LED then next time you order from them? Maybe. Maybe not. Some manufacturers will be very careful about they binning and provide coded values which mean you really can re-order similar devices. But not all do that for you. Just another thing to consider.

You can also just buy grab-bag LEDs (no pre-binning) and instead plan to write software which carries a "calibration" value that is unique for each LED you will multiplex. You still use the exact same currents in all the LEDs (using ICs that do this easily for you), but now you "adjust" the pulse width differently for each LED.

In this latter case, let's say you have a multiplexing system with those switches and current sinks I mentioned in the general approach above. The current sinks are all set for, let's say, \$80\:\text{mA}\$ (and your switches can handle their maximum load just fine) because you will be using a \$\times 4\$ multiplexing approach (25% for each time-slice.) Let's say you are using a \$1\:\text{kHz}\$ rate, so that each time slice is \$250\:\mu\text{s}\$. This means that, without calibration involved, you'd operate an LED (if on) at \$80\:\text{mA}\$ for \$250\:\mu\text{s}\$, with a dead time of \$750\:\mu\text{s}\$ before coming back to that LED in the multiplexing process.

If you now add an LED calibration feature to this, one way might be to build up the entire system with random LEDs and then identify which one of them was the least bright. That one gets the full on-time of \$250\:\mu\text{s}\$. You'd now go through all of the nearby LEDs and adjust their timing downward from there until they appeared the same brightness. In this way, with unique time periods per LED you'd be able to get them all looking the same.

If you need to make different panels similarly adjusted all look the same, then you'd make the set current limit (which I'd suggested might be \$80\:\text{mA}\$ earlier) to a different value. By providing "set current" adjustability, you allow yourself a way of making all the displays look the same if they are placed into the same, larger system.

As you can see, none of the above can reasonably be done "with resistors."

BUY THIS BOOK

While there are many books out there on this topic, there is one and only one seminal public textbook on the subject matter:

    Optoelectronics/
    Fiber-Optics Applications
    Manual    Second Edition
    
    Prepared by The Applications Engineering Staff of the
    HEWLETT-PACKARD OPTOELECTRONICS DIVISION

    Stan Gage, Applications Engineering Manager       Hans Sorensen, Applications Engineer
    Dave Evans, Applications Engineer                 Dick Jamison, Applications Engineer
    Mark Hodapp, Applications Engineer                Bob Krause, Applications Engineer

    McGraw-Hill Book Company
    1981 (and 1977 for the first edition)

Your question suggests to me that you are embarking on a trek of which, perhaps out of consideration for our time, you are not fully sharing the details here. Given that, you need extra resources that will help you navigate as you go. And I cannot think of a better book to have on hand. It stands alone in the industry.

This book is comprehensive in scope and detailed down to a fine point, too. If you have a question about LEDs, any question at all, then the odds are very high there will be a section on the subject within this single textbook.

(I have five remaining copies of the book, here at home, though I originally bought closer to 20 of them about 20 years ago. The reason is that I was able to buy them cheaply and I wanted to make sure my customers got a copy, if they didn't already have one. Part of the service I offered, so to speak.)

This book is also old school, which is where your question is coming from. Modern LED display systems use specialized ICs for the purpose -- and I mean custom ICs that are not available on the open market and are designed to a very specific purpose. I worked on these back RGB LED display modules (circa 2002, for Siemens-OSRAM):

enter image description here

That's my signature (j.k.) on the back, there. Inside each module are (6) custom ICs that are simply unobtainium to the outside world: custom designed for this product. These were paneled up into those outside active LED displays you might see alongside a freeway, attracting your attention away from your driving, for example. Each module was rated for about \$80-100\:\text{W}\$ of dissipation and they used three separate voltage rails, one for each color, in order to help minimize the module's dissipation under normal operation.

These devices use switches and current sinks, similar to what I discussed above. The current sinks were settable "per color" and this was treated as a "100%" current for the LEDs. (Red would have one value, green another, and blue yet another.) Within that setting, PWM was used to dim within the multiplexed time slot. So if the full time slot period was \$100\:\mu\text{s}\$ for a particular LED's current sink, for example, then the PWM value also for that LED would be used to change the period for which that current sink was enabled. A 25% PWM value for the LED would mean that the current sink was enabled for only \$25\:\mu\text{s}\$. This doesn't affect the switch time, though. That would still be enabled for the full \$100\:\mu\text{s}\$, because there are other LEDs also being switched; each of which may have differing PWM values. So the switch would remain enabled for a fixed time. But the current sinks would be enabled for varying times, but where a 100% PWM value meant they were enabled for the entire time slot.

In the above units, we even included features such as a "column stagger" which could be set from \$0\:\text{ns}\$ to \$15\:\text{ns}\$. This delayed the turn-on of the column current sources and helped to reduce the generated EMI.

The point I'm trying to make here is that LEDs are not easy to drive. They seem really easy when it's just one; or just a few blinky lights. But the moment you start talking about serious numbers of them? And serious levels of multiplexing? This is when the serious sit-down thinking time happens while you balance various approaches towards your goal and knock out a very detailed, very exact plan of attack.

jonk
  • 77,059
  • 6
  • 73
  • 185
  • Thank you so much for your extensive answer. It helps clarify a few things. The LEDs I linked (as well as two other similar which also say "for level indicator") were suggested to me by my local supplier, but after your remarks I can understand that they are not suitable for such a project. Still, there is an indication of Peak Forward Current at 160mA specifying for 1/10 duty cycle and 0.1ms pulse width. Wouldn't that mean that they have tested them with multiplexing? Anyway I will probably go and buy the book you suggested and start a bit of reading to get a grasp of it. – tsambou Nov 23 '19 at 21:27
  • Additionally I wanted to add this link here from a project similar to the one I want to make: http://www.midibox.org/dokuwiki/doku.php?id=mb-lre8x2cs_rev4.6#mb-lre8x2cs_rev_46 If you take a look at the schematic you can see that the source drivers are plain 74HC595 shift registers while the sinking is done through a ULN2803. But doesn't this mean that each LED can get up to 8.75mA since a 74HC595 can source up to 70mA of current? This quite puzzles me, since it looks to have been applied multiple times successfully. – tsambou Nov 23 '19 at 21:34
  • @tsambou Yes, there is that peak figure. Thanks for pointing it out to me. I've adjusted my answer. The book is excellent. Do see about getting a copy. They are not currently in print, though. So it will be a used book. – jonk Nov 23 '19 at 21:57
  • @tsambou That's a beautiful panel! I just did a quick look. It reminds me of my own love -- the PDP-11/70 front panel and the HP21xx front panel designs for minicomputers (back when.) It's truely lovely. By the way, I just paid almost $50 for a good optical quadrature encoder control. And that did NOT include the knob, which cost me another $10. Used to be, everything had mechanicals. But these days it's all too expensive. It's nice to see this semi-retro, yet also modern approach. I love it. – jonk Nov 24 '19 at 06:29
  • @tsambou And no, I don't like the resistor limiters. But I see where you got your ideas. If I were serious about that kind of stunningly beautiful panel, I'd do it right and spend a few extra dollars on parts. I'd also study more of the HP book I mentioned, because you will probably want to look over the special area of ***contrast enhancement*** ideas, too. There's a lot that can be done with non-electrical filtering -- methods to improve the difference between the luminous sterance of the LEDs with respect to their backgrounds and ambient light/reflectance, etc. Worth the time. – jonk Nov 24 '19 at 06:34
  • @tsambou If there's a market for something like this, you might make yourself a real bundle -- maybe even a livelihood -- from specializing in this and related devices. There may be lots of potential. – jonk Nov 24 '19 at 06:36
  • Thanks a lot for your input. I am still a bit confused about how to pick the right LED. Since the one I linked does mention a peak current for a specific duty cycle/pulse width I would guess it has been tested with multiplexing. But in any case, since you mention that it is not suitable, is there a specific keyword or feature of an LED that indicated it can be used for applications such as mine? I need something in order to be able to search for a part, or ask my local supplier if he can provide something. – tsambou Nov 24 '19 at 11:46
  • @tsambou In my experiences, that's been determined by a lot of bench work; and also perhaps communication with the manufacturer. I would certainly bow to definite statements by the manufacturer of this device, for example. The bench work usually also involves the optical design and luminous sterance and filtering tests. If the LED is already determined, then usually that work product exists. It doesn't mean the work wasn't done. – jonk Nov 24 '19 at 14:54
  • @tsambou You have to make your own choices, though. So let's assume you want to use this LED, don't want to contact the manufacturer for clarification about the absolute specs, and don't want to spend bench time (which also means you won't have any data on the voltage needed at some very much higher current.) Then I don't know what to say about it. You are making your own assumptions, which I think don't provide enough good info. I can only suggest then that you do not attempt a X8 multiplexing. Maybe a X4. – jonk Nov 24 '19 at 14:59
  • @tsambou The rest of what I said should generally apply. I wouldn't use resistors to current limit in the situation I saw. There are better ways using modern LED driver ICs. This is the kind of design I might have seen 35 years ago when newer and nicer ICs didn't exist. I don't want to pick one of those for you, though. Availability in your area may play an important part of a good decision. But I'd look for one that includes the shift registers and includes settable current limiting externally. PWM within each period may not be needed in your case, though. – jonk Nov 24 '19 at 15:10
  • @tsambou I've expanded many more details in the answer. They may be worth a little thought on your part. Jut FYI. – jonk Nov 24 '19 at 20:16