AVR Based Tester
AVR Based Tester
Contents
1 Features
2 Hardware
2.1 Circuit of the TransistorTester . . . . . . . . . . . . . .
2.2 Extensions for the TransistorTester . . . . . . . . . . .
2.2.1 Protection of the ATmega inputs . . . . . . . .
2.2.2 Measurement of zener voltage above 4 Volt . . .
2.2.3 Frequency generator . . . . . . . . . . . . . . .
2.2.4 Frequency measurement . . . . . . . . . . . . .
2.2.5 Using of a rotary pulse encoder . . . . . . . . .
2.2.6 Connection of a graphical display . . . . . . . .
2.2.7 Connection of a graphical color display . . . . .
2.3 Hints for building the TransistorTester . . . . . . . . .
2.4 Changeover for tester versions designed by Markus F. .
2.5 Chinese clones with text display . . . . . . . . . . . . .
2.6 Chinese clones with graphical display . . . . . . . . . .
2.7 Chinese kits with graphic displays . . . . . . . . . . . .
2.8 Extented circuit with ATmega644 or ATmega1284 . . .
2.9 Buildup of a tester with ATmega1280 or Arduino Mega
2.10 Programming of the microcontroller . . . . . . . . . . .
2.10.1 Using the Makefile with Linux . . . . . . . . . .
2.10.2 Using the WinAVR package with Windows . . .
2.11 Troubleshooting . . . . . . . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
9
9
11
11
12
13
13
13
15
19
20
21
22
23
28
29
31
33
33
34
36
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
38
38
39
42
43
43
44
45
45
45
45
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
47
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
58
60
61
63
66
68
69
73
73
75
76
81
81
81
84
86
87
89
92
98
99
100
104
108
109
109
111
115
119
6 Signal generation
121
6.1 Frequency Generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
6.2 Puls width generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
7 Known errors and unsolved problems
122
123
124
Preface
Basically Motive
Every hobbyist knows the following problem: You disassemle a Transistor out of a printed board or
you get one out of a collection box. If you find out the identification number and you already have
a data sheet or you can get the documents about this part, everything is well. But if you dont find
any documents, you have no idea, what kind of part this can be. With conventional approach of
measurement it is difficult and time-consuming to find out the type of the part and parameters. It
could be a NPN, PNP, N- or P-Channel-Mosfet etc. It was the idea of Markus F. to hand over the
work to a AVR microcontroller.
Deutscher Amateur Radio Club (DARC) in Lennestadt. Also I would like to say thanks for the
integration of the sampling method to the radio amateur Pieter-Tjerk (PA3FWM). With this method
the measurement of little capacity and inductance values could be improved noticeable. Last but
not least I would say thanks to Nick L. from Ukraine, who has supported my with his prototype
boards, has suggested some hardware add ons and also has organized the russian translation for this
description.
Chapter 1
Features
1. Operates with ATmega8, ATmega168 or ATmega328 microcontrollers. Additionally ATmega644,
ATmega1284, ATmega1280 or ATmega2560 microcontrollers can be used.
2. Displaying the results to a 2x16 or a 4x16 character LCD-Display. If the processor have at
least 32K flash memory, also a graphical display with 128x64 pixel and a ST7565, ST7920,
ST7108, KS0108 or a SSD1306 controller can be used. In doing so a 4-wire SPI interface or a
I2 C bus must be used instead of the 4-bit parallel interface for the SSD1306 controller. Even
color displays with ILI9163 or ST7735 controller are usable with the SPI interface. For the
ST7108 or KS0108 controller you must use a serial - parallel interface with a 74HC(T)164 or a
74HC(T)595. Displays with PCF8812 or PCF8814 controller can be only used without the big
icons for transistors, because the display size is unsufficient (102x65 and 96x65).
3. One key operation with automatic power shutdown.
4. Battery operation is possible since shutdown current is only about 20nA.
5. Low cost version is feasible without crystal and auto power off. With software version 1.05k
the sleep modus of the Atmega is used to reduce current if no measurement is required and no
rotary encoder is used (not with ATmega8).
6. Automatic detection of NPN and PNP bipolar transistors, N- and P-Channel MOSFETs,
JFETs, diodes, double diodes,N- and P-IGBTs, Thyristors and Triacs. For Thyristors and
Triacs the ignition current and holding current must be reached with the tester. For IGBTs
the 5V signal should be enough for driving the gate voltage.
7. Automatic detection of pin layout of the detected part.
8. Measuring of current amplification factor and Base-Emitter threshold voltage of bipolar transistors.
9. Darlington transistors can be identified by the threshold voltage and high current amplification
factor.
10. Detection of the protection diode of bipolar transistors and MOSFETs.
11. Measuring of the Gate threshold voltage, the Gate capacity value and the RDSon at almost 5V
gate voltage of MOSFETs.
and values with up to four
12. Up to two Resistors are measured and shown with symbols
decimal digits in the right dimension. All symbols are surrounded by the probe numbers of the
Tester (1-3). So Potentiometer can also be measured. If the Potentiometer is adjusted to one
of its ends, the Tester cannot differ the middle pin and the end pin.
5
13. Resolution of resistor measurement is now up to 0.01, values up to 50M  are detected.
and value with
14. One capacitor can be detected and measured. It is shown with symbol
up to four decimal digits in the right dimension. The value can be from 25pF (8M Hz clock,
50pF @1M Hz clock) to 100mF . The resolution can be up to 1pF (@8M Hz clock].
15. For capacitors with a capacity value above 90nF the Equivalent Serial Resistance (ESR) is
measured with a resolution of 0.01 and is shown with two significant decimal digits. This
feature is only available for ATmega with at least 16K flash memory.
16. For capacitors with a capacity value above 5000pF the voltage loss after a load pulse can be
determined. The voltage loss give a hint for the quality factor of the capacitor.
or symbol
18. LED is detected as diode, the flux voltage is much higher than normal. Two-in-one LEDs are
also detected as two diodes.
19. Zener-Diodes can be detected, if reverse break down Voltage is below 4.5V . These are shown
as two diodes, you can identify this part only by the voltages. The outer probe numbers, which
surround the diode symbols, are identical in this case. You can identify the real Anode of the
diode only by the one with break down (threshold) Voltage nearby 700mV !
20. If more than 3 diode type parts are detected, the number of founded diodes is shown additionally
to the fail message. This can only happen, if Diodes are attached to all three probes and at
least one is a Z-Diode. In this case you should only connect two probes and start measurement
again, one after the other.
21. Measurement of the capacity value of a single diode in reverse direction. Bipolar Transistors
can also be analysed, if you connect the Base and only one of Collector or Emitter. If a ATmega
with more than 16K flash memory is used, also the reverse current of the diode is measured
with a resolution of 2nA. The value is only output to the screen, if it is greater than zero.
22. Only one measurement is needed to find out the connections of a bridge rectifier.
23. Capacitors with value below 25pF are usually not detectet, but can be measured together with
a parallel diode or a parallel capacitor with at least 25pF . In this case you must subtract the
capacity value of the parallel connected part. For processors with at least 32K flash memory
the tester changeover to a special capacity meter function, if a capacitor with more than 25pF
is once measured at TP1 and TP3. In this capacitor meter mode you can measure capacitors
below 25pF at TP1 and TP3 directly.
24. For resistors below 2100 also the measurement of inductance will be done, if your ATmega
is shown behind the resistor
has at least 16K flash memory. For that a inductor icon
icon
. The range will be from about 0.01mH to more than 20H, but the accuracy is
not good. The measurement result is only shown with a single component connected.
25. Testing time is about two seconds, only capacity or inductance measurement can cause longer
period.
26. Software can be configured to enable series of measurements before power will be shut down.
27. Build in selftest function with optional 50Hz Frequency generator to check the accuracy of
clock frequency and wait calls (only for processors with at least 32K flash memory).
6
28. Selectable facility to calibrate the internal port resistance of port output and the zero offset of
capacity measurement with the selftest (only for processors with at least 16K flash memory).
A external capacitor with a value between 100nF and 20F connected to pin 1 and pin 3
is necessary to compensate the offset voltage of the analog comparator. This can reduce
measurement errors of capacitors of up to 40F . With the same capacitor a correction voltage
to the internal reference voltage is found to adjust the gain for ADC measuring with the internal
reference.
29. Display the Collector cutoff current ICE0 with currentless base (1A units) and Collector residual current ICES with base hold to emitter level (only for processors with at least 16K flash).
This values are only shown, if they are not zero (especially for Germanium transistors).
30. For a ATmega with at least 32K flash memory the tester changes the operation modus from
universal tester to a resistor tester, if only one resistor is detected at the test pin 1 (TP1)
and test pin 3 (TP3). If you have selected the additional measurement of inductance for the
resistor meter function with the Makefile option RMETER WITH L, also the inductance of
components is measured in this mode. This special operating mode is indicated with a [R] or
[RL] at the right side of the first display line. In the same way the tester changes to a capacity
meter function, if a capacitor is detected at TP1 and TP3. This operation mode is indicated
with a [C] at the right side of the first display line. With this capacity meter function capacity
values are shown down to 1pF . Only for the automatic start you need a capacitor with more
than 25pF . Both special modes can be finished by a key press. The tester will then continue
with the normal tester function.
31. For processors with at least 32K flash a dialog function can be selected, which enable additional
functions. Of course you can return from dialog to the normal Transistor Tester function.
32. With dialog function you can use a frequency measurement at port PD4 of the ATmega. The
resolution is 1Hz for input frequencies above 25kHz. For lower frequencies the resolution
can be up to 0.001mHz by measuring the mean period. You should read the the subsection
Frequency measurement 2.2.4 at page 13 for details of connection a frequency signal.
33. With the dialog function and without the activated serial output a external voltage of up to
50V can be measured with the 10:1 voltage divider at the PC3 port. If the PLCC-Version of
the ATmega328 is used, one of the additional pins can be used for the voltage measurement
together with the serial output. If the zener diode measurement extension (DC-DC converter)
is assembled, the measurement of zener diodes is also possible with this function by pressing
the key.
34. With the dialog function a frequency output can be selected at the TP2 pin (PB2 Port of the
ATmega). Currently a preselection of frequencies from 1Hz up to 2M Hz can be selected.
35. With the dialog function a fixed frequency output with selectable pulse width can be activated
at the TP2 pin (PB2 port of the ATmega). The width can be enhanced with 1% by a short
key press or with 10% by a longer key press.
36. With the dialog function can be started a separated capacity measurement with ESR measurement. Capacities from about 2F up to 50mF can most be measured in circuit, because only
a little measurement voltage of about 300mV is used.
37. If your ATmega has at least 32K flash memory (Mega328), you can also use the sampling
method of the ADC, which can measure capacitors with less than 100pF at a resolution of
up to 0.01pF. With the same method you can also measure coils with less than 2mH with
7
significant better resolution of the inductance by building a resonant circuit with a parallel
capacitor of known capacity value.
You should make sure, that all capacitors have no residual charge before starting any measurement, especially if you use the tester for measurement of capacitor in circuit.
Thyristors and Triacs can only be detected, if the test current is above the holding current. Some
Thyristors and Triacs need as higher gate trigger current, than this Tester can deliver. The available
testing current is only about 6mA! Also a IGBT can only be detected correctly, if a voltage of 5V
is sufficient to drive the gate. Notice that many features can only be used with microcontroller with
enough program memory such as ATmega168. Only processors with at least 32k flash memory like
ATmega328 or ATmega1284 can take all features.
Attention: Allways be sure to discharge capacitors before connecting them to the Tester!
The Tester may be damaged before you have switched it on. There is only a little protection at the
ATmega ports.
Extra causion is required if you try to test components mounted in a circuit. In either case the
equipment should be disconnected from power source and you should be sure, that no residual
voltage remains in the equipment.
Chapter 2
Hardware
2.1
The circuit of the TransistorTester in figure 2.1 is based on the circuit of Markus F. released in Abb. 1
of AVR-Transistortester report [1]. Changed or moved parts are marked with green color, optional
parts are marked with red color.
Some changes are made because the electronical power switch make problems in some implementations. Therefore the resistor R7 is reduced to 3.3k. The capacitor C2 is reduced to 10 nF and
R8 is moved so that the PD6 output does not try to switch the C2 capacitor directly. Additional
blocking capacitors are added and should be placed near the power connection of the Atmega and
near the Voltage regulator.
Because the PD7 input and PC6 (RESET) are the only pins, where pull up resistors where needed,
one extra 27k resistor is added to the PD7 (pin 13) input. With this modification the software can
disable all internal pull up resistors of the ATmega.
The additional crystal with its 22pF capacitors are optional added. The accuracy of a crystal
has the benefit of more stable time measurement for getting the capacitor values.
New software version can use a voltage scale switch of the ADC. The speed of switching is
reduced by the external capacitor C1 at the AREF (21) pin of the ATmega. To avoid slowing down
the measurement speed more than necessary, the value of this capacitor should be reduced to 1nF.
Removing of the capacitor C1 is also possible. For adapting the software to the actual circuit take
a look to the Makefile options in the configuring chapter 4 at page 47.
Some different versions of R11 / R12 resistor combinations circulates in the internet. I have
adapted my software to the original of Markus F. [1] with 10k and 3.3k. The voltage ration of
the divider can be set with Makefile options.
The additional 2.5V precision voltage reference connected at pin PC4 (ADC4) can be used to
check and calibrate the VCC voltage, but is not required. You can use a LM4040-AIZ2.5 (0.1%), a
LT1004CZ-2.5 (0.8%) or a LM336-Z2.5 (0.8%) as voltage reference. If you dont install the precision
voltage reference and you dont add the relay extension, you should install a pull up resistor R16 to
PC4 with a higher resistance value (47k). This helps the software to detect the missing voltage
reference. A optional ISP connector has been added to easier load new software versions to the tester.
VCC
Ubat
VCC
R10
22p
C12
33k
T3
BC557C
3k3
R7
LED1
IC2
PB2(OC1B)
PB3(MOSI/OC2)
PB7(XTAL2/TOSC2)
PB4(MISO)
27k
BC547
Test
VCC
R8
C6
100n
BC547
C2
10n
R9
T1
IN
OUT
GND
PB5(SCK)
PD0(RXD)
PD1(TXD)
VCC
100k
10u 100n
PB1(OC1A)
R15
T2
C5
PB0(ICP)
PB6(XTAL1/TOSC1)
8MHz
10
PD2(INT0)
VCC
C4
100n
8
10k
2k2
R16
PD3(INT1)
PD4(XCK/T0)
PD5(T1)
GND
PD6(AIN0)
27k
PD7(AIN1)
ISP
VCC
16
17
10k
18
19
1
2
2
3
10k
VCC
SCK
MOSI
Reset
7
8
11
12
9
10
11
13
6
RESET
12
13
14
R14
3
4
5
6
2
MISO
R6
15
VCC
470k
14
VCC
Button
680
2.5V
R4
R12
3k3
22p
Ubat
C9
AGND
LT1004
33270
15
GND
+5V
VEE
RS
R/W
E
D0
D1
D2
D3
LCD 2x16
C11
D1
PC5(ADC5/SCL)
28
470k
22
27
R5
C1 1n
26
680
PC4(ADC4/SDA)
R2
AREF
25
470k
21
TP1
TP2
TP3
24
R3
AVCC
100n
23
R1
9V
20
PC0(ADC0)
PC1(ADC1)
PC2(ADC2)
PC3(ADC3)
PC6(RESET)
680
C3
serial
ATmega8/168/328
1
R11
10u
10k
C10
R13
Reset
D4
D5
D6
D7
16
GND
Port
PD0
PD1
PD2
PD3
PD4
Character
LCD
LCD-D4
LCD-D5
LCD-D6
LCD-D7
LCD-RS
ST7565 LCD
SPI
LCD-REST
LCD-RS
LCD-SCLK
LCD-SI
ST7920 LCD
serial
LCD-REST
PD5
PD7
LCD-E
pushbutton
(LCD-CE)
pushbutton
LCD-EN
pushbutton
LCD-B0
ST7108 LCD
SSD1306
additional function
2
serial
IC
595-PCLK
LCD-CS2
rotary encoder 2
164-595-CLK LCD-SDA
LCD-CS1
rotary encoder 1
LCD-RS
frequency counter
164-595-SER
LCD-EN
LCDSCL
pushbutton pushbutton
10
Port
PD0
PD1
PD2
PD3
PD4
PD5
PD7
ST7565 LCD
STRIP GRID
additional function
LCD-A0 (RS)
LCD-REST
LCD-SCLK
LCD-SI
rotary encoder 2
rotary encoder 1
frequency counter
pushbutton
2.2
2.2.1
For better protection of the ATmega inputs one of the additional circuits 2.2 can be integrated. The
de-energized contacts of the relay protect the ATmega without power. The contacts will be opened by
software only for measurement. Also with the additional diode protection the chance of the ATmega
will be better to survive the connection of a capacitor with higher residual voltage. A complete
protection is not possible. Therefore capacitors should always be discharged before measuring.
BC547
TP1
TP2
TP3
VCC
or Ubat
depending of relay type
4k7
PC4(ADC4/SDA)
VCC
P6KE6V8A
PC0(ADC0)
PC1(ADC1)
PC2(ADC2)
TP1
TP2
TP3
100nF
2
SRV054
11
VCC
or Ubat
depending of relay type
4k7
BC547
PC4(ADC4/SDA)
TP1
PC0(ADC0)
PC1(ADC1)
TP2
PC2(ADC2)
TP3
3x10
2.2.2
If the serial output of text is not required, the Pin PC3 of the ATmega can be used as analog input for
measuring a external voltage. The voltage can be up to 50V with the optional 10:1 resistor divider
and can be used for measuring the breakdown voltage of a zener diode. A current limiting power
supply with up to 50V can be switched on with low signal at PD7 pin of the ATmega to deliver
current for testing the break down voltage of a zener diode. Figure 2.4 shows a suggestion for this
expansion. The tester shows the external voltage as long as you hold the key pressed. About 40mA
more battery current is used by this expansion during key pressing.
Vout15
serial / PC3
33uH
IRFU9024
C13 1uF
Vin
TMA0515D
20k
10n
T4
C16
Ubat
50u
Com
Vin+
DCDC Conv.
IN
OUT
GND
C17
R17
L1
Vout+15
C15
100n
R19
IC3
MCP1702
Uext
10k
180k
R18
Uext
C14
100n
Button
External
Voltage
Figure 2.4. Expansion for measuring of break down voltage of Zener diodes
The 10:1 voltage divider can be used with the optional dialog part for the ATmega328 without
the activated DC-DC converter for the zener diode measurement. Without the pressed key the
voltage converter is not powered. For that the external voltage (for example battery voltage) can be
measured at the zener diode port. You can only measure positiv DC voltages up to 50V . You have
also to respect the correct polarity.
12
2.2.3
Frequency generator
With the dialog part of the ATmega you can also select a frequency generator, which supports
currently a selection of frequencies from 1Hz up to 2M Hz. The output of the 5V signal is done
with a 680 resistor to test port TP2. You can use the GND signal from the minus pin of the zener
diode extension or the test port TP1. The test port TP3 is connected to GND with a 680 resistor.
Of course you can also connect a driver circuit to the ATmega port PB2 with a separate output
driver circuit and a additional output terminal. But the input of this circuit should not insert a big
capacity load for the ATmega output.
2.2.4
Frequency measurement
For using the with the dialog selectable frequency measurement is a little hardware extension necessary. The input pin PD4 (T0/PCINT20) of the ATmega is used for the frequency measurement. The
same pin is also used for the connection of the LCD. With normal layout, the PD4 pin is connected
to the LCD-RS signal, with the strip grid design it is connected to LCD-D4. For both signals the
PD4 pin can be switched to input as long as no output to the LCD is required. The LCD respect the
input value only, if the LCD-E signal is switched to GND. For driving the input pin from external
clock source at least one serial resistor of 270 should be used. Better you should use the circuit of
figure 2.5 . The voltage at the PD4 pin (LCD-RS or LCD-D4) should be adjusted to 2.4V without
the assembled ATmega or during frequency measurement of the ATmega, to get the best sensivity
for the input frequency signal. The LCD should always be installed for adjusting, because the pull
up resistor of the LCD change the voltage.
VCC
10k
10k
470
PD4
TP4
10k
100nF
2.2.5
For easier control of the menu function for the ATmega328 you can expand the circuit by a rotary
pulse encoder with a push button. The circuit 2.6 shows a standard expansion for a normal character
LCD. All signals for the connection of the rotary pulse encoder are available at the plug connector
for the LCD. For this reason the expansion can also be easy upgraded for many existing testers. In
many cases the graphical LCD is assembled on a adapter board with some connection pins of the
character LCD. Also in this cases the upgrade with a rotary encoder is not very difficult to do.
13
PD3
1k
PD1
1k
VCC
10k
VCC
10k
Test Key
Switch A
L
H
Switch B
L
detent
State: 2
detent
2
detent
2
Version 2
Switch A
L
H
Switch B
L
detent
State: 2
detent
1
detent
2
detent
1
detent
2
detent
1
Version 1
Figure 2.7. Feature of two different rotary pulse encoder
14
The figure 2.8 shows a rotary pulse encoder, which has not only bouncing contacts, but also has
a unstable state of one of the switches at the indexed position (detent). Every change of the state
of the switches is detected by the program and saved in a cyclic buffer. Therefore the last three
states of the switches can be checked after every status change. For every cycle of switch states a
total of four sequences of state can be defined for every direction of rotation. If there is only one
indexed position (detent) for every cycle of switch states, only one of the state sequence pair must
be monitored (WITH ROTARY SWITCH=2 or 3) for correct counting. If there are two indexed
positions for every cycle of the switch states, as shown in figure 2.8, you must monitor two pairs
of switch state sequences (WITH ROTARY SWITCH=1). You can choise any resolution for the
WITH ROTARY SWITCH for a rotary pulse encoder without indexed positions. A value of 2 or
3 selects the lowest resolution, 1 selects a middle resolution and 5 selects the highest resulution. A
oscillation of the selection (counter up, counter down) can be avoided with the type of monitoring,
but sometimes a count can be missed with a bad placement of the indexed position.
H
Switch A
L
H
Switch B
detent 1
State:
detent 2
2
detent 3
1
2020
2
023 = 
320 = +
3232
3
231 = 
132 = +
1313
0101
310 = 
013 = +
2020
102 = 
201 = +
2.2.6
Many thanks to Wolfgang Sch. for his work to support a chinese version with ST7565 controller.
By now you can also connect a graphical 128x64 pixel LCD with a ST7565 controller. Because the
ST7565 controller is connected with a serial interface, only four signal lines are required. Two port
D pins of the ATmega can be used otherwise. The ATmega processor should have at least 32k flash
memory for the support of a graphical display. The ST7565 controller works with a operating voltage
of 3.3V . Therefore a additional 3.3V voltage regulator is required. The data sheet of the ST7565
controller does not allow the direct connection of input pins to 5V signal level. So the extension of
figure 2.9 uses a additional 74HC4050 CMOS device for the conversion of the voltage level. You can
try to exchange the four 74HC4050 gates with four resistors of about 2.7k. With the voltage drop
at the resistors you will prevent the increase of the 3.3V controller power voltage across the diodes of
the controller inputs from the 5V ATmega outputs signals. You have to try, if the signal form with
the resistors can be accepted from the ST7565 controller inputs. The signal form at the controller
inputs will be more simular to the output shape of the ATmega with the 74HC4050 gates in any case.
15
30
29
28
4050
PD0
PD1
RES
RS
27
26
25
24
23
22
21
20
PD5
10
PD3
PD2
11
SI
SCLK
14
19
18
17
16
12
15
Vdd
Vss
LCD
/CS
/RES
IRS
P/S
A0
C86
VR
VO
V4
V3
R/W_WR
/RD_E
DB0
DB1
DB2
DB3
DB4
DB5
DB6_SCL
V2
V1
CAP2+
CAP2
CAP1+
DB7_SI
VDD
VSS
CAP1
CAP3+
VOUT
1
2
3
4
5
6
7
8
1u
1u
1u
1u
10
11
1u
1u
12
13
14
15
1u
1u
1u
ERC128642
MCP17023.3
IN
VCC
10?
100n
GND
OUT
GND
100n
10u
100n
100n
Background
LED
16
VCC
GND
VCC
10u
68
GND
3.9k
68
LDO
IN
VCC
OUT
GND
10u
3.9k
100nF
SCL
3V3
GND
100nF
3.9k
PD5
SCL
PD5
SDA
PD2
SDA
3.9k
PD2
GND
MCP17023302
VEE
PD2
PD5
VCC
VSS
VDD
VO
RS
R/W
E
DB0
DB1
BB2
DB3
DB4
DB5
DB6
DB7
PSB
GND
VCC
VEE
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
GND
VCC
PD4
GND
PD5
PD0
PD1
PD2
PD3
NC
RST
VOUT
BLA
BLK
VCC
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
VSS
VDD
VO
RS
R/W
E
DB0
DB1
BB2
DB3
DB4
DB5
DB6
DB7
PSB
For connection to the ATmega644 series of processors the pins PB2 to PB5 instead of PD0 to
PD3 are used. The exchange of a text display to a graphical display is possible with a adapter printed
board because all required data signals and power signals are available at the LCD connector. A
little simpler is the connection of a graphical display with a ST7920 controller because the controller
can operate with 5V power voltage. For that the display should offer 128x64 visible pixels. The
display module with the ST7920 controller can be connected with the 4-bit parallel interface or with
a special serial interface., as shown in figure 2.11.
NC
RST
VOUT
BLA
BLK
serial mode
PD5
74HC164
VCC
10k
9
8
PD2
1
2
PD4
CLR
CLK
3
A
QA
QB
QC
QD
PD3
QE
QF
QG
PD1
QH
VCC
14
VCC GND
4
5
6
10
11
12
13
VCC
10k
100nF
100nF
25k
GND
VSS
VDD
VO
RS
R/W
E
DB0
DB1
DB2
DB3
DB4
DB5
DB6
DB7
CS1
CS2
/RST
VOUT
BLA
BLK
VCC
VCC
VEE
PD5
VCC
74HC595
10k
PD0
13
12
10
PD2
G
RCK
SRCLR
SRCK
11
QA
14
PD4
SER
QB
QC
QD
QE
PD3
QF
QG
PD1
QH
QH
VCC
16
VCC
GND
15
1
2
3
4
5
6
7
9
8
VCC
10k
100nF
100nF
25k
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
VSS
VDD
VO
RS
R/W
E
DB0
DB1
DB2
DB3
DB4
DB5
DB6
DB7
CS1
CS2
/RST
VOUT
BLA
BLK
LM12864 (ST7108)
VEE
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
VCC
VCC
LM12864 (ST7108)
GND
1
2
3
4-7
8-11
12
13
14
15
16
17
18
19
20
2
1
3
7-10
11-14
15
16
17
5
4
7
18
19
20
4
3
(5)
9-12
13-16
1
2
7
6
8
17
18
2
1
3
7-10
11-14
15
16
17
5
4
6
18
(19)
-
Port
PD0
PD1
PD2
PD3
PD4
PD5
PCF8814
PCF8814
SPI
3-line
LCD-RESet LCD-RESset
LCD-D/C
LCD-SCE
LCD-SCLK LCD-SCLK
LCD-SDIN
LCD-SDIN
LCD-EN
PCF8814
I2 C
additional function
rotary encoder 2
LCD-SDIN
rotary encoder 1
frequency counter
LCD-SCLK
Table 2.4. Pin assignments for different interface types of the PCF8814 controller
Some code for supporting a PCF8812 controller with 102x65 pixels is also implemented, but not
yet tested.
2.2.7
Some Chinese salesmen offer cheap color display modules with a SPI interface. The picture 2.13
shows the backsides of two supported modules with 128x128 pixel and 128x160 pixel. The moduls
are very small, so the shown text and symbols are very little. But the appearance is sharp and clear.
you can evel show 10 lines of text. At the picture 2.14 you can see the result of the measurement of
a Germanium transistor at a 128x128 pixel display.
2.3
Every LCD-display with at least 2x16 character and a HD44780 compatible controller can be used
with the TransistorTester. You should respect the current needed for illumination, some LCD need
lower current than others. I had tried OLED type displays, but this type cause interference with
measurements of the ATmega and are not recommended. Also loading of special characters for
displaying the resistor symbol has caused problems with the OLED.
The resistors R1 to R6 are critical for measurements and this 680 and 470k resistors should be
measurement type resistors (tolerance of 0.1%) to get the full accuracy. You should use a precision
socket for the ATmega microcontroller to enable the replacement of the microcontroller. The microcontroller ATmega8, ATmega168 and ATmega328 can be used. Recommended is a ATmega328, if
you wish to use all features.
Anyway you should assemble all parts to printed board without the microcontroller. A up-to-date
low voltage drop regulator like MCP1702-5002 is recommended as IC2, because it need only 2A of
standby current and can still deliver 5V , if your input voltage is only 5.4V . But this part is not pin
compatible to well known 78L05 with TO92 body!
After checking, that all needed parts are at the correct place, you should first connect the battery
or power supply to the printed board without LCD-display and microcontroller. You should check
the voltage at the power pins of the microcontroller and LCD-display terminal during the Test key is
pressed. The voltage should disappear, if you release the Test key. If the voltage had correct polarity
and value, you should disconnect the power and assemble the microcontroller with correct alignment.
Be careful and make sure, that all pins of the microcontroller are in the socket holes. Now you can
20
also connect the LCD. Check if power pins of the LCD has the right connection to GND and VCC
of your board.
If you are sure that everything is all right, reconnect the power. If you have already programmed
the ATmega, you can press the Test button. By pressing the Test key, the background light of the
LCD should switch on. If you release the Test button, the LED should illuminate weak. Notice, that
the software for the microcontroller must be compiled for the correct processor type. A program for
the ATmega8 does not run on a ATmega168!
2.4
Voltage control If the problem exist, the tester will shut down immediately with every switch on.
With imy suggested setting of the fuses (Makefile) the voltage control of the different ATmega
versions is switched to 4V (brown out level). This may be the reason why the tester makes
trouble with the power on sequence. The Pin PD6 tries to switch the 100nF capacitor C2
to VCC level causing a voltage breakdown of the VCC voltage (5V ). The capacitor C2 can
be reduced to < 10nF without problems. If possible, the direct connection of PD6 should be
replaced by a resistor > 220.
Improvement of power on circuit Often this problem is the reason, if the tester starts with the
button hold pressed, but switch off directly by releasing. The problem is enforced by a high
current background light for the LCD. The resistor R7 to the base of the PNP transistor T3 was
optimized with the value 27k too much to save power consuming. To improve the switching
with lower battery voltage or lower current amplification factor of the PNP transistor T3, you
should reduce the resistance to 3.3k.
Additional pull-up resistor at PD7 The missing pull-up resistor results to a switch off of the
tester with the message Timeout after a short display time. The software is configured with
the option PULLUP DISABLE, that all internal pull-up resistors are switched off. For that
reason the voltage of pin PD7 is not definded, if the level is not switched by the push button
or transistor T2 to GND. One external pull-up resistor of 27k to VCC avoid this error.
Capacitor C1 at the AREF pin Many designs use a 100nF capacitor at the AREF pin, like the
design of Markus F. too. As long as the reference voltage of the ADC is never changed, this is a
good solution. The software of the TransistorTester for the ATmega168/328 uses a automatic
selection of the internal 1.1V reference voltage of the ADC, if the input voltage is below 1V .
With this solution a better resolution of the ADC can be reached for little input voltages.
Unfortunately the switching from 5V to 1.1V reference is very slowly. A additional wait time
of 10ms must be respected for this reason. With changing the capacity value to 1nF this wait
time can be reduced significant. I have not noticed any degration of measurement quality with
this change. Even a removing of the capacitor has no significant change of measurement results.
If you prefer to leve the capacitor unchanged, you can remove the option NO AREF CAP in
the Makefile to activate longer wait times in the program.
Expanding of a 8M Hz crystal With some skill you can expand a 8M Hz crystal to the backside
of the printed board directly to the pins PB6 and PB7 (pin 9 and pin 10). My own expansion
was done without the both 22pF capacitors. This solution has operated well with all tested
ATmega. But it is not required to use a crystal. You can still use the 8M Hz RC oszillator
by setting the fuses to get the better resolution of time constant for measuring the capacity
values.
Smoothing of the operating voltage The original circuit of Markus F. shows only one 100nF
capacitor to block the VCC voltage. This is clearly too little smoothing. You should at least
21
use one 100nF near the ATmega power pins and one near the voltage regulator. The input
of the voltage regulator should be blocked with a 100nF too. Additional 10F capacitors
(electrolytic or ceramic) at the input and output of the voltage regulator can stable the voltage
level. Ceramic 10F capacitos with SMD mounting form are easier to use for backfitting and
have usually a lower ESR value.
Selection of the ATmega processor The using of the base function of the tester is still possible
with a ATmega8. The flash memory of that device is used near 100%. Because the ATmega168 or ATmeg328 processors are pin-compatible to the ATmega8, I can recommend the
replacement. Actually the price for ATmega328 is so cheap, that there is no reason to take
a ATmega168 type. With a ATmega168/328 you get the following advantages: Self test with
automatic calibration.
Improvement of measurement quality by automatic switching of ADC scale.
Measurement of inductors with resistance below 2100.
Measurement of ESR value of capacitors with value of above 90nF .
The resolution of resistor measurement below 10 is 0.01.
Using of pin PC4 as serial output.
Missing precision voltage reference Usually the software should detect the missing voltage reference with the unconnected pin PC4. In this case no VCC=x.xV message should appear in
row 2 of the LCD on power on. If this message appear without the reference, you should
connect a 2.2k resistor to the PC4 input and VCC.
2.5
As I know, the tester is rebuild in China in two versions with character displays. The first model is
rebuild from the first design of Markus F. without the ISP port. The assembled ATmega8 is placed
in a socket, so you can replace it with a ATmega168 or ATmega328. For this version you should
consider all the hints of section 2.4. Additional 100nF ceramic cpacitors should be connected near
by the VCC-GND and AVCC-GND pins of the ATmega for better stabilization of the power voltage.
Because there is no ISP connector at the board, you must expand the board with a ISP connector
or you must plug the ATmega to a external socket for programming. In addition you should notice,
that if your ATmega should run with a 8M Hz crystal, your external ISP programmer must have a
external clock for programming or a crystal mounted at the socket.
The second version of rebuilded tester is build with SMD components. Also the fix installed
ATmega168 is a SMD type with 32TQFP body. Fortunately on the board is a 10-pole ISP connector
provided for the programming. I have analysed the board version 2.1 2012/11/06. One error is
the assembly of the part D1, which should be a precision 2.5V voltage reference. Assembled is
only a zener diode. This part should be removed. You can mount a LM4040AIZ2.5 or LT1004CZ-2.5
precision voltage reference at this place. A missing voltage reference is noticed by the software, so
that you must not install the voltage reference. My exemplar was delivered with software version
1.02k. The 10-pole ISP plug was not assembled and I must install a jumper from ISP pin 6 to ISP pin
10. My programmer expect a GND connection at pin 10, but the board has GND level only on pin
4 and pin 6 of the ISP. The label of the ATmega168 was rub away and there was no documentation
delivered with the part. The lock fuses of the ATmega were set, so no readout was possible. But
I could install the software version 1.05k without any problems. Another user has problems with
the same software version 1.05k. This user has the chinese board 2.2 2012/11/26. The software
runs only without problems, if a additional 100nF keramic capacitor was placed between the pin
22
18-AVCC and 21-GND near by the ATmega. The software 1.05k uses the sleep state of the ATmega
for waiting time. For this reason the current alternates often and the voltage regulator is stressed
more. Further I have noticed, that the VCC voltage is blocked with a 100nF ceramic capacitor and
with a 220F electrolytic capacitor nearby the 78L05 voltage regulator. The 9V supply voltage is
blocked with the same capacitors, but not at the input of the regulator but at the emitter of the
PNP transistor (parallel with the battery). The printed circuit board track from the ATmega168 to
the test port is very thin, so that a resistance of 100m could be measured for one path. This will be
the reason for measuring a resistance of 0.3 for two direct connected pins. The ESR measuring can
usually consider this by zero compensation. Beginning with version 1.07k the software does respect
this offset for measuring resistors below 10 too.
2.6
Newer rebuilds of the tester like a version from Fish8840 use a 128x64 pixel graphical display. This
version use a modified circuit for the switch on logic. The figure 2.15 shows a part of the modified
circuit.
47k
47k
R17
VCC
INP
OUT
GND
27k
R18
100k
C24
Q2
R20
TEST
Q1
D5
47k
D6
Reset
R15
27k
PC5
PD7 ADC5
R8
PC6
OFF
+9V
VCC
R9
10k
R7
VCC
PD6
23
Reset signal (PD0) is required. Because the data signals are never switched to VCC directly, the
3.3V power of the LCD controller can not be elevated. My version of the Fish8840 tester has all
signals for connecting a character display routed to the LCD plug connector. Therefore you can
prepare the board for connection of a character display, if the female header is completed and the
potentiometer for the contrast level is added. However the supply pin 15 for the background light is
connected directly to the VCC level. If you install a character display, you should check, that your display module is equipped with a serial resistor for the background LED. Of course iyou have to adapt
the software for different displays. Also the hardware extension are possible with the Fish8840 board.
All attempt to replace the original software is allways done at ones own risk. No guaranty can
be given for operational capability of newer software versions. Unfortunately the original state of
the chinese software can not be saved because the security bits of the ATmega328 are set. So there
is no way to get back to the original state.
A additional version with graphical display is the WEI M8 printed board, which is shown in
picture 2.18. This build use a LiIon accumulator with AA (mignon) size as power supply, which can
be loaded with the micro USB plug. Operating is also possible without the accumulator, only with
the USB power.
25
picture of figure 2.21 you can see in the right upper corner the ISP male connector with correct
orientation beside the six holes of the board. For programming the ATmega I have not soldered the
male connectorr. I have only pugged it into the holes instead and have fixed it with a finger during
the programming. With that procedure the male connector can be easy removed an the display can
be mounted again to its origin place. The chinese software could be replaced with the 1.12k without
any noticeable problem. Also the activating of the brown-out monitor by setting the extended fuse
has not shown any surprice.
(a) completely
this version the graphical display is connected with a adapter circuit board to the 16-pol female
connector. The port PD5 of the ATmega is connected via pin 6 of the female connector to the CE
(Chip Enable) input of the graphical controller. The signal CE is also conneted at the adapter board
to the 0V power (GND). This will resulte to a short-circuit if the ATmega will switch the PD5
output to 5V . But newer versions of the software also switch the CE signal, even if the signal is not
necessary for correct operation. For correct operation of the GM328 tester with newer software
versions you should cut the connection of the CE signal to pin 6 of the male connector.
2.7
Two different kit versions with graphical display and rotary encoder are known until now. The first
released kit use a display with a ST7565 or compatible controller (128x64 pixels). In addition to
the rotary encoder a additional input for frequency measurement is provided. For the test ports a
14-pin Textool socket, three soldering pads for cables and a testpad for SMD parts are provided at
the main board. The pictures 2.23 shows the mounted kid. One of the both 22pF capacitors was
replaced with a trimmer at the soldering side. With a trimmer the frequency of the crystal can be
adjusted for better accuracy of frequency measurement and frequency generation.
28
2.8
A extended circuit for ATmega644/1284 processors was developed with Nick L. from the Ukraine.
The circuit 2.26 enables a additional test of crystals and a extended range for the frequency measurement. Although the basic circuit is very simular to the circuit 2.1, the port assignment is different.
A rotary pulse encoder with circuit 2.6 can be connected here at the pins PB5 and PB7 (instead of
PD1 and PD3). Both signals and also the power signals VCC and GND are available at the ISP
connector, so that the extension can also be connected here.
The 16:1 frequency divider of the 74HC4060 is allways used for frequencies above 2M Hz. The
frequency divider can also be used for frequencies between 25kHz and 400kHz to upgrade the
frequency resolution by using the period measurement. For switching between the operational states
(frequency divider and crystal oszillator) the analog switches 74HC4052 are used. The table 2.5 shows
the pin assignments for the ATmega324/644/1284 microcontrollers for different display connections.
The using of the I2 C interface is only possible with the SSD1306 controller. The signals of the I2 C
interface require a pull-up resistor of 4.7k to 3.3V . The outputs of the ATmega is only switched to
29
Character LCD
Graphic LCD
SPI 4-wire
Graphic LCD
I2 C
PB2
PB3
PB4
PB5
LCD-RS
LCD-E
LCD-D4
LCD-D5
(LCD-CE)
LCD-REST
LCD-RS
LCD-SCL
LCD-SDA
PB6
PB7
LCD-D6
LCD-D7
LCD-SCLK
LCD-SI
additional function
ISP-MOSI
Rotary encoder 2
ISP-MISO
ISP-SCK
Rotary encoder 1
VCC
from ATmega ports
VEE
PB3
74164
VCC
10k
9
8
PB6
1
2
PB2
CLR
CLK
3
A
QA
QB
QC
QD
PB7
QE
QF
QG
PB5
QH
VCC
14
VCC GND
4
5
6
10
11
12
13
VCC
10k
100nF
100nF
25k
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
GND
VSS
VDD
VO
RS
R/W
E
DB0
DB1
DB2
DB3
DB4
DB5
DB6
DB7
CS1
CS2
/RST
VOUT
BLA
BLK
VCC
VCC
VEE
from ATmega644 ports
VCC
LM12864 (ST7108)
GND
PB3
VCC
74LS595
10k
PB4
13
12
10
PB6
11
G
RCK
SRCLR
SRCK
QA
14
PB2
SER
QB
QC
QD
QE
PB7
QF
QG
PB5
QH
QH
VCC
16
VCC
GND
15
1
2
3
4
5
6
7
9
8
VCC
10k
100nF
100nF
25k
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
VSS
VDD
VO
RS
R/W
E
DB0
DB1
DB2
DB3
DB4
DB5
DB6
DB7
CS1
CS2
/RST
VOUT
BLA
BLK
LM12864 (ST7108)
You can also connect a display with the ST7108 controller ito the ATmega644 of ATmega1284 by
using a little circuit as shown in figure 2.25. You should also respect the different pin assignments
of display modules with ST7108 controllers as shown in table 2.3 at page 18.
31
PA5(ADC5)
C2
LT1004
36
R5
35
3k3
PA6(ADC6)
AGND
2.5V
C7
BC547
Test
MCP17025.0
IC2
PB0(PCINT8/XCK0/T0)
PB1(PCINT9/CLK0/T1)
100n
11
R20
10n
GND
PB2(PCINT10/INT2/AIN0)
LF
5
4
PC4(TD0/PCINT20)
10
PC5(TDI/PCINT21)
PC6(TOSC1/PCINT22)
9
12
IC3
13
VCC
PC7(TOSC2/PCINT23)
11
R10
9
10
11
22
VCC
13
24
14
R21
25
26
27
28
MISO
VCC
SCK
MOSI
D5
D6
D7
6
GND
Vss
Vdd
VEE
VCC
IC5
16
Vdd
C15
12
6
14
14
15
11
1
5
2
VCC
4
16
7
A
B
TP5
(Vext)
Vss
INH
X0
X1
X2
X3
13
X
Y0
Y1
Y2
5mA/1mA
3
JMP1
Y3
IC6
Vdd
VEE
Vss
T8
DCDC
5V
100u
4.7u
C31
2x15V 
1u
C33
C30
IN
OUT
GND
L1
33uH
100n
C29
100n
C28
8.2k
T7
IRLML5203
R40
MCP17025.0
IC7
47u
C22
T5
1k
T4
R27
4.7k
1k
100p
R26
R28
100k C34
1k
R22
R23
470
100
R24
15k
1N4148
D11
R25
VCC
Ubat
BC640
3x 1N4148
C16
BFT93
300
R37
100n
BFT93
R36
1.2k
VCC
VCC
100n
7
5
13
15
1
2
Q9
Q10
Q12
Q13
Q14
IC4
Y3
VCC
7
3
Y
10
9
39k
Y0
Y1
Y2
5
2
4
16
Q6
Q7
Q8
X3
100n
2.2n
D3
D4
R30
12p
Q4
Q5
13
X
C14
TP4
Frequency
D2
10k
12p
C20
D1
74HC4052
10
9
CLK O
CLKO
RESET
R41
C27
CLKI
16:1
R35
1M
C26
11
12
X0
X1
X2
14
15
11
1
33p
D0
74HC4060
A
B
INH
12
10u
R/W
E
74HC4052
10
9
6
C19
RS
100n
C21
VEE
VCC
Reset
C17
GND
+5V
ISP
29
RESET
HF
15
16
33270
Vss
Vdd
12
23
14
1
2
3
4
5
6
7
8
1u
620k
PC3(TMS/PCINT19)
R8
470k
C32
R34
C25
PC2(TCK/PCINT18)
360k
2M4
R31
R29
39p
PC0(SCL/PCINT16)
PC1(SDA/PCINT17)
680
6
7
8
PB7(PCINT15/OC3B/SCK)
Button
21
4
5
PB6(PCINT14/OC3A/MISO)
CD4011
R12
2
3
PB4(PCINT12/OC0B/SS)
PB5(PCINT13/ICP3/MOSI)
10k
20
PB3(PCINT11/OC0A/AIN1)
27k
100k
C13
C12 100n
VCC
C9
BC547
T3
R19
10u 100n
PD7(PCINT31/OC2A)
10
LED1
IN
OUT
GND
PD6(OC2B/ICP)
VCC
R13
10k
18
19
PD5(PCINT29/OC1A)
27k
VCC
17
PD4(PCINT28/OC1B)
R17
T2
C10
PD2(PCINT26/RXD1)
PD3(PCINT27/TXD1)
XTAL2
serial
16
R18
3k3
R16
Ubat
15
PD1(PCINT24/TXD0)
12
100n
14
PD0(RXD0/T3)
1030p
MPSA65
C11
XTAL1
8MHz
C8
33k
T1
13
22p
R14
470k
C6
D10
SS14
R6
PA7(ADC7)
C5 1n
37
R9
PA4(ADC4)
2k2
AREF
38
470k
PA3(ADC3)
TP5 (Vext)
TP1
TP2
TP3
R7
PA2(ADC2)
680
32
39
470k
PA1(ADC1)
AVCC
100n
180k
40
R11
30
PA0(ADC0)
20k
R1
RESET
1
R4
680
C4
9V
R3
ATmega644/1284
9
10k
R2
10u
10k
Reset
C3
5
VCC
10n
Ubat
VCC
100nF
P6KE6V8A
SRV054
1k
R32
300
R33
10k
D13
T6
D12
1N4148
BFR93A
1N4148
2.9
The basic circuit of the tester can also be also build with a Arduino Mega with a ATmega1280
or ATmega2560 microcontroller with a shield. The required connections are shown in figure 2.27.
The names for the connections of the display signals of the Arduino are shown with green color.
31
Components with red color identification are not required for operating. The ATmega2560 controller
has many connectors, but only one connector has the required functions for both techniques of the
frequency measurement. The connector must be used as clock input for a build in counter and must
also be used as interrupt source for change of signal level. This feature is only available for the pin
PE6 (T3/INT6). The other clock inputs of counters PD7 (T0), PD6 (T1), PH7 (T4) and PL2 (T5)
can not be used as interrupt source for status change. Unfortunately the PE6 pin is not connected
to a pin of the Arduino female connector strip. The PE5 pin (7) is connected to the connector 3 of
the PWM socket strip and can be jumpered with the PE6 pin (8) of the ATmega2560. The output
signal of the frequency generation is available at the PB6 (OC1B) pin. This pin is connected to the
connector 12 of the PWM socket strip. The ISP-connector is not required, because the program can
be loaded with the bootloader and the USB interface to the ATmega. With the bootloader there is
always a little delay for the power up start of the program.
VCC
Ubat
VCC
22p
XTAL1
16MHz
22p
11
PK0(ADC8/PCINT16)
PK1(ADC9/PCINT17)
PK3(ADC11/PCINT19)
PK4(ADC12/PCINT20)
VCC
PK5(ADC13/PCINT21)
GND
PA7(AD7)
27k
80
PA6(AD6)
VCC
PA5(AD5)
GND
PA4(AD4)
PA3(AD3)
PA2(AD2)
100n
81
PA1(AD1)
VCC
61
100n
62
31
100n
32
PA0(AD0)
VCC
PE5(OC3C/INT5)
GND
PE6(T3/INT6)
VCC
PB6(OC1B/PCINT6)
GND
PB2(MOSI)
PB3(MISO)
PB1(SCK)
470k
R6
680
470k
R4
R5
2.5V
3k3
XTAL2
10
100n
92
GND
PK2(ADC10/PCINT18)
33
Test
PF5(ADC5)
LT1004
93
89
88
87
86
85
84
VCC
10k
1
71
72
73
74
75
JP129
Button
10k
3
4
JP127
JP126
JP125
76
JP124
77
JP123
78
JP122
7
8
9
10
7
8
25
21
PWM3
Input
11
Frequency
PWM12
Output
12
13
14
15
+5V
VEE
RS
R/W
E
D0
D1
D2
D3
D4
D5
D6
D7
16
22
20
33270
ISP
Button
GND
34
PF4(ADC4)
94
470k
AREF
95
680
PF3(ADC3)
1n
99
PF2(ADC2)
TP1
TP2
TP3
96
R2
AVCC
97
R3
PF1(ADC1)
100n
98
PF0(ADC0)
R1
100
RESET
680
30
serial
VCC
ATmega1280/2560
2k2
10k
10u
10k
Reset
VCC
2
MISO
VCC
SCK
MOSI
6
RESET
GND
32
Port
PA0
PA1
PA2
PA3
PA4
PA5
PA7
Character
ST7565
ST7920
ST7108
SSD1306 additional function
LCD
SPI
seriell
seriell
I2 C
LCD-D4 LCD-REST LCD-RESET HC595-RCK
LCD-D5
LCD-RS
LCD-CS2
rotary encoder 2
LCD-D6 LCD-SCLK
HC164-CLK
LCD-D7
LCD-SI
LCD-CS1
rotary encoder 1
LCD-RS
LCD-B0
LCD-RS
LCD-SDA
HC164-SER
LCD-E
(LCD-CE)
LCD-EN
LCD-EN
LCDSCL
key signal
Table 2.6. Connections for different display to the ATmega1280/2560 processors
2.10
I release the software for the microcontroller with source code. The developement is done with Linux
operationg system (Ubuntu) and is controlled with a Makefile. The Makefile makes sure, that your
software will be compiled with the prior selected Makefile options. Some constellations are precompiled with the source. Please take a look to the ReadMe.txt file in the directory Software/default and
to the chapter 4 at page 47. The result of compilation have the extensions .hex and .eep . Usually
the names will be TransistorTester.hex and TransistorTester.eep . The .hex file contains the data
for the program memory (flash) of the ATmega processor. The .eep file contains the data for the
EEprom memory of the ATmega. Both data files must be loaded to the correct memory.
Additionally the operating state of the ATmega processor must be programmed with the fuses.
If you can use my Makefile and additionally the program avrdude [12], you need no exact knowledge
of the details about the fuses. You have only to type make fuses if you have no crystal or make
fuses-crystal if you have installed the 8M Hz crystal to your printed board. With the ATmega168
series of the microcontroller you can also use make fuses-crystal-lp to use a crytal with the low
power mode. Never choose the crystal mode of clock generation, if you dont have installed the
8M Hz crystal. If you are not sure with the fuses, leave them as default set by manufactor and
first bring the the tester to operation in this mode. Maybe your program runs too slow, if you use
program data compiled for 8M Hz operation, but you can correct this later! But a wrong set of fuses
may inhibit later ISP-programming.
2.10.1
You can install packages with Debian based Linux versions by using a package manager as synaptic or
dpkg. The package subversion must be installed for downloading the sources or the documentation
from the SVN archive. With the command
svn checkout svn://www.mikrocontroller.net/transistortester
you can download the complete archive. Of course you can also download only subdirectories of
the archive. For using the Makefile in one of the subdirectories you must install the packages make,
binutils-avr, avrdude, avr-libc and gcc-avr. Once you must prepare the access to the interfaces for
the user. If you open a consol window and you have also connected a ISP programmer with USB
interface, you can see the recognized USB devices with the command lsusb. A sample of the result
of lsusb you can see here:
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Bus 002 Device 003: ID 046d:c050 Logitech, Inc. RX 250 Optical Mouse
33
Bus 002 Device 058: ID 03eb:2104 Atmel Corp. AVR ISP mkII
Bus 002 Device 059: ID 2341:0042 Arduino SA Mega 2560 R3 (CDC ACM)
Bus 002 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
A Device 58 is detected here a a AVR ISP mkII type (DIAMEX ALL-AVR). The ID 03eb is a vendor
ID and the ID 2104 is a product ID. Both IDs are required for a entry in the file /etc/udev/rules.d/90atmel.rules . In this example the file 90-atmel.rules has one line:
SUBSYSTEM=="usb", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2104", MODE="0660",
GROUP="plugdev"
This entry allow the access to the USB device 58 for members of the group plugdev. The also
detected USB device 59 allows a access to the serial device /dev/ttyACM0 for members of the
group dialout.
Therefore your user identification should be a member of the group plugdev and also a member
of the group dialout. With the command usermod -a -G dialout,plugdev $USER the membership
of both groups should be established. Now the program avrdude should have permission to access
both devices. In a console window you must first change the directory with the command cd to
a proper subdirectory of the directory trunk. Now you can change options of the Makefile with any
text editor. For compiling the source you must only type the simple command make. If the ISP
programmer is configured proper in the Makefile, a command make upload should result to load
the program with the ISP interface to the ATmega. The fuses of the ATmega must also be set
correctly once. You can achieve this with the command make fuses or make fuses-crystal. The
program avrdude probably reports a error for setting the extended fuse efuse. The reading of unused
fuse bits is specified as 1 for the ATmega, but the avrdude program mask the unused bits, so that
it expect a 0 for all unused bits. Normally the efuse should be set to 0xfc, but avrdude read back
0x04 with the mask. You can change the file avrdude.conf to change the behaviour of avrdude or
you can set the efuse to 0x04. The value for all efuses can be set with the identifier EFUSE VAL at
the begin of file setup.mk in the trunk directory. Probably the fuses are also set correctly with the
error message.
2.10.2
If you use the Windows operating system, the easiest way to get a correct programmed ATmega is
to use the WinAVR package [16],[17]. With my patch [18] you can also set the fuses by using the
Makefile. Of course the avrdude program must support your programmer and the configuration in
the Makefile must match to your environment.
The figures 2.28 show the File menu of the graphical user interface of WinAVR for open the file
Makefile and for saving the changed Makefile (Save).
34
35
2.11
Troubleshooting
In most cases of problems you will miss the text output to the LCD-display. At first you should
check, if the LED was illuminated weak, if you release the Test button.
Power does not switch on. If the LED is without light and the VCC power has correct 5V voltage
during holding the Test button, the microcontroller does not switch the power correctly. The
microcontroller should hold the power by switching the PD6 output to 5V , which is usually
done as one of the first actions. If you hold the Test key pressed, the power is switched on
anyway. So you can check the value of VCC power and additionally the voltage value of the
PD6 output, if you hold the key pressed. If VCC voltage has correct value (5V ), but PD6
voltage is below 4V , your microcontroller does not start the program. In this case you should
check if the microcontroller flash has been loaded with proper data for your installed type and
if ATmega is correctly configured with the fuses. If your ATmega put the PD6 output to 5V
and the power does not stay if you release the Test key, it is more difficult to find the reason.
First you can shorten the LED and try again. If your Tester now starts, your LED may be
faulty or mounted with wrong polarity. If this is not the reason, the current amplification factor
of your T3 transistor (BC557C) is insufficient. The current to the base of T3 is lower in the
microcontroller state as in the key pressed state.
Nothing is readable on the LCD display Check the voltage at the contrast pin at the LCD
display (pin 3). Adjust to correct value specified in the data sheet of your display and optimize
by viewing. If you have a high temperature display type, you must provide a negative contrast
voltage for operation. In this case you can use the ICL 7660 device for generating a negative
voltage from positive 5V .
The tester software can be configured for many different controller with different connection
types. You should check, if your software matches to your mounted display type. If there is
no output readable on the LCD and the background light is on, you should disconnect the
power and check all four data plus the two control signal connections. If all connection are
well, the only reason I see is a uncorrect timing of control signals. This can be caused by a
slower LCD controller than expected by the software or the ATmega software runs at wrong
clock speed. Please check for which clock speed your programming data was compiled and if
the fuses of the ATmega are correct set to that speed. You find the clock parameter in the
corresponding Makefile. If the tester is build without the switch off electronic, you can test
with a LED connected to the test pins, if the program operates normally. If the LED flickers,
the program operates well. The missing text on the LCD must be caused by wrong connection
or timing. For some graphical displays the contrast is changeable with a menu function. If you
have changed the contrast value, that nothing is readable at the screen, you cannot handle the
menu function any more. You can try to read the display from a slanting look to the display,
not from the front side. In this case you can try to handle the menu function with this view.
Otherwise you can write the EEprom data new with a ISP programmer to reset the contrast
value.
Something but not all is readable on the LCD display Check if the .eep data are loaded to
the EEprom memory of ATmega. If all data are loaded correctly, you should check the clock
speed of your programming data (Makefile) and ATmega processor settings (fuses).
Measurement is slow and Capacitors are measured about 8 times too small You run software compiled for 8M Hz clock at real clock speed of 1M Hz. Please set the fuses of the ATmega
correctly.
36
Measurement has strangely values Check if your programmer is still connected to the ISP-plug.
The ISP interface should be disconnected for measuring. Very often the reason of wrong
measurements is the use of software compiled with the AUTOSCALE ADC option and with
the option NO REF CAP, but the capacitor at the AREF pin has still a value of 100nF . Wrong
assembly of components or remaining soft solder flux can disturb the measurements too. Please
check with the selftest function of your TransistorTester software if possible. For the details
see Chapter 5.5.
Otherwise inspect your board visually and check the resistor values with a ohmmeter. You
can use the pins of the ATmega for this check, for example to check the R1 you can measure
between pin 23 and pin 14. Take a look at the circuit diagram 2.1 for details. There is no need
to remove the microcontroller, only battery or power supply should be removed before.
The Tester switch off the power after 2 seconds display time This condition exists, if the
external Pull-Up resistor at the PD7 input is missing or the key button is keep pressed. The
software switch off the internal Pull-Up resistors to prevent a influence to the measurement
results. Therefore a external Pull-Up resistor (27k) is required.
Der Tester shows only Vext=xx.xV in row 2 This problem exists, if the Pull-Up resistor at
the PD7 input is missing or the key button is keep pressed. Additionally the software is
configured without the serial output (without option WITH UART) and without the internal
Pull-Up resistors (with option PULLUP DISABLE). You should install the Pull-Up resistor at
pin PD7.
37
Chapter 3
Instructions for use
3.1
Using of the Transistor-Tester is simple. Anyway some hints are required. In most cases are wires
with alligator clips connected to the test ports with plugs. Also sockets for transistors can be
connected. In either case you can connect parts with three pins to the three test ports in any
order. If your part has only two pins, you can connect this pins to any two of the tree test ports.
Normally the polarity of part is irrelevant, you can also connect pins of electrolytical capacitors in
any order. The measurement of capacity is normally done in a way, that the minus pole is at the
test port with the lower number. But, because the measurment voltage is only between 0.3V and at
most 1.3V , the polarity doesnt matter. When the part is connected, you should not touch it during
the measurement. You should put it down to a nonconducting pad if it is not placed in a socket.
You should also not touch to the isolation of wires connected with the test ports. Otherwise the
measurement results can be affected. Then you should press the start button. After displaying a
start message, the measurement result should appear after two seconds. If capacitors are measured,
the time to result can be longer corresponding to the capacity.
How the transistor-tester continues, depends on the configuration of the software.
Single measurement mode If the tester is configured for single measurement mode (POWER OFF
option), the tester shut off automatical after displaying the result for 28 seconds for a longer
lifetime of battery. During the display time a next measurement can be started by pressing
the start button. After the shut off a next measurement can be started too of course. The
next measurement can be done with the same or another part. If you have not installed the
electronic for automatic shut down, your last measurement result will be displayed until you
start the next measurement.
Endless measurement mode A special case is the configuration without automatical shut off. For
this case the POWER OFF option is not set in the Makefile. This configuration is normally
only used without the transistors for the shut off function. A external off switch is necessary
for this case. The tester will repeat measurements until power is switched off.
Multi measurement mode In this mode the tester will shut down not after the first measurement but after a configurable series of measurements. For this condition a number (e.g. 5) is
assigned to the POWER OFF option. In the standard case the tester will shut down after five
measurements without found part. If any part is identified by test, the tester is shut down after
double of five (ten) measurements. A single measurement with unknown part after a series of
measurement of known parts will reset the counter of known measuerements to zero. Also a
single measurement of known part will reset the counter of unknown measurements to zero.
This behavior can result in a nearly endless series of measurements without pressing the start
button, if parts are disconnected and connected in periodical manner.
38
In this mode there is a special feature for the display period. If the start button is pressed only
short for switching on the tester, the result of measurement ist only shown for 5 seconds. Buf if
you press and hold the start button until the first message is shown, the further measurement
results are shown for 28 seconds. The next measurement can started earlier by pressing the
start button during the displaying of result.
3.2
If the menu function is selected, the tester start a selection menu after a long key press (>500ms)
for additional functions. This function is also available for other processors with at least 32K flash
memory. The selectable functions are shown in row two of a 2-line display or as marked function
in row 3 of a 4-line display. The previous and next function is also shown in row 2 and 4 of the
display in this case. After a longer wait time without any interaction the program leave the menu
and returns to the normal transistor tester function. With a short key press the next selection can
be shown. A longer key press starts the shown or marked function. After showing the last function
switch off, the first function will be shown next.
If your tester has also the rotary pulse encoder installed, you can call the menu with the additional
functions also with a fast rotation of the encoder during the result of a previous test is shown. The
menu functions can be selected with slow rotation of the encoder in every direction. Starting of the
selected menu function can only be done with a key press. Within a selected function parameters
can be selected with slow rotation of the encoder. A fast rotarion of the encoder will return to the
selection menu.
frequency The additional function frequency (frequency measurement) uses the ATmega Pin
PD4, which is also connected to the LCD. First the frequency is allways measured by counting.
If the measured frequency is below 25kHz, additionally the mean period of the input signal is
measured and with this value the frequency is computed with a resolution of up to 0.001Hz.
By selecting the POWER OFF option in the Makefile, the period of frequency measurement
is limited to 8 minutes. The frequency measurement will be finished with a key press and the
selectable functions are shown again.
f-Generator With the additional function f-Generator (frequency generator) the selectable frequencies can be switched with key presses. After selecting the last choise of frequencies, the
generator is switched back to the first frequency next (cyclical choise). If the POWER OFF
option is selected in the Makefile, the key must be pressed longer, because a short key press
(< 0.2s) only reset the time limit of 4 minutes. The elapsed time is shown with a point for every
30 seconds in row 1 of the display. With periodical short key press you can prevent the time
out of the frequency generation. With a long key press (> 0.8s) you will stop the frequency
generator and return to the function menu.
10-bit PWM The additional function 10-bit PWM (Pulse Width Modulation) generates a fixed
frequency with selectable puls width at the pin TP2. With a short key press (< 0.5s) the pulse
width is increased by 1%, with a longer key press the pulse width is increased by 10%. If 99%
is overstepped, 100% is subtracted from the result. If the POWER OFF option is selected in
the Makefile, the frequency generation is finished after 8 minutes without any key press. The
frequency generation can also be finished with a very long key press (> 1.3s).
39
C+ESR@TP1:3 The additional function C+ESR@TP1:3 selects a stand-alone capacity measurement with ESR (Equivalent Series Resistance) measurement at the test pins TP1 and
TP3. Capacities from 2F up to 50mF can be measured. Because the measurement voltage is
only about 300mV , in most cases the capacitor can be measured in circuit without previous
disassembling. If the POWER OFF option is selected in the Makefile, the count of measurements is limited to 250, but can be started immediately again. The series of measurements can
be finished with a long key press.
3 symbol the tester changes to a resistor meter at TP1 and TP3 .
Resistor meter With the 1
This operation mode will be marked with a [R] at the right side of the first display line. Because
the ESR measurement is not used in this operation mode, the resolution of the measurement
result for resistors below 10 is only 0.1. If the resistor measurement function is configured
3 symbol is shown at this menu.
with the additional inductance measurement, a 1
Then the resistor meter function includes the measurement of inductance for resistors below
2100. At the right side of the first display line a [RL] is shown. For resistors below 10
the ESR measurement is used, if no inductance is find out. For this reason the resolution
for resistors below 10 is increased to 0.01. With this operation mode the measurement is
repeated without any key press. With a key press the tester finish this operation mode and
returns to the menu. The same resistor meter function is started automatically, if a single
resistor is connected between TP1 and TP3 and the start key was pressed in the normal tester
function. In this case the tester returns from the special mode opration to the normal tester
function with a key press.
3 symbol the tester changes to a capacitor meter function at
Capacitor meter With the 1
TP1 and TP3. This operation mode will be marked with a [C] at the right side of the first
display line. With this operation mode capacitors from 1pF up to 100mF can be measured. In
this operation mode the measurement is repeated without key press. With a key press the tester
finish this operation mode and returns to the menu. In the same way as with resistors, the
tester changes automatically to the capacitor meter function, if a capacitor between TP1 and
TP3 is measured with the normal tester function. After a automatically start of the capacitor
meter function the tester returns with a key press to the normal tester function.
rotary encoder With the function rotary encoder a rotary encoder can be checked. The three
pins of the rotary encoder must be connected in any order to the three probes of the transistor
tester before the start of the function. After starting the function the rotary knob must be
turned not too fast. If the test is finished successfully, the connection of the encoder switches is
shown symbolic in display row 2. The tester finds out the common contact of the two switches
and shows, if the indexed position has both contacts in open state (o) or in closed state (C).
A rotary encoder with open switches at the indexed positions is shows in row 2 for two seconds
as 1-/-2-/-3 o. This type of encoder has the same count of indexed positions as count of
pulses for every turn. Of course the pin number of the right common contact is shown in the
middle instead of 2. If also the closed switches state is detected at the indexed positions, the
row 2 of the display is also shown as 123 C for two seconds. I dont know any rotary
encoder, which have the switches always closed at any indexed position. The interim state of
the switches between the indexed positions is also shown in row 2 for a short time (< 0.5s)
without the characters o or C. If you will use the rotary encoder for handling the tester, you
should set the Makefile option WITH ROTARY SWITCH=2 for encoders with only the open
state (o) and set the option WITH ROTARY SWITCH=1 for encoders with the open (o)
and closed (C) state at the indexed positions.
40
C(F )-correction With this menu function you can change a correction factor for bigger capacity
values. You can preset the same factor with the Makefile option C H KORR. Values above zero
reduce the output value of the capacity with this percent value, values below zero will increase
the shown capacity value. A short key press will reduce the correction value about 0.1%, a
longer key press will increase the correction value. A very long key press will save the correction
value. It is a characteristic of the used measurement method, that capacitors with low quality
like electrolytic type will result to a too high capacity value. You can detect a capacitor with
low quality by a higher value of the Vloss parameter. High quality capacitors have no Vloss or
only 0.1%. For adjusting this parameter you should only use capacitors with high quality and
a capacity value above 50F . By the way the exactly capacity value of electrolytic capacitors
is unimportant, because the capacity value differ with temperature and DC-voltage.
Selftest With the menu function Selftest a full selftest with calibration is done. With that call
all the test functions T1 to T7 (if not inhibited with the NO TEST T1 T7 option) and also
the calibration with external capacitor is done every time.
Voltage The additional function Voltage (Voltage measurement) is only possible, if the serial
output is deselected or the ATmega has at least 32 pins (PLCC) and one of the additional pins
ADC6 or ADC7 is used for the measurement. Because a 10:1 voltage divides is connected to
PC3 (or ADC6/7), the maximum external voltage can be 50V . A installed DC-DC converter for
zener diode measurement can be switched on by pressing the key. Thus connected zener diodes
can be measured also. By selecting the POWER OFF option in the Makefile and without key
pressing, the period of voltage measurement is limited to 4 minutes. The measurement can
also be finished with a extra long key press (> 4 seconds).
Contrast This function is available for display controllers, which can adjust the contrast level with
software. The value can be decreased by a very short key press or left turn with the rotary
encoder. A longer key press (> 0.4s) or a right turn of the rotary encoder will increase the
value. The function will be finished and the selected value will be saved nonvolatile in the
EEprom memory by a very long key press (> 1.3s).
BackColor For color displays this menu item can be enabled with the Makefile option LCD CHANGE COLO
for selecting the background color. The rotary encoder extension must be installed. You can
select the colors red, green and blue with a longer key press. The intensity value of the selected
color, which is marked with a  symbol in column 1, can be changed by a turn of the rotary
encoder.
FrontColor For color displays this menu item can be enabled with the Makefile option LCD CHANGE COLO
for selecting the foreground color. The rotary encoder extension must be installed. You can
select the colors red, green and blue with a longer key press. The intensity value of the selected
color, which is marked with a  symbol in column 1, can be changed by a turn of the rotary
encoder.
Show data The function ,,Show Data shows besides the version number of the software the data of
the calibration. These are the zero resistance (R0) of the pin combination 1:3, 2:3 and 1:2 . In
addition the resistance of the port outputs to the 5V side (RiHi) and to the 0V side (RiLo) are
shown. The zero capacity values (C0) are also shown with all pin combinations (1:3, 2:3, 1:2
and 3:1, 3:2 2:1). Next the correction values for the comparator (REF C) and for the reference
voltage (REF R) are also shown. With graphical displays the used icons for parts and the font
set is also shown. Every page is shown for 15 seconds, but you can select the next page by a
key press or a right turn of the rotary encoder. With a left turn of the rotary encoder you can
repeat the output of the last page or return to the previous page.
41
Switch off With the additional function Switch off the tester can be switched off immediately.
Transistor Of course you can also select the function Transistor (Transistor tester) to return to
a normal Transistor tester measurement.
With the selected POWER OFF option in the Makefile, all additional functions are limited in
time without interaction to prevent a discharged battery.
3.3
If the software is configured with the selftest function, the selftest can be prepared by connecting all
three test ports together and pushing of the start button. To begin the self test, the start butten
must be pressed again within 2 seconds, or else the tester will continue with a normal measurement.
If the self test is started, all of the documented tests in the Selftest chapter 5.5 will be done.
If the tester is configured with the menu function (option WITH MENU), the full selftest with the
tests T1 to T7 are only done with the Selftest function, which is selectable as menu function.
In addition the calibration with the external capacitor is done with every call from function menu,
otherwise this part of calibration is only done first time. Thus the calibration with the automatically
started selftest (shorted probes) can be done faster. The repetition of the tests T1 to T7 can be
avoided, if the start button is hold pressed. So you can skip uninteresting tests fast and you can
watch interresting tests by releasing the start button. The test 4 will finish only automatically if you
separate the test ports (release connection).
If the function AUTO CAL is selected in the Makefile, the zero offset for the capacity measurement will be calibrated with the selftest. It is important for the calibration task, that the connection
between the three test ports is relased during test number 4. You should not touch to any of the test
ports or connected cables when calibration (after test 6) is done. But the equipment should be the
same, which is used for further measurements. Otherwise the zero offset for capacity measurement
is not detected correctly. The resistance values of port outputs are determined at the beginning of
every measurement with this option.
If you have selected the samplingADC function in the Makefile with the option WITH SamplingADC
= 1, two special steps are included to the calibration precedure. After the normal measuring of
the zero capacity values, also the zero capacity values for the samplingADC function is measured
(C0samp). As last step of the calibration the connection of a test capacitor at pin 1 and pin 3 is
requested for later measurement of little coils with the message 1
3 10-30nF[L]. The capacity
value should be between 10nF and 30nF , to get a measurable resonant frequency by later parallel
connection to a coil with less than 2mH. For inspection of coils with more than 2mH inductance
the normal measurement method should result to a sufficient accuracy. The parallel connection of
the capacitor to use the other measurement method should not be usefull.
A capacitor with any capacity between 100nF and 20F connected to pin 1 and pin 3 is required
after the measurement of the zero capacity values. To indicate that, the message 1
3 >100nF is
shown in row 1 of the display. You should connect the capacitor not before the message C0= or this
text is shown. With this capacitor the offset voltage of the analog comparator will be compensated
for better measurement of capacity values. Additionally the gain for ADC measurements using the
internal reference voltage will be adjusted too with the same capacitor for better resistor measurement
results with the AUTOSCALE ADC option. If the menu option is selected for the tester and the
selftest is not started as menu function, the calibration with the external capacitor is only done for
42
the first time calibration. The calibration with the external capacitor can be repeated with a selftest
call as menu selection.
The zero offset for the ESR measurement will be preset with the option ESR ZERO in the
Makefile. With every self test the ESR zero values for all three pin combinations are determined.
The solution for the ESR measurement is also used to get the values of resistors below 10 with a
resolution of 0.01.
3.4
Normally the Tester shows the battery voltage with every start. If the voltage fall below a limit,
a warning is shown behind the battery voltage. If you use a rechargeable 9V battery, you should
replace the battery as soon as possible or you should recharge. If you use a tester with attached 2.5V
precision reference, the measured supply voltage will be shown in display row two for 1 second with
VCC=x.xxV.
It can not repeat often enough, that capacitors should be discharged before measuring. Otherwise
the Tester can be damaged before the start button is pressed. If you try to measure components in
assembled condition, the equipment should be allways disconnected from power source. Furthermore
you should be sure, that no residual voltage reside in the equipment. Every electronical equipment
has capacitors inside!
If you try to measure little resistor values, you should keep the resistance of plug connectors and
cables in mind. The quality and condition of plug connectors are important, also the resistance of
cables used for measurement. The same is in force for the ESR measurement of capacitors. With
poor connection cable a ESR value of 0.02 can grow to 0.61. If possible, you should connect the
cables with the test clips steady to the tester (soldered). Then you must not recalibrate the tester
for measuring of capacitors with low capacity values, if you measure with or without the plugged
test cables. For the calibration of the zero resistance there is normaly a difference, if you connect
the three pins together directly at a socket or if you connect together the test clips at the end of
cables. Only in the last case the resistance of cables and clips is included in the calibration. If you
are in doubt, you should calibrate your tester with jumpers directly at the socket and then measure
the resistance of shorten clips with the tester.
You should not expect very good accuracy of measurement results, especially the ESR measurement and the results of inductance measurement are not very exact. You can find the results of my
test series in chapter 5 at page 58.
3.5
You should keep in mind by interpreting the measurement results, that the circuit of the TransistorTester is designed for small signal semiconductors. In normal measurement condition the measurement current can only reach about 6mA. Power semiconductors often make trouble by reason of
residual current with the identification an the measurement of junction capacity value. The Tester
often can not deliver enough ignition current or holding current for power Thyristors or Triacs. So a
Thyristor can be detected as NPN transistor or diode. Also it is possible, that a Thyristor or Triac
is detected as unknown.
Another problem is the identification of semiconductors with integrated resistors. So the base emitter diode of a BU508D transistor can not be detected by reason of the parallel connected internal
42 resistor. Therefore the transistor function can not be tested also. Problem with detection is also
given with power Darlington transistors. We can find often internal base - emitter resistors, which
make it difficult to identify the component with the undersized measurement current.
43
3.6
For normal measurement the three pins of the transistor will be connectet in any order to the
measurement inputs of the TransistorTester. After pushing the start button, the Tester shows in row
1 the type (NPN or PNP), a possible integrated protecting diode of the Collector - Emitter path and
the sequence of pins. The diode symbol is shown with correct polarity. Row 2 shows the current
amplification factor B or hF E and the current, by which the amplification factor is measured. If
the common emitter circuit is used for the hFE determinatation, the collector current Ic is output.
If the common collector circuit is used for measuring of the amplification factor, the emitter current
Ie is shown. Further parameters are shown for displays with two lines in sequence, one after the the
other in line 2. For displays with more lines further parameters are shown directly until the last line
is allready used. When the last line is allready used before, the next parameter is shown also in the
last line after a time delay automatically or earlier after a key press. If more parameters are present
than allready shown, a + character is shown at the end of the last line. The next shown parameter
is anyway the Base - Emitter threshold voltage. If any collector cutoff current is measurable, the
collector current without base current IC E0 and the collector current with base connected to the
emitter IC ES is also shown. If a protecting diode is mounted, the flux voltage U f is also shown as
last parameter.
With the common Emitter circuit the tester has only two alternative to select the base current:
1. The 680 resistor results to a base current of about 6.1mA. This is too high for low level
transistors with high amplification factor, because the base is saturated. Because the collector
current is also measured with a 680 resistor, the collector current can not reach the with the
amplification factor higher value. The software version of Markus F. has measured the Base Emitter threshold voltage in this ciruit (Uf=...).
2. The 470k resistor results to a base current of only 9.2A . This is very low for a power transistor with low current amplification factor. The software version of Markus F. has identified
the current amplification factor with this circuit (hFE=...).
The software of the Tester figure out the current amplification factor additionally with the common Collector circuit. The higher value of both measurement methodes is reported. The common
collector circuit has the advantage, that the base current is reduced by negative current feedback
corresponding to the amplification factor. In most cases a better measurement current can be reached
with this methode for power transistors with the 680 resistor and for Darlington Transistors with
470k resistor. The reported Base - Emitter threshold voltage Uf is now measured with the same
current used for determination of the current amplification factor. However, if you want to know the
Base - Emitter threshold voltage with a measurement current of about 6mA, you have to disconnect
the Collector and to start a new measurement. With this connection, the Base - Emitter threshold
voltage at 6mA is reported. The capacity value in reverse direction of the diode is also reported. Of
course you can also analyse the base - collector diode.
With Germanium transistors often a Collector cutoff current ICE0 with currentless base or a
Collector residual current ICES with base hold to the emitter level is measured. Only for ATmega328
processors the Collector cutoff current is shown in this case at the row 2 of the LCD for 5 seconds
or until the next keypress before showing the current amplification factor. With cooling the cutoff
current can be reduced significant for Germanium transistors.
44
3.7
Because the structure of JFET type is symmetrical, the Source and Drain of this transistores can
not be differed. Normally one of the parameter of this transistor is the current of the transistor
with the Gate at the same level as Source. This current is often higher than the current, which can
be reached with the measurement circuit of the TransistorTester with the 680 resistor. For this
reason the 680 resistor is connected to the Source. Thus the Gate get with the growing of current a
negative bias voltage. The Tester reports the Source current of this circuit and additionally the bias
voltage of the Gate. So various models can be differed. The D-MOS transistors (depletion type) are
measured with the same methode.
3.8
You should know for enhancement MOS transistors (P-E-MOS or N-E-MOS), that the measurement
of the gate threshold voltage (Vth) is more difficult with little gate capacity values. You can get a
better voltage value, if you connect a capacitor with a value of some nF parallel to the gate /source.
The gate threshold voltage will be find out with a drain current of about 3.5mA for a P-E-MOS and
about 4mA for a N-E-MOS. The RDS or better RDSon is measured with a gate - source voltage of
nearly 5V , which is probably not the lowest value.
3.9
Measurement of capacitors
The capacity values are always computed from the time constant, which is build by the serial connection of the build in resistors with the capacitor during charging. With little capacity values the
470k resistors are used for the measurement the time to reach a threshold voltage. For bigger capacity values with some 10F the voltage grow at the capacitor is monitored after charge pulses with
the 680 resistors. With this voltage grow the capacity can be computed together with the count
of fixed length pulses. Very low capacity values can be measured with the samplingADC method.
For analysing the same load pulse is repeated many times and the voltage is monitored with the
time shift of the ADC S&H time using interval-tics build from the processor clock. But a complete
AD conversion take 1664 processor tics! Up to 250 ADC samples are build by this way and from
the voltage curve the capacity value is computed. If the samplingADC function is selected in the
Makefile, all capacitors with less than 100pF are measured with the samplingADC function in the
capacitor-meter mode [C]. The resolution is up to 0.01pf with a clock frequency of 16M Hz. The
calibrated condition is difficult to build with this high resolution. You can assume the use of the
samplingADC methode every time, fractions of 1pF are displayed at the screen. By the way it should
mentiored, that the junction capacitance of single diodes can also be measured with this method.
Because this method can measure the capacity value by charging or discharging, two capacity results
are shown. Both values differ be reason of the capacity diode effect.
3.10
Measurement of coils
The normal measurement of the inductance is based on the measurement of the time constant of the
current grow. The detection limit is about 0.01mH, if the resistance of the coil is below 24. For
bigger resistance values the resolution is only 0.1mH. If the resistance is above 2.1k, this technique
can never be used to detect coils. The measurement results of this normal measurement is shown in
the second line (resistance and inductance). With the samplingADC method a resonant frequency
of coils can be detected with greater inductance values. If this effect is noticeable, the frequency and
the quality factor Q of the coil is shown additionally in line 3.
45
The method of resonant frequency measurement can also be used for the determination of the
inductance value, if a sufficient big capacitor mith know capacity value is connected parallel to a little
inductance (<2mH). With a parallel connected capacitor the normal measurement of inductance
can no more operate well. If the resonant frequency let assume a parallel connected capacitor, the
inductance of the normal measurement is not shown and the resistance value is shown in line 1. For
this resonant circuit the quality factor Q is also computed and shown behind the frequency value in
line 3. You can identify this type of measurement with the inductance value at the first position of
line 2, followed by the text  if  and the value of the assumed parallel capacity. The value of this
3 10  30nF (L)).
parallel capacitor can currently only be set with the calibration function (1
For displays with only two lines, the content for the third line is shown time-delayed in line 2.
46
Chapter 4
Configuring the TransistorTester
The complete software for the TransistorTester is available in source code. The compilation of
modules is controlled with a Makefile. The developement was done at the Ubuntu Linux operating
system with the GNU toolchain (gcc version 4.5.3). It should be possible to use other Linux operating
systems without problems. To load the compiled data to the flash memory or the EEprom memory,
the tool avrdude (version 5.11svn) was taken by the Makefile, if you call make upload. The program
avrdude [12] is available for Linux and Windows operating system. The gnu C-compiler gcc is also
taken by the AVR studio software and by the WinAVR [16],[17] software at the Windows operating
system. You can load the program data (.hex and .eep) also with other tools to the ATmega, but
only my Makefile version takes care to load the correct data to the choosed processor. Avrdude
loads only data to the ATmega if the Signature Bytes of the connected ATmega is identical to the
choosed one. If you alter the Makefile, all the software will be compiled new, if you call a make
or make upload command. The software compiled for a ATmega8 does not run on a ATmega168.
The software compiled for a ATmega328 does not run on the ATmega168! A exeption from this
rule is the software compiled for ATmega168, this data can also be used for a ATmega328 without
changes. Be careful, if you dont use my Makefile.
With the correct options set, my software runs on the unchanged hardware of Markus F. You must
set the option PARTNO=M8, NOT the option NO AREF CAP and NOT the PULLUP DISABLE
option. The clock rate can also be set to 8M Hz with fuses, no crystal is required!
The following options in the Makefile are avaiable to configure the software for your Tester.
PARTNO describes the target processor:
m8 = ATmega8
m168 or m168p = ATmega168
m328 or m328p = ATmega328
m644 or m644p = ATmega644
m1284p = ATmega1284
m1280 = ATmega1280
m2560 = ATmega2560
Example: PARTNO = m168
UI LANGUAGE specifies the favored Language
LANG BRASIL, LANG CZECH, LANG DUTCH, LANG ENGLISH, LANG GERMAN,
LANG HUNGARIAN, LANG ITALIAN, LANG LITHUANIAN, LANG POLISH,
LANG RUSSIAN, LANG SLOVAK, LANG SLOVENE, LANG SPANISH and
LANG UKRAINIAN is currently avaiable. The russian or ukrainian language requires a LCD
with cyrillic character set.
Example: UI LANGUAGE = LANG ENGLISH
47
LCD CYRILLIC is only needed for a LCD-display with cyrillic character set. The  and  character is not avaiable with the cyrillic character set. If you specify this option, both characters
are loaded to the LCD with software. You should set this option, if your display shows wrong
characters instead of  or .
Example: CFLAGS += -DLCD CYRILLIC
LCD DOGM must be set, if a LCD with ST7036 controller (Type DOG-M) is used for displaying.
The LCD-contrast is then set with software commands. If you have changed the contrast value
to a wrong value, so that you can not read anything at your display, you shouls first try to
read somthing from a side look to the display. If this fails also, you should reset the EEprom
to the initial values with a ISP programmer.
Example: CFLAGS += -DLCD DOGM
FOUR LINE LCD can be used with a 4x20 character display for better using the additional space.
Additional parameters, which are shown only short in row 2, will be shown in row 3 and 4 with
this option.
Example: CFLAGS += -DFOUR LINE LCD
DD RAM OFFSET Somne character displays use different DD-RAN starting addresses for the
beginning of each line. Usually the DD-RAM starting address for line 1 is 0. Some displays
like TC1604 or TC1602 use a 128 (0x80) for the beginning of line 1. This can be respected
with this option. Example: CFLAGS += -DDD RAM OFFSET = 128
WITH LCD ST7665 This option must be used, if a 128x64 pixel LCD is connected with serial interface. For this display type further options must be set, which are described in table 4.1. You
can also use the simular SSD1306 controller instead of the ST7565 controller for example. This
must be done by setting the variable WITH LCD ST7565 to 1306. A PCF8812 or PCF8814
Controller is also supported, if the Option is set correctly. Also a display with a ST7920 or
ST7108 controller can be connected. For the ST7108 controller a additional serial-parallel converter 74HC(T)164 or 74HC(T)595 must be used.
Example: WITH LCD ST7565 = 1
LCD INTERFACE MODE For the SSD1306 controller also the I2 C type interface with address
0x3c can be used instead of the 4-wire SPI interface by setting this option to 2. For the ST7920
controller a special serial interface can be selected by setting this option to 5. If only one connection type is provided for a controller, you need not set the constant LCD INTERFACE MODE
. All currently used values for LCD INTERFACE MODE and WITH LCD ST7565 are shown
in table 4.1.
48
Display-Type
Character 16x2,
Character 20x4
Graphic ST7565
Graphic ST7565
Graphic SSD1306
Graphic SSD1306
Graphic ST7920
Graphic ST7920
Graphic ST7108
or KS0108
Graphic PCF8812
Graphic PCF8814
Graphic ILI9163
128x128 Color
Graphic ST7735
128x160 Color
Interface
4-Bit parallel
4-Bit SPI
I2 C
4-Bit SPI
I2 C
4-Bit SPI
I2 C
4-Bit parallel
2-Bit serial
8-Bit parallel
+ 74HCT164
SPI
SPI
I2 C
3-line
SPI
SPI
disabled (4)
disabled (4)
2
3
disabled (4)
7735
disabled (4)
presentation.
Example: CFLAGS += -DLCD ST7565 H OFFSET = 4
LCD ST7565 V FLIP With this option the display content can be flipped in vertical direction.
Example: CFLAGS += -DLCD ST7565 V FLIP = 1
VOLUME VALUE You can predefine a contrast value for ST7565 or SSD1306 controllers. The
value for the ST7565 controller can be between 0 and 63. For the SSD1306 controller you can
select a value between 0 and 255.
Example: CFLAGS += -DVOLUME VALUE = 25
LCD ST7565 Y START With this option you can set the first row correctly to the top of screen.
The first row is shifted to the middle of the screen for some display variants. For this variants
you can shift the first row to the top of the screen again, if this option is set to 32 (half of the
screen height).
Example: CFLAGS += -DLCD ST7565 Y START = 32
LCD CHANGE COLOR This option expand the menu functions with a selection item to change
the background and the foreground color. If the value is set to 2, the colors blue and red are
swapped. You can select this option only for color displays (controller ST7735 or ILI9163).
Example: CFLAGS += -DLCD CHANGE COLOR=1
LCD BG COLOR With this 16-bit value you can select a background color. Normally the upper
5 bits are used for the color red, the middle 6 bits are used for the color green and the lower 5
bits are used for the color blue. Sometimes the bits for the colors red and blue are swapped.
You can select this option only for color displays (controller ST7735 or ILI9163).
Example: CFLAGS += -DLCD BG COLOR=0x000f
LCD FG COLOR With this 16-bit value you can select a forground color. The example selects the
color white for text and symbols. You can select this option only for color displays (controller
ST7735 or ILI9163).
Example: CFLAGS += -DLCD FG COLOR=0xffff
FONT 8X16 You must select one font size for the ST7565 controller. Selectable are different fonts
with the name FONT  with appended size information (width X height). Currently the font
sizes 6X8, 8X8, 7X12, 8X12, 8x12thin, 8X14, 8X15, 8X16, and 8X16thin are available. Font
size 8X16 or 8x16thin is the most efficient use of graphics space for a 128x64 pixel LCD.
Example: FONT 8X16
BIG TP The pin numbers for the graphical presentation can be shown bigger with this option.
Example: CFLAGS += BIG TP
INVERSE TP With this option you can select a inverse presentation (white background) of the
pin numbers on the graphical display. Because a boarder in required for this presentation, you
can not combine this option with the BIG TP option.
Example: CFLAGS += INVERSE TP
STRIP GRID BOARD This option adapts the software to a changed port D connection for strip
grid printed boards. You can find the details in the chapter hardware 2.1 at page 9. You can
also choose alternative assignments of ATmega pins for graphical displays. For the chinese T5
board you must set the STRIP GRID BOARD option to 5. For alternative pin assignments of
graphical displays the assignment of the pushbutton signal is unchanged.
Example: CFLAGS += -DSTRIP GRID BOARD
50
WITH MENU activated a menu function for a ATmega328. You can select some additional functions with a selection menu, which you can call with a long key press (> 0.5s).
Example: CFLAGS += -DWITH MENU
WITH ROTARY SWITCH The menu function can be easier controlled with a the extension of a
rotary pulse encoder. See the description 2.6 in the Hardware section for details of the required
extension. If your rotary pulse encoder has the same count of indexed positions (detent) as
pulses of the switch for every turn, you must set the option WITH ROTARY SWITCH to
2. If the rotary pulse encoder has twice the count of indexed position, you must set the
option WITH ROTARY SWITCH to 1. Setting the WITH ROTARY SWITCH to 5 selects
the highest resolution for the rotary switch. Every cycle of the two switches results to a count
of 4. Usually this setting is only usefull for rotary switch encoders without indexed positions. A
setting of the WITH ROTARY SWITCH to 4 is required for correct handling of two separate
push buttons for Up and Down, which are installed instead of the normal rotary encoder
switches. Do not use a setting of 4 for normal rotary encoders!
Example: CFLAGS += -DWITH ROTARY SWITCH=1
CHANGE ROTARY DIRECTION You can change the direction of the detected rotary direction by hardware swap of the two switch signals or by setting the this option.
Example: CFLAGS += -DCHANGE ROTARY DIRECTION
WITH SELFTEST If you specify this Option, software will include a selftest function. Selftest
will be started, if you connect all three probes together and start measurement. If the menu
function is selected, only the calibration part of the self test is executed by automatic start
with shorted probes. The selftest parts T1 to T7 are only executed, if the selftest is started
with menu selection.
Example: CFLAGS += -DWITH SELFTEST
NO COMMON COLLECTOR HFE disables the hFE measurement of transistors with the
common collector circuit. You can save memory to enable the extended selftests T1 to T7
for a ATmega168 processor. By default both measurement circuits for the hFE measurement
are enabled, but there is no place in the program memory of the ATmega168 for the extended
selftests.
Example: CFLAGS += -DNO COMMON COLLECTOR HFE
NO COMMON EMITTER HFE disables the hFE measurement of transistors with the common emitter circuit. You can save memory to enable the extended selftests T1 to T7 for a
ATmega168 processor. By default both measurement circuits for the hFE measurement are
enabled, but there is no place in the program memory of the ATmega168 for the extended
selftests.
Example: CFLAGS += -DNO COMMON EMITTER HFE
NO TEST T1 T7 This option disable the execution of the selftest parts T1 to T7. This tests are
usefull to find errors in the hardware like incorrect measurement resistors or isolation problems.
If your hardware is well, you can omitt this selftest parts T1 to T7 by setting this option to get
a faster calibration. With enabled menu function the selftest parts T1 to T7 are only started by
selection of the menu function Selftest. The ATmega168 processor does not use the selftest
parts T1 to T7, if both measurement types for hFE determination are used.
Example: CFLAGS += -DNO TEST T1 T7
AUTO CAL The zero offset for capacity measurement will be written additionally to the EEprom
with the selftest routine. Additionally the offset voltage of the analog comparator (with option
51
REF C KORR) and the voltage offset of the internal reference voltage (REF R KORR) will be
measured automatically, if you connect a capacitor with a capacity value between 100nF and
20F to pin 1 and pin 3 after measurement of capacity zero offset. All found values will be
written to EEprom and will be used for further measurements automatically. The port output
resistance values will be determined at the beginning of each measurement.
Example: CFLAGS += -DAUTO CAL
SHORT UNCAL MSG After the test of a part a message is shown for processors with at least
32K flash memory, if the tester is still uncalibrated. Normally followes after the hint a short
description, how the tester can be calibrated. This description is not shown, if you set the
option SHORT UNCAL MSG in the Makefile. With this option set, the tester only display a
one line hint. This reduces the required space of flash memory and also the display time for
the user, which already know, how to calibrate the tester.
Example: CFLAGS += -DSHORT UNCAL MSG
WITH SamplingADC With this option set, the tester make use of the sampling method of ADC
in special cases. By shifting the sampling time of the ADC with increments of 1, 4 or 16
processor clock intervals for repeatable signals fast changes of voltages can be monitored. The
load time of little capacitors below 100pF can be monitored with a resulting resolution of
0.01pF with a 16M Hz processor clock. With the same method the resonant frequency of little
coils below 2mH can be monitored with a parallel capacitor to build a LC-resonator. If the
capacity of the parallel capacitor is known, the inductance of the coil can be calculated with
high resolution from the resonant frequency. As a side product the quality factor Q can be
estimated from the resonant behavior. This features are switched on by setting the option
WITH SamplingADC. At the calibration sequence additionally the zero capacity values of the
sampling method is measured and after that the capacity value of a suitable capacitor for later
building the LC-resonator with a unknown coil is measured.
Example: WITH SamplingADC = 1
WITH XTAL This option enables additional tests for crystals and resonators, if the SamplingADC
function is also enabled and a 16 MHz crystal is used for clock generation (OP MHZ = 16). If
possible, the frequencies for serial and parallel circuit is measured and than the serial capacity
Cm of the equivalent circuit is tried to compute from the frequency offset.
Example: CFLAGS += -DWITH XTAL
WITH UJT This option enables additional tests for Unijunction transistors. If the SamplingADC
function is enabled, the tester tries to build a oscillator with the part. But the UJT type is also
detected without the SamplingADC function. Without the option WITH UJT the unijunction
transistors are detectes as double diode.
Example: CFLAGS += -DWITH UJT
WITH PUT This option enables a additional test for Programmable Unijunction Transistor.
Without this option PUTs are usually detected as Bipolar Junction Transistor.
Example: CFLAGS += -DWITH PUT
FREQUENCY 50HZ At the end of selftest a 50 Hz Signal will be generated on Port 2 and Port 3
for up to one minute. This option should be set only for special cases to check the delay
function.
Example: CFLAGS += -DFREQUENCY 50HZ
CAP EMPTY LEVEL This option defines the voltage level for discharged capacitor (mV units).
You can set the level to higher value as 3mV , if the tester does not finish discharging of
52
capacitors. In this case the tester ends after longer time with the message Cell!.
Example: CFLAGS += -DCAP EMPTY LEVEL=3
WITH AUTO REF specifies, that reference voltage is read to get the actual factor for capacity
measuring of low capacity values (below 40F ).
Example: CFLAGS += -DWITH AUTO REF
REF C KORR specifies a offset for readed reference voltage in mV units. This can be used to
adjust the capacity measurement of little capacitors. A correction value of 10 results to about
1 percent lower measurement results. If the option AUTO CAL is selected together with
the WITH SELFTEST option, the REF C KORR will be a offset to the measured voltage
difference of the test capacitor and the internal reference voltage.
Example: CFLAGS += -DREF C KORR=14
REF L KORR specifies a additional offset in mV units to the reference voltage for the measurement of inductance values. The REF C KORR offset and respectively the offset value from the
calibration is additionally used with the inductance measurement. The REF L KORR value
will be subtracted for measurements without a 680 resistor, for measurements with a 680
resistor the value will be added. A correction value of 10 will change the result about 1 percent.
Example: CFLAGS += -DREF L KORR=40
C H KORR specifies a correction value for the measurement of big capacitor values. A value of
10 results to 1 percent lower measurement results.
Example: CFLAGS += -DC H KORR=10
WITH UART uses the pin PC3 as output for the serial text (V24). If the option is not set, the
pin PC3 can be used for reading a external voltage with a 10:1 resistor divider. With this
equipment you can check the breakdown voltage of zener diodes, which have more than 4.5V
breakdown voltage. This measurement will repeat with 3 measurements per second until you
release the Start button.
Example: CFLAGS += -DWITH UART
TQFP ADC6 The Option TQFP ADC6 uses the additional input ADC6 of the ATmega with
TQFP or QFN package instead of the PC3 pin (ADC3). With this option the external voltage
input can be used independent of the usage of PC3 pin for serial output. The ADC6 input
is then used for the zener diode measurement and for the dialog selectable external voltage
measurement for a ATmega328.
Example: CFLAGS += -DTQFP ADC6
TQFP ADC7 The Option TQFP ADC7 uses the additional input ADC6 of the ATmega with
TQFP or QFN package instead of the PC3 pin (ADC3). With this option the external voltage
input can be used independent of the usage of PC3 pin for serial output. If this option is used
without the option TQFP ADC6, both the zener diode measurement and the measurement of
external voltage with the dialog is done with the ADC7 analog input. If this option is used
together with the TQFP ADC6 option, is the zener diode measurement done with the ADC6
pin and both pins are used for voltage measurement with the dialog of the ATmega328. Both
ADC input pins shouls be assembled with a 10:1 voltage divider.
Example: CFLAGS += -DTQFP ADC7
WITH VEXT enables the measurement of a external voltage with a 10:1 voltage divider. For
the ATmega168 or ATmega328 processor usually the PC3 pin is used as input, if no option TQFP ADC6 or TQFP ADC7 is set. In this case this option is only possible, if the
53
EBC STYLE specifies, that the output of transistor pin layout is done with format EBC=... or
GDS=.... This way of output save program memory for the ATmega. Without this option
the layout is shown with the format 123=..., where every point represent a E (Emitter),
B (Base) or C (Collector). For FET transistors every point can be a G (Gate), D (Drain) or
S (Source). If the sequence of the test pins is not 1, 2 and 3 in the reading direction, you can
invert the sequence with the option EBC STYLE=321 . The pin assignment is then shown with
style 321=..., which will better match the usual reading direction, if the testpin sequence is
3,2,1 .
Example: CFLAGS += EBC STYLE
NO NANO specifies that the decimal prefix nano will not be used to display the measurement
results. So capacity values will be shown in F instead of nF .
Example: CFLAGS += NO NANO
NO LONG PINLAYOUT can be set to prevent the long style of pin layout for graphical displays
like  Pin 1=E 2=B 3=C. If the option is set, the short style is used instead like  Pin
123=EBC.
Example: CFLAGS += NO LONG PINLAYOUT
PULLUP DISABLE specifies, that you dont need the internal pull-up resistors. You must have
installed a external pull-up resistor at pin 13 (PD7) to VCC, if you use this option. This option
prevents a possible influence of pull-up resistors at the measuring ports (Port B and Port C).
Example: CFLAGS += -DPULLUP DISABLE
ANZ MESS this option specifies, how often an ADC value is read and accumulated. You can
select any value between 5 and 200 for building mean value of one ADC measurement. Higher
values result to better accuracy, but longer measurement time. One ADC measurement with
44 values takes about 5ms.
Example: CFLAGS += -DANZ MESS=25
POWER OFF This option enables the automatic power off function. If you dont specify this
option, measurements are done in a loop infinitely until power is disconnected with a ON/OFF
switch. If you have the tester without the power off transistors, you can deselect the option
POWER OFF.
If you have NOT selected the POWER OFF option with the transistors installed, you can also
shut down the tester, if you have selected the WITH MENU option.
You can also specify, after how many measurements without a founded part the tester will
shut down. The tester will also shut down the power after twice as much measurements are
done in sequence without a single failed part search. If you have forgotten to unconnect a test
part, total discharging of battery is avoided. Specify the option with a form like CFLAGS
+= -DPOWER OFF=5 for a shut off after 5 consecutive measurements without part found.
Also 10 measurements with any founded part one after another will shut down. Only if any
sequence is interrupted by the other type, measurement continues. The result of measurement
stay on the display for 28 seconds for the single measurement, for the multiple measurement
version display time is reduced to 5 seconds (set in config.h). If the start key is pressed a longer
time on power on time, the display time is also 28 seconds for the multiple measurement. The
maximum value is 255 (CFLAGS += -DPOWER OFF=255).
Example 1: CFLAGS += -DPOWER OFF=5
Example 2: CFLAGS += -DPOWER OFF
BAT CHECK enables the Battery Voltage Check. If you dont select this option, the version
number of software is output to the LCD instead. This option is usefull for battery powered
55
56
57
Chapter 5
Description of the measurement
procedures
The simplified schematic of a Input/Output-Port pin of the ATmega is shown in figure 5.1. The PUD
switch isolates all pull up resistors of the ATmega. The output of a pin can be switched off with
the DD switch. The Input can operate regardless to the state of the switch DD. The PORT switch
usually defined the output level, but also switches the pull up resistor. Because the Switches PORT
and DD can not be changed at the same time but only one after another, the pull up resistors can
disturb the measurement. Therefore I prefere to disable the pull up resistors with the PUD switch.
Of course all the switches are electronic type and the resistors 19 and 22 are approximated values.
VCC
PUD
Pull up
to ADC Mux, Port C only
22
Port Pin
DD
19
PIN
PORT
22
19
22
19
22
19
VCC
GND
ADCMUX
R4
PB3
470k
R3
PB2
680
PC1
TP2
Every test pin (measurement port) can be used as digital or analog input. This measurement
capability is independent of using the port as output. Every test pin can be switched to output and
in this mode it can be directly connected to GND (0V ) or VCC (5V ), or it can be connected via a
680 resistor or a 470k resistor to either GND or VCC. Table 5.1 shows all possible combination
of measurements. Notice, that the positive state can be switched directly to VCC (Port C) or it can
be connected with the 680 resistor to VCC (Port B). The same possibility has the negative state of
terminal probe to the GND side. The test state means, that probe can be open (Input), connected
with the 470k resistor to VCC or GND, or that the probe can be connected with the 680 resistor
to VCC or GND.
1.
2.
3.
4.
5.
6.
59
5.1
Measurement of Semiconductors
The currentflow of the device with currentless control gate (third pin, also called Tristate pin) is to be
examined first. The Tristate pin of the device under test is the base or gate for example. One probe
pin is selected as the positive side of the device and connected directly to VCC. The other probe
pin selectes as negative side of the device. The negative side is connected with the 680  resistor
to GND. With fieldeffect transistors the state of the device depends on the voltage of the gate. The
Tristate pin is first connected with the 680  resistor for 5 ms to the GND side and the voltage at
the negative side is measured. After that the voltage of the negative side is measured again during
the Tristate pin switched as input (High Impedance). Then the assumed gate is connected with the
680  resistor for 5 ms to the VCC side and the voltage on the negative side is measured again. If
the measured voltage is lower than the first measurement result, this circuit will be assumed as the
right one. Then the voltage is measured again with currentless Tristate pin.
If the voltage of the negative pin with fixed Tristate pin is higher than 115 mV and this level
is not 100 mV lower than the voltage measured with currentless Tristatepin, a depletion transistor
type is assumed. With bipolar transistors, which have a high collector residual current, the residual
current with currentless base is usually significant higher. With the checking of both voltages we can
avoid the wrong detection of some Germanium transistors with a higher collector cutoff current as
depletion transistors (JFET).
Then additional tests are done to differ N-channel JFET or N-D-MOSFET and P-channel JFET
or P-D-MOSFET. Die MOSFET-Versionen knnen erkannt werden durch das Fehlen von Steuerstrom
in jedem TriStatePins Zustand. The MOSFET versions can be differed by the missing of gate current
in any state of the TriStatePin.
To get parameters of the depletion types, they will be measured with a 680  resistor at the source
pin, as shown in figure 5.3 . This measurement will be done instead of the usually measurement of
current with the gate hold at source level, because the IDSS current of the FET transistor can often
not be reached with the relative high resistance of the 680  resistor.
60
ADCMUX
22
19
ADCMUX
TP3
R6
PB5
470k
TP1 D
PB4
R5
PC2
680
R2
470k
PB1
R1
680
PB0
22
19
22
19
VCC
22
22
19
GND
PC0
19
22
19
22
19
22
19
22
19
VCC
GND
ADCMUX
470k
R3
R4
PB3
PB2
680
PC1
TP2
Figure 5.3. Measurement of the Gate-Source voltage and Source current of a N-JFET transistor
If the component has no current between positive probe and negative probe without signal at the
TristatePin, the next tests are specified in the next section 5.1.1. If current was detected, the next
test is described in the diode section 5.1.4.
5.1.1
First the current amplification factor is measured with common collector (emitter follower) for the
assumed PNP transistor. The measuring situation is shown in figure 5.4. If the measured voltage
B
. The
at the Base (U B) is above 9 mV with the 680  resistor, the hFE is build as hF E = U EU
UB
voltage U E is the difference of the Emitter-voltage to VCC. The difference between the 22  and
19  resistors are not respected. If the U B voltage is below 10 mV , the measurement is done with the
E470000
.
470 k resistor at the base. In this case the current amplification factor is build as hF E = UUB(680+22)
61
GND
ADCMUX
22
19
22
19
22
19
22
19
22
19
ADCMUX
TP3
PB5
R6
TP1
PB4
470k
PC2
680
R1
R2
PB1
470k
PB0
680
PC0
R5
22
19
VCC
22
19
22
19
22
19
VCC
GND
R4
PB3
470k
680
R3
PB2
PC1
TP2
Figure 5.4. hFE measurement of PNP transistor with common collector circuit
Next the tests with common emitter are done for the assumed PNP transistor. The positive side
of component is now direct connected to VCC, the negative side 680  resistor is connected to GND
as shown in Figure 5.5. If the negative side of component has a voltage of above 3.4 V , when the
base side 680  resistor was connected to GND, it must be a PNP transistor or a P-Channel FET.
This can be easy find out by analysing the base voltage. If the base voltage is greater 0.97 V , it
must be a PNP. For measuring the current amplification factor, the 470 k resistor is taken as Base
C0)470000
resistor instead of the 680 . The current amplification factor is build by hF E = (U CU
U B(680+19)
. The voltage UC0 is the voltage at the colletor resistor without base current. The higher current
amplification factor is assumed to be the right one, this one or the one found with the common
collector circuit.
The values found for the PNP are only valid, if a second set of measurements is done. In order to
prevent detecting the PNP in the inverse mode (collector and emitter are swapped), the measurement
with the higher current amplification is taken as the right one. If base voltage is lower than 0.97 V ,
it must be a P-E-MOS. In this case the gate threshold voltage is measured by switching the gate
slowly with the 470 k resistor up and down, waiting for a digital input signal change of the Drain
side and then read the voltage of the gate pin.
62
GND
22
19
22
19
ADCMUX
TP3
PB5
R6
TP1
PB4
470k
R2
470k
R1
680
PC2
PB1
680
PB0
PC0
R5
ADCMUX
22
19
22
19
22
19
22
19
VCC
22
19
22
19
22
19
VCC
GND
ADCMUX
R4
PB3
470k
680
R3
PB2
PC1
TP2
Figure 5.5. test and hFE measurement of PNP transistor with common emitter circuit
5.1.2
The measuring of NPN-Transistors begin in the same way as PNP-Transistors with measuring the
current amplification factor in the common collector circuit. First measurement is done with a 680 
base resistor switched to VCC. If the voltage at the base resistor ist too low, the 470 k resistor is
taken instead. Measurement then continues with the common emitter circuit as shown in figure 5.6.
63
22
22
GND
19
22
19
19
22
19
22
19
22
19
VCC
ADCMUX
ADCMUX
R6
PB5
470k
TP3
R5
TP1
680
470k
PB4
PC2
PB1
R1
680
PB0
R2
PC0
22
19
22
19
22
19
VCC
GND
ADCMUX
R4
PB3
470k
680
R3
PB2
PC1
TP2
Figure 5.6. test and hFE measurement of NPN transistor with common emitter circuit
If the voltage of collector sinks below 1.6 V , when the 680  base resistor is connected to VCC,
ist must be a NPN, N-Channel MOSFET or Thyristor/Triac. With two simple tests a Thyristor
or Triac can be identified. If the gate pin resistor is connected for 10 ms to GND and than made
currentless, the current at the anode should stay. If then the anode resistor is short connected to
GND and reconnected to VCC, the Thyristor should not trigger again (no current). Please keep in
mind, that only low power Thyristors can be tested, because the holding current of the tester can
reach only 6 mA. If both tests attest a Thyristor, further tests with reverse polarity are done to
exclude or confirm a Triac.
If neither Thyristor nor Triac could be confirmed, it can be a NPN or N-Channel E-MOSFET.
The Base voltage of a NPN Transistor will be near the Emitter voltage, so this type can be
identified definitely. The current amplification factor in the common emitter circuit is build by
CU C0)470000
. If the voltage of the Base or better Gate shows, that there is no or
hF E = (V(VCCU
CCU B)(680+22)
little current, part will be a N-Channel E-MOS (Enhancement MOSFET). In this case the threshold
voltage is measured by switching the Gate slowly with the 470 k resistor to VCC and GND, waiting
for a digital input signal change of the Drain side and then read the voltage of the Gate pin. This
measurement is done eleven times with ADC results accumulated as shown in Figure 5.7. The result
is multiplied by four and divided by 9 to get the voltage in mV resolution.
64
65
5.1.3
saveNresult
H
680
L
vCEs
lp_otr
680
680
L
680
lp_otr
vCEs
680
lp2
680
H
T
update_pins
=1?
680
n.cnt = n.cnt+1
680
N
n.b = TristatePin
n.e = LowPin
n.c = HighPin
update_pins = 1
n.cnt+p.cnt>1?
(n.cnt!=1)||(n.b==p.b)?
checkDiode
Y
N
savePresult
Pchannel
vCEs*2+20 > lp_otr ?
vCEs > 115 ?
hp1
Nchannel
tp1
680
p.cnt = p.cnt+1
H
T
470k
tp1
H
T
470k
L
680
lp1
hp2
update_pins
=1?
680
H
T
470k
L
H
T
470k
p.b = TristatePin
p.e = HighPin
p.c = LowPin
680
lp2
Y
Y
tp2
470k
lp2
470k
H
T
L
680
CheckPins
Exit
H
T
L
N
Part = FET
Typ = PDMOS
Part = FET
Typ = NDMOS
Part = FET
Typ = PJFET
Part = FET
Typ = NJFET
p.cnt = p.cnt+1
p.gthvoltage = tp1hp1
p.current = (VCChp1)/680
n.cnt = n.cnt+1
n.uBE = lp1
n.gthvoltage = lp1tp1
n.current = lp1/680
savePresult
Part 2
saveNresult
66
hp1
tp1
Part2
680
tp1
H
T
680
H
T
680
lp1
680
PChannel
NChannel
tp1 < 10 ?
(VCCtp1) < 10 ?
hp1
tp1
680
H
T
470k
tp1
c_hfe=(VCChp1tp1)/tp1
H
T
470k
c_hfe=(VCChp1)*470k/680/tp1
680
lp1
c_hfe=lp1*470k/680/(VCCtp1)
hp1
tp2
680
H
T
680
L
H
lp2
T
L
680
checkDiode
checkDiode
N
Y
Y
H
T
680
ThyristorCheck
680
lp1
Ntype
hp2
tp2
470k
hp2
T
L
tp2
680
lp1
680
H
T
470k
lpx
Part = TRANS
Typ = PNP
e_hfe = (lp1lp_otr)*470k/680/tp2
update_pins = 0
p.hfe = e_hfe
p.uBE = hp2  tp2
update_pins = 1
Part = TRANS
Typ = NPN
e_hfe = (rhplp_otr)*470k/680/rtp
update_pins = 0
p.cnt > 0 or
e_hfe > p.hfe ?
lp_otr < 97 ?
rhp > 3400 ?
N
n.cnt = 0 ? or
e_hfe > n.hfe ?
p.hfe = c_hfe
p.uBE = hp1  tp1
update_pins = 1
update_pins = 1 ?
lp_otr < 97 ?
lp1 > 2000 ?
n.hfe = e_hfe
n.uBE = tp2  lpx
update_pins = 1
Part = FET
Typ = N_E_MOS
hp2 >lp2+250 ?
Y
c_hfe > n.hfe ?
p.ice0 = lp_otr/680
p.ices = vCEs / 680
savePresult
Part = FET
Typ = P_E_MOS
Typ = N_E_IGBT
n.hfe = e_hfe
n.uBE = tp2  lpx
update_pins = 1
680
H
T
470k
H
T
680
DInp
tpx
680
N
update_pins = 1 ?
tpx
470k
savePresult
680
H
T
L
H
T
L
Typ = P_E_IGBT
470k
DInp
680
saveNresult
n.gthvoltage = tpx
ThyristorCheck
hp3
hp4
680
680
680
hp2
T
680
T
L
Part = THYRISTOR
n.cnt = n.cnt + 1
n.uBE = tp2lp2
n.gthvoltage = hp1lp2
hpx
680
Ntype
Non conducting?
H
T
L
N
hpx
tpx
680
680
Switched
T
L
N
hpx
680
Fired
T
L
680
H
T
saveNresult
hpx
680
Cleared again
H
T
L
Y
N
Part = TRIAC
5.1.4
Measurement of Diodes
If current is detected with the pre-tests, the behavior of the part will be checked to be a diode. The
flow voltage with the 680  resistor must be between 0.15 V and 4.64 V . The flux voltage with
the 680  must be greater than 1.125 times the flux voltage with the 470 k resistor and sixteen
times the flux voltage with the 470 k must be greater than the flux voltage with the 680  resistor.
Additionally the afterward renewed measurement with the 470 k resistor should not have a higher
voltage than the previous measurement with the 680  resistor. I hope, that this behavior identifies
always a diode. The identification of a diode by no current flow in the opposite direction is not
possible with a inverse parallel diode. If only a single diode is detected, the residual current in
reverse direction is measured with the 470 k resistor at 5 V . The resolution is about 2 nA. If the
residual current is greater as 5.3 A (voltage at the 470 k is more than 2.5 V ), the measurement
68
is done with the 680  instead. Then the resolution is only about 1 A. Furthermore the capacity
in reverse direction is also measured for single diodes.
5.1.5
The following three tables shows results of different test probes with one ATmega8, a ATmega168
and a ATmega328 processor. The measurement of the inverse capacity value for the double diode
MBR4045PT is only possible with cooling. This will be caused by high residual current of this 40A
diode. Also the capacity value of the inverse base emitter diode of the germanium transistor AC128
can only be measured with cooling.
Diode Type
1N4148
Mega8@8MHz
Mega168 @8MHz
Diode, 715mV,
1pF
Diode, 665mV,
1pF
Diode, 619mV,
19pF
Diode, 538mV,
16pF
Diode, 650mV,
13pF
Diode, 1.96V, 5pF
2xDi, 743mV, 2.53V
Diode, 609mV,
5.15nF
Diode, 582mV,
256pF
Diode, 272mV,
0pF
Diode, 718mV,
0pF, 2nA
Diode, 672mV,
1pF, 4nA
Diode, 621V,
17pF, 12nA
Diode, 541mV,
14pF, 63nA
Diode, 655mV,
10pF, 6nA
Diode, 1.95V, 4pF
2xDi, 737mV, 2.52V
Diode, 611mV,
5.20nF, 0.39uA
Diode, 586mV,
255pF, 21nA
Diode, 277mV,
0pF, 2.2uA
Mega328 @8MHz
Diode, 715mV,
1pF, 4nA
1N4150
Diode, 666V,
2pF, 6nA
BA157
Diode, 615mV,
18pF, 12nA
BY398
Diode, 537mV,
15pF, 63nA
1N4007
Diode, 650mV,
13pF, 6nA
LED green
Diode, 1.95V, 4pF
ZPD2,7
2xDi, 733mV, 2.51V
BU508A B+E
Diode, 606mV,
5.25nF, 0.4uA
BU508A B+C
Diode, 587mV,
259pF, 19nA
AC128 B+E
Diode, 273mV,
0pF, 2.3uA
AC128 B+E
Diode, 349mV,
cooled
140pF, 0.57uA
MBR20100CT 2xDi, 337mV, 337mV 2xDi, 338mV, 338mV 2xDi, 336mV, 335mV
MBR20100CT
Diode, 337mV,
Diode, 339mV,
Diode, 337mV,
345pF
351pF, 29nA
350pF, 25nA
MBR4045PT
Diode, 243mV,
Diode, 233mV,
Diode, 235mV,
cooled
1.80nF
1.94nF, 1.7uA
1.95nF, 1.8uA
SK14
Diode, mV,
Diode, mV,
Diode, 263mV,
0pF
pF, nA
0pF, 0.57uA
SK14
Diode, mV,
Diode, mV,
Diode, 334mV,
cooled
nF
pF, nA
88pF, 4nA
SF38G
Diode, 519mV,
Diode, 521mV,
Diode, 516mV,
107pF
105pF, 2nA
106pF, 2nA
Table 5.2. measurement results of diode testing
69
Transistor
Type
BU508A
2N3055
BC639
BC640
BC517
BC516
BC546B
BC556B
AC128 (Ge.)
BUL38D
parasitic
BRY55/200
MAC97A6
Typ
Mega8
commoncollector
NPN
B=9, 601mV
NPN
B=20, 557mV
NPN
B=148, 636mV
PNP
B=226, 650mV
NPN
B=23.9k, 1.23V
PNP
B=75.9k, 1.21V
NPN
B=285, 694mV
PNP
B=304, 704mV
PNP
B=63, 191mV
NPNp
B=37, 627mV
PNPn
B=11, 654mV
Thyrist.
0.84V
Triac
0.92V
Mega328
B=9, 597mV
B=21, 550mV
B=172, 629mV
B=176, 609mV
B=24.8k, 1.22V
B=76.2k, 1.20V
B=427, 687mV
B=254, 668mV
B=59, 191mV
B=41, 617mV
B=81, 543mV
0.81V
0.90V
Mega328
commoncollector
B=9, 598mV
B=21, 550mV
B=172, 629mV
B=171, 655mV
B=25.1k, 1.22V
B=76.2k, 1.20V
B=427, 687mV
B=235, 709mV
B=57, 193mV
B=40, 624mV
B=10, 656mV
0.81V
0.90V
Mega328
commonemitter
B=4, 484mV
B=6, 442mV
B=158, 605mV
B=177, 608mV
B=764, 1.23V
B=760, 1.23V
B=369, 683mV
B=255, 668mV
B=43, 117mV
B=36, 562mV
B=83, 541mV
0.82V
0.90V
70
Transistor
Type
Mega8@1MHz
Mega168 @8MHz
Mega328 @8MHz
Original Version
Version 1.10k
Version 1.10k
Markus F.
AC128
PNP, B=52, 279mV
PNP, B=59, 184mV
PNP, B=59, 191mV
AC116-65
PNP, B=505, 378mV
PNP, B=72, 146mV
PNP, B=72, 149mV
AC116-145 PNP, B=485, 294mV PNP, B=146, 161mV PNP, B=146, 163mV
AC176-65
NPN, B=98, 235mV
NPN, B=58, 94mV
NPN, B=56, 96mV
GC122
PNP, B=84, 368mV
PNP, B=55, 117mV
PNP, B=56, 117mV
GC301
PNP, B=48, 289mV
PNP, B=39, 184mV
PNP, B=39, 188mV
AD161
NPN, B=360, 230mV NPN, B=296, 126mV NPN, B=298, 128mV
AD162
PNP, B=2127, 280mV PNP, B=89, 107mV
PNP, B=89, 107mV
Table 5.4. Measurement results of bipolar junction germanium transistors
In the table 5.5 the results of some field-effect transistor measurements are shown. One measured
parameters of the E-type MOS types is the gate-source voltage, by which the digital input of the
ATmega connected to the 680  drain resistor changes the state. The other parameter is the gate
capacity value. For very fast change of the gate voltage due to a small gate capacity, the detected
voltage is slightly inaccurate. With the BS250 the Voltage changes from 2.6 V to 2.5 V , if you connect
a additional 10 nF capacitor to the gate-source. For JFET transistors often the characteristic current
Idss is specified, the current in the drain when the gate-source voltage is 0 V . Here, however, the
current is given by a 680  load resistance at the source side of the JFET. The load resistor generates
a reverse voltage Vgs, which is also shown. Due to the symmetrical design of the JFET transistors,
the drain and source can not be distinguished.
71
Mega8@8MHz
Transistor
Type
ZVNL120A
N-E-MOS
D, 1.6V, 147pF
IRF530N
N-E-MOS
D, 3.6V, 1.55nF
BS170
N-E-MOS
D, 2.6V, 78pF
IRL3803
N-E-MOS
D, 2.3V, 9.81nF
IRFU120N
N-E-MOS
D, 4.2V, 909pF
BUZ71A
N-E-MOS
D, 3.2V, 714pF
ZVP2106A
P-E-MOS
D, 3.2V, 122pF
IRF5305
P-E-MOS
D, 3.6V, 2.22nF
BS250
P-E-MOS
D, 2.6V, 53pF
IRFU9024
P-E-MOS
D, 3.5V, 937pF
J310
N-JFET
3.1mA Vgs=2.2V
Idss=24-60mA
2N5459
N-JFET
2.1mA Vgs=1.5V
Idss=4-16mA
BF256C
N-JFET
3.4mA Vgs=2.4V
Idss=11-18mA
BF245A
N-JFET
1.1mA Vgs=.75V
Idss=2-6mA
BF245B
N-JFET
2.5mA Vgs=1.7V
Idss=6-15mA
BF245C
N-JFET
3.9mA Vgs=2.7V
Idss=12-25mA
J175
P-JFET
3.2mA Vgs=2.2V
Idss=7-60mA
2N5460
P-JFET
0.78mA Vgs=0.54V
Idss=1-5mA
BSS139
N-D-MOS
1.7mA Vgs=1.2V
BSS169
N-D-MOS
2.6mA Vgs=1.8V
GP07N120
N-E-IGBT C=3.81nF Vt=4.2V
Mega168 @8MHz
Mega328 @8MHz
D, 1.5V,141pF
D, 3.6V, 1.54nF
D, 2.6V, 68pF
D, 2.3V, 9.71nF
D, 4.2V, 913pF
D, 3.2V, 708pF
D, 3.2V,115pF
D, 3.6V, 2.22nF
D, 2.6V, 43pF
D, 3.6V, 945pF
3.1mA Vgs=2.2V
D, 1.5V, 140pF
D, 3.6V, 1.54nF
D, 2.6V, 68pF
D, 2.3V, 9.74nF
D, 4.2V, 911pF
D, 3.2V, 705pF
D, 3.2V, 116pF
D, 3.6V, 2.22nF
D, 2.6V, 44pF
D, 3.5V, 933pF
3.1mA Vgs=2.2V
2.1mA Vgs=1.5V
2.1mA Vgs=1.5V
3.4mA Vgs=2.4V
3.4mA Vgs=2.4V
1.1mA Vgs=0.75V
1.1mA Vgs=0.75V
2.5mA Vgs=1.7V
2.5mA Vgs=1.7V
3.9mA Vgs=2.7V
3.9mA Vgs=2.7V
3.2mA Vgs=2.2V
3.2mA Vgs=2.2V
0.77mA Vgs=0.54V
0.78mA Vgs=0.54V
72
5.2
Resistor Measurement
Each resistor is measured with four different types of measurement in one current direction. The
same resistor ist also tested with the same four measurement types in the other current direction.
The measurement in the opposite direction is only used to identify a resistor. If mismatch between
both measurements is too big, its not a resistor.
5.2.1
The measurement of a unknown resistor Rx is done in two ways with the build in precision 680
resistors. The diagram of this measurements for test pin 1 (TP1) and test pin 3 (TP3) are simplified
shown in figure 5.11 and figure 5.12 as a example of the six choises of probe combinations.
GND
22
19
22
19
22
19
22
19
22
19
ADCMUX
TP1
Rx
PB4
TP3
PB5
R6
PC2
680
R1
R2
PB1
470k
PB0
680
PC0
470k
ADCMUX
R5
22
19
VCC
22
19
22
19
22
19
22
19
22
19
GND
ADCMUX
TP1
Rx
TP3
PB4
PB5
R6
PC2
470k
R2
PB1
470k
R1
PB0
680
PC0
R5
ADCMUX
680
22
19
VCC
73
The V symbol within the circle marks the ports used for voltage measurement. In both configurations the value of resistor Rx can be computed with the known resistor values and the measured
voltages, if the relation of resistor Rx and the 680 is not too high. The theoretical voltage gradient
is shown in figure 5.13, where resistor values are shown in logarithmic scale.
5000
voltage / mV
4000
3000
PC2, type 1
PC0, type 2
2000
1000
0
100m
10
100
1k
resistor Rx / Ohm
10k
100k
74
PC2, type 1
voltage / mV
voltage / mV
200
195
190
185
180
175
170
165
160
155
150
145
140
135
130
0
4
5
6
7
resistor Rx / Ohm
4850
4845
4840
4835
4830
4825
4820
4815
4810
4805
4800
4795
4790
4785
4780
10
PC0, type 2
4
5
6
7
resistor Rx / Ohm
10
5.2.2
The next figures 5.15 and 5.16 shows the same measurement procedure for the measurement with
the precision 470k resistors. Because the 470k is very big in relation to the port resistor values
22 and 19, the port resistor values are ignored for the computing of the resistor value Rx.
For both measurement types with the 470k resistors only one Voltage is measured, because the
current is so low, that no voltage difference at the internal port resistors of the ATmega can be
measured (as expected). The theoretical voltage gradient is shown in figure 5.17 where the resistor
values are again shown in logarithmic scale. The theoretical gradient in this diagram ends at 100M ,
but the resulting value of the Tester is limited to 60M , otherwise the Tester assumes that no resistor
is connected. The weighted average of both measurement types is taken as result with the same rules
described for the measurements with the 680 resistors. For all ATmega processors I had found,
that the measured results with the 470k resistors are more exactly, if a constant offset of 350 will
be added. This offset can be adjusted with the RH OFFSET define in the config.h file.
22
19
22
19
22
19
22
19
22
19
22
GND
ADCMUX
ADCMUX
TP3
75
R6
Rx
PB5
470k
TP1
PB4
R5
PC2
680
R2
PB1
470k
PB0
R1
PC0
680
19
VCC
22
19
22
19
22
19
22
19
22
19
22
19
VCC
GND
ADCMUX
Rx
TP3
PB5
R6
TP1
PB4
470k
PC2
680
R2
R1
PB1
470k
PB0
680
PC0
R5
ADCMUX
5000
voltage / mV
4000
3000
PC2 type 3
PC0, type 4
2000
1000
0
10k
100k
1M
10M
resistor Rx / Ohm
100M
5.2.3
Figure 5.18 shows the relative errors of the resistor measurements with three ATmega8 microcontrollers. Additionally some results with the original software of Markus F. with one ATmega8 are
shown as Mega8orig in this figure. More measurements results with ATmega8A and ATmega8L
are shown in figure 5.19a and 5.19b. Figure 5.20 shows the same measurements with a ATmega168
microcontroller. Mega168 are the results without the AUTOSCALE ADC option, Mega168as are
the same measurements with the AUTOSCALE ADC option. With the ATmega168 microcontroller
it seems to be possible, that measurements of resistors in the range from 20 to 20M  can be measured with a tolerance of 1%. For Measurements below 100 you should keep in mind, that any
measurement probe with wire have a resistance too. It is better to connect the resistor directly to
the terminal pins. If this is not possible, subtract the resistance value of the shortened probe. For
example, if your Resistor have a printed value of 30, your tester shows a value of 30.6 and the
two probes shortened have a value of 0.5, then your resistor has been measured with 30.1. Below
a resistance value of 10 one resolution step results to a error of more than 1%!
76
Mega8-1
Mega8-2
Mega8-3
Mega8orig
Error / Percent
3
2
1
0
-1
-2
-3
-4
-5
1
10
100
1k
10k 100k 1M
Resistor value / Ohm
10M
100M
5
4
3
Mega8L-7
Mega8L-8
Mega8L-9
4
3
Error / Percent
Error / Percent
Mega8A-4
Mega8A-5
Mega8A-6
1
0
-1
-2
2
1
0
-1
-2
-3
-3
-4
-4
-5
-5
1
10
100
1k
10k 100k 1M
Resistor value / Ohm
10M
100M
10
100
1k
10k 100k 1M
Resistor value / Ohm
77
10M
100M
Mega168
Mega168as
Error / Percent
3
2
1
0
-1
-2
-3
-4
-5
1
10
100
1k
10k 100k 1M
Resistor value / Ohm
10M
100M
78
3
2
m168a-4
m168a-5
m168a-6
m168a-4
m168a-5
m168a-6
4
3
Error / Percent
1
0
-1
-2
2
1
0
-1
-2
-3
-3
-4
-4
-5
-5
1
10
100
1k
10k 100k 1M
Resistor value / Ohm
10M
100M
10
100
1k
10k 100k 1M
Resistor value / Ohm
m168p-7
m168p-8
m168p-9
m168p-7
m168p-8
m168p-9
4
3
Error / Percent
Error / Percent
m168-1
m168-2
m168-3
m168-1
m168-2
m168-3
2
1
0
-1
-2
-3
-4
-5
1
10
100
1k
10k 100k 1M
Resistor value / Ohm
10M
100M
Figure 5.22. Relativ error for resistor measurements with three ATmega168P
79
10M
100M
3
2
m328p-13
m328p-14
m328p-15
m328p-13
m328p-14
m328p-15
4
3
Error / Percent
Error / Percent
m328-10
m328-11
m328-12
m328-10
m328-11
m328-12
1
0
-1
-2
2
1
0
-1
-2
-3
-3
-4
-4
-5
-5
1
10
100
1k
10k 100k 1M
Resistor value / Ohm
10M
100M
10
100
1k
10k 100k 1M
Resistor value / Ohm
80
10M
100M
5.3
Measurement of Capacitors
The measurement of capacitor values are done as separate task by measurement of load time after all
other measurements. The original software of Markus F. did this with a program loop, which reads
the corresponding digital input pin until a switch occured and count the loop cycles. This has the
handicap, that the resolution of time measurement is limited by the time consumption of one loop
cycle. This usually was done in all six combinations for all three probe pins. The actual software
uses two different ways to get the load time in only three combinations for the three probe pins. The
positive side is now always the higher probe number. Only if capacity is measured parallel with a
diode, the polarity can be in the other order.
5.3.1
Discharging of Capacitors
You should always discharge the capacitor before connecting it to the tester. The tester additionally
discharge the capacitor before any measurement. If the voltage is below 1300mV , the capacitor is
shortened by the output pins of the connected ADC port (Port C). I believe that this is legal because
every output port has a built in resistance of about 20. The data sheet Figure 149 (page 258) [2]
shows voltage drop of output pins up to 2V . Of course I can not guaranty, that no damage can
occur. I have tested the function with big capacitors of more than 15mF many times and I have
never noticed any problem. The current should be below the specified limit of 40mA and is reduced
fast by discharging. Off course damage can occur if you do not discharge a (high voltage) capacitor
before connecting it to your tester.
5.3.2
One side of the capacitor is connected to GND. The other side of the capacitor is connected with
the 680 resistor to VCC for a period of 10ms. Afterwards this probe pin is switched to Input (High
Impedance). After this 10ms current pulse the voltage of the capacitor is measured without any
current. If the voltage has not reached a minimal value of 300mV , the load pulse is repeated up to
499 times. If after 127 pulses a minimum voltage of 75mV is not reached (about 2s), further load
is stopped, because never the 300mV can be reached with the remaining load pulses. Figure 5.24
shows the three phases of measuring the capacity value of a capacitor. The value of the capacity is
then computed with the count of load pulses and the reached load voltage from a table. The table
contains the factors to get the capacity in nF units from load time and the reached voltage with a
spacing of 25mV . Interim value of voltage will be interpolated.
81
22
19
22
19
GND
22
19
22
19
22
19
22
19
VCC
<1.3V
ADCMUX
Cx
TP3
PB5
R6
R2
470k
R1
TP1
PB4
470k
PC2
PB1
680
PB0
680
PC0
R5
ADCMUX
GND
22
ADCMUX
PB4
Cx
TP3
R6
TP1
PB5
470k
PC2
680
470k
PB1
R1
680
PB0
R2
PC0
R5
ADCMUX
19
22
19
22
19
22
19
22
19
22
19
VCC
22
19
22
19
22
19
22
19
22
19
22
GND
ADCMUX
ADCMUX
TP3
PB5
470k
Cx
R5
TP1
PB4
R6
PC2
PB1
470k
R1
680
PB0
R2
PC0
680
19
VCC
Figure 5.24. discharge a capacitor and load with 10ms load pulses until voltage reach a value of
300mV
As a result of the low load voltage, the measurement is much faster than the initial software
version, because this advantage works also on discharging. So bigger capacitors can be measured.
Furthermore a diode, which is parallel connected to the capacitor dont disturb the measurement
in most cases, because the flux voltage of most diodes is not reached. Beginning with software
version 1.12k a trickery is used to measure the residual voltage of a capacitor before the capacity
measurement. Depending on the previous history of the capacitor the residual voltage can be positive
or negative. Negative voltages can not be measured with the ADC. For that reason the voltage of
the negative test pin is raised with the 680 resistor to about 132mV as shown in figure 5.25. With
the difference of the voltages measured at both sides of the capacitor the residual voltage can be
82
build with any polarity. The voltage of the positive test pin remains positive in any case, even if the
capacitor have a negative residual voltage of some mV.
22
19
22
19
22
19
22
19
22
19
GND
ADCMUX
Cx
TP3
PB5
470k
R2
TP1
PB4
R6
PC2
PB1
470k
R1
680
PB0
R5
ADCMUX
PC0
680
22
19
VCC
83
5.3.3
If the first 10ms load pulse has overloaded the capacitor, another technique of measurement is used.
The ATmega processor has a build in 16-Bit counter, which can operate at the full clock rate (1M Hz
or 8M Hz). This counter has also the feature to save his counter value by a external event. This
event can be built by the output of the comparator. The comparator can operate with any ADC
input pin and the band gap reference. Figure 5.28 shows a simplified diagram of the measurement
situation. So I discharge the capacitor, prepare the comparator to the proper pin input, start the
counter at 0 and start immediately the charging of the capacitor with one side connected to GND
and the other side connected with the 470k resistor to VCC. Now I check within a program loop,
if the counter flags signals a overflow event or a input capture (external) event. I count the overflow
events until I detect the input capture event. In this case I stop the counter and check if I must
count a additional overflow, because the counter cant be stopped by the input capture event.
The input capture counter and the overflow counter built together the total time, from which
we can get the capacity with a factor. The actual software can use a table with the theoretical
dependency of the load time in respect to the comparator voltage. The table is spaced in 50mV
steps and will be interpolated according to the actual reference voltage. This table will only be
acticated with the Makefile option WITH AUTO REF. From the build capacity value I subtract a
predefined experimental find out constant or a value found by the last selftest with AUTO CAL
option to eliminate the zero offset. The zero offset may vary with printed board type, the used
test equipment or processor. The selftest with AUTO CAL option will find out your zero offset
automatically.
84
I noticed that the reference voltage is permanently somewhat to low, so that you can choose an
offset with the Makefile option REF C KORR. After calibration with the AUTO CAL option , the
REF C KORR will only be a offset to the measured difference voltage between loaded capacitor and
internal reference. The measured reference voltage will then be corrected (added) by your value (mV
units). If option WITH AUTO REF is not used, the reference voltages of ATmega8, ATmega168
and ATmega328 are applied as noted in the data sheets [2] [3]. A sample measurement of this type
is shown in figure 5.29. The measurement time for the 22F capacitor is above 2.6s because the
470k is used for charging. But discharging is in this case much faster than charging.
Bandgap
Reference
Clock
Control
Logic
ACBG
AIN0
Clear
Direction
TOV1
Timer Counter
TCNT1
DATA BUS
Count
Noise
Canceler
AIN1
From ADC Multiplexor
ACME
Edge
Detector
ICR1
VCC
TP3
Cx
ICFn
470k
R6
TP1
5.3.4
The radio amateur Pieter-Tjerk (PA3FWM) has integrated the measurement capability for very
small capacity values (< 100pF) with the sampling technique. The conversion period of the ADC
is in fact too long for sampling a fast signal directly. But the voltage of the input signal is hold at
a specified time of the conversion cycle, the Sample and Hold (SH) time. The ADC need 13 clock
cycles for a total conversion and the ADC clock is build by dividing the processor clock by 128 or
64. The input voltage is fixed at exactly ADC clock number 1.5 for continuous cycles. If the input
signal can be generated again and again, we can shift the sample time of the ADC from one to the
next signal repetition, so that we get a sample sequence of the fast signal. A normal ADC cycle
takes 13x64 = 832 clock cycles with a 8 MHz processor clock. If we repeat the input signal with a
831 clock cycle, a uninterrupted ADC (free rum mode) would sample the signal one processor clock
tick later for every following signal repetition. We must make sure with this method, that the first
ADC sampling of the signal is done at the requested starting time. The time of the following ADC
samples would be shifted by one processor clock tic later for every next signal repetition. If the signal
can be repeated exactly, the combined signal of many periods is the same, which would be sampled
and converted directly with a ADC running with the processor clock (8 MHz). Figure 5.30 shows
the principle of sampling a ten times repeated signal to get 10 samples (SH0 - SH9). In reality the
relativ time shift of successive samples is much smaller than shown here.
U
t
SH0
SH1
SH2
SH3
SH4
SH5
SH6
SH7
SH8
SH9
Pieter-Tjerk has optimized his function for a 16 MHz operation. In this configuration you will get
a resolution of 0.01 pF. For the 8 MHz operation the ADC will run at the half speed for getting the
above-mentiored disturbances at the same data points compared to the 16-MHz operation. The loss
of resolution with the 8 MHz operation will be irrelevant for most users and the additional testing
time with the slower ADC in this mode is tolerable too.
5.3.5
The series resistance ESR [8] is a good indicator for the aging of electrolytical capacitors for example.
The figure 5.31 shows a equivalent circuit of a capacitor. The resistor Rp represents the leakage
resistance of the capacitor, ESL the equivalent series inductivity and the resistance ESR represents
the equivalent series resistance.
Rp
ESR
ESL
ESR / Ohm
10
6V
16V
35V
63V
0.1
0.01
1
10
100
1000
Capacity / uF
10000
100000
Figure 5.32. ESR data from the Panasonic data sheet of the series FC
87
ESR / Ohm
6V
16V
35V
63V
0.1
0.01
10
100
1000
Capacity / uF
10000
Figure 5.33. ESR data from the Panasonic data sheet of the series FR
ESR / Ohm
10
FC 25V
FR 25V
0.1
0.01
10
100
1000
Capacity / uF
10000
Figure 5.34. Comparison of the ESR data from series FC with series FR
There is no simple way to measure the ESR with a frequency of 100 kHz with the ATmega
hardware, because neither the ADC can sample a so high input frequency, nor the existing circuit can
support with a 100kHz signal. At next there will be introduced two methods for the measurement
of the ESR, which both manage on the existing circuit. Both methods use a rectangular signal for
the measurement, so that the results will never be the same with the values measured with sinusoidal
88
signal. With the first method the measured values are close to those values, which are measured with
a 1kHz signal. But the second method has the advantage, that the zero value can be determined
with shorted test pads and that additionally the measured ESR is more close to the value measured
with 10kHz signal. Currently I have no idea for a measurement method, which can produce a ESR
value close to the value of a 100kHz measurement.
The following table 5.6 should show the dependency of the ESR results from measurement frequency. All capacitors without the 47F capacitor are from the same FC series of manufactor
Panasonic. The reference values are measured with a Peaktech 2170 LCR meter. All results of the
TransistorTester are measured with the method 2 of subchapter 5.3.7 . Capacitors with big capacity
values are difficult to measure with higher frequencies like 100kHz because the inductance ESL make
trouble.
Capacitor
1uF / 50V
2.2uF / 50V
4.7uF / 50V
4.7uF / 50V
10uF / 50V
22uF / 10V
47uF / 63V
Data sheet
100 kHz
2.4
1.8
1.3
1.3
1.3
2.0
?
PeakTech Peaktech
100 kHz
10 kHz
1.27
1.75
1.07
1.34
1.19
1.40
1.19
1.40
1.26
1.45
1.52
1.76
0.46
0.50
5.3.6
If the measured capacitor has a capacity of more than 0.45F , the tester will try to measure the
series resistance too. For a capacity of more than 3.6F the normal clock rate of 125kHz for the
Analog-Digital converter is used. For lower capacities the higher clock rate of 500kHz is used to
accelerate the measurement. The accuracy of the ADC results will be more worth by the higher
clock rate, but this could be accepted by the higher ESR values of capacitors with lower capacity.
Otherwise the measurement of ESR with this method is not possible for a capacity of less than 1.8F
at the normal clock rate of 125kHz.
Strictly speaking the ESR of a capacitor depends on the operating frequency and temperature.
Usually the value measured with sine wave-form signal of 100kHz is denoted in the data sheets. This
measurement can not be done with the ATmega without external equipment. With the subsequent
written method the measurement frequency with the standard ADC clock rate will be below 640 Hz
with nearly rectangular signal. With 500kHz ADC clock rate the measurement frequency will be
2400 Hz. To get the value of the equivalent series resistance, the voltage of both connections will
be measured during loading in one direction with the ADC internal reference voltage (1.1V ). After
the measurement the load current will be switched off and the voltage of the capacitor is measured
again without the current. If this voltage is below 3mV , the sequence of measurement is repeated.
The figure 5.35 shows the corresponding circuits.
89
GND
22
ADCMUX
PB4
Cx ESR TP3
R6
TP1
PB5
470k
PC2
680
470k
PB1
R1
680
PB0
R2
PC0
R5
ADCMUX
19
22
19
22
19
22
19
22
19
22
19
VCC
22
19
22
19
22
19
22
19
22
19
22
GND
ADCMUX
Cx ESR TP3
PB5
R6
TP1
PB4
470k
470k
R1
680
PC2
PB1
PB0
R2
PC0
R5
ADCMUX
680
19
VCC
90
Figure 5.36. Voltage curve of a 4.2F capacitor during the ESR measurement
Figure 5.37. Voltage curve of a 2.2F capacitor during the ESR measurement
The accuracy of the ESR measurement is not very high by different reasons:
1. The voltage measurement at both pins of the capacitor can not be done at the same time, the
only way is to do it in sequence. In the interim time between both measurements the load
current has changed due to the charge of capacitor. The program tries to compensate this fact
with a capacity dependent correction of the low side voltage.
2. The ADC takes the measurement voltage after 1.5 clock ticks after the start of conversion. The
conversion beginns with the rising edge of the ADC-clock, if the start bit is set. If the charge
current will be switched off to early, the ADC takes the wrong voltage for the measurement
with current. If the charge current will be switched off to late, the capacitor will take more
electric charge, than that of the corresponding measurement with load current. This will cause
a too high voltage of the measurement without current. But it is difficult to switch off the
current at the right time by software.
3. The port output resistance is used as a reference value by this measurement method, but this
resistance value is not exacly known too.
91
4. The resolution of the ADC is not sufficient to get a resolution of resistance of 0.01. To get
the best avaiable resolution of ADC, the internal reference (1.1V ) is used for all measurements.
The resolution deficit will be attenuated by accumulating a big number of single measurements
too.
5. The switching of ports can not be exactly synchronized to the ADC clock with polling of
conversion done.
Anyway the results seems to be practical, as shown with the following figure 5.38. The ESR
values of the same part measured with the Transistortester vary more than the values measured with
the LCR meter. The ESR values from the LCR meter are measured with a frequency of 1kHz or
are interpolated for little capacities to 2.4kHz. You must respect the quality of all connection parts.
The used cable connections can cause a higher measured resistance value. The plug connectors can
also result a higher resistance value. The LCR meter has the advantage of the used Kelvin terminals.
Only one capacitor with a capacity below 1F was a 500nF ceramic type, all others were plastic film
capacitors. The only electrolytical capacitor of the test series below 9F was a 2.2F capacitor.
7
328p
328
168p
168a
168
LCR
ESR / Ohm
5
4
3
2
1
0
100n
1u
10u
Capacity value / F
100u
1m
5.3.7
From beginning with software version 1.07k the ESR measurement way is changed to a new measurement method. The different measurement steps are shown in figure 5.40. The difference to
the previous way is that the period of current flow through the capacitor is essential shorter. The
capacitor is preloaded with a half pulse to the negative direction and is than loaded in a cyclic way
in both direction. The timing of the load pulse is so selected, that the middle of the load puls at
sample 4 and 8 is pointed to the sample and hold time of the ADC (2.5 clock tics after start of
ADC). A complete measurement cycle is shown in figure 5.39. The sums of 255 measurement cycle
results is used for getting a result with adequate resolution. A continuing charge of the capacitor
in any direction is avoided by the same charge and discharge pulse length and the same circuit. By
measuring the reference voltage the capacitor remains currentless. By that this measurement are
not time critital. It is only assumed, that the capacitor hold the voltage until the next charge or
discharge pulse begins.
92
ADC busy
Sample1
Sample2
Sample3
Sample4
Sample5
Sample6
Sample7
Sample8
Current
Figure 5.39. Timing of a measurement cycle for the new ESR-measurement way
93
22
19
22
19
22
19
22
19
22
19
GND
ADCMUX
PC2
TP1
PB4
Cx ESR TP3
PB5
R6
R2
R1
470k
PB1
680
PB0
680
PC0
470k
ADCMUX
R5
22
19
VCC
GND
22
ADCMUX
PB4
Cx ESR TP3
R6
TP1
PB5
470k
PC2
680
470k
PB1
R1
680
PB0
R2
PC0
R5
ADCMUX
19
22
19
22
19
22
19
22
19
22
19
VCC
22
19
19
22
ADCMUX
R6
Cx ESR TP3
PB5
470k
R2
R1
TP1
PB4
680
PC2
PB1
470k
PB0
680
PC0
R5
ADCMUX
22
GND
19
22
19
22
19
22
19
VCC
GND
22
19
22
19
ADCMUX
94
PB5
470k
Cx ESR TP3
680
R2
TP1
PB4
R6
PC2
PB1
470k
R1
PB0
680
PC0
R5
ADCMUX
22
19
22
19
22
19
22
19
VCC
Due to the shorter load puls not only the ESR of capacitors with lower capacity can be measured,
but this way of measurement can also be used for the measurement of resistors with little resistance,
if they dont have a detectable inductance. By doing that, a resolution of 0.01 for this resistors
can be achieved. Also the zero resistance can be detected by the calibration part of the selftest
for all three test pin combination. You should keep in mind, that stable plug sockets or clamping
connectors are essential for stable results. The measurement periode is about 900s, which results
to a frequency of about 1.1kHz. Because the load pulse is very short, the measurement result is
comparable to measurements with 10kHz. A measurement example with a 10F foil capacitor, once
measured alone and once measures with a 2.7 series resistor is shown in figure 5.41. You can see
the effect of the additional resistance by comparing both diagrams. You can see also, why the ADC
measurement (SH) should point to the middle of the load pulse. With big capacity values the load
current is nearly stable during the total pulse length, so you will get the middle voltage at the middle
time of the load pulse. With lower capacity values you will get a significant difference, which can be
compensated by the known capacity value.
Figure 5.41. Voltage curve of a 10F capacitor during new ESR measurement
By using the 27s long charge pulses the ESR of capacitors above 180nF can be determined. For
measuring of capacitors with lower capacity the current pulse is shortened to 8s for version 1.11k.
The figures 5.42 show the voltage curve of a 2.2F capacitor without and with a 2.7 series resistor.
95
Figure 5.42. Voltage curve of a 2.2F capacitor during new ESR measurement with 8s charge
pulses
Because you can not see the sample and hold time of the ADC in the figures 5.42, the voltage
curve is shown zoomed in figures 5.43. The sample and hold time is approximately in the middle of
the screen picture.
Figure 5.43. Zoomed voltage curve of a 2.2F capacitor during new ESR measurement with 8s
charge pulses
The measurement results of the new ESR measurement method is shown in figure 5.44. The
ESR values are different from the results shown for the previous mesurement procedure in figure 5.38
because the ESR is frequency dependence of the ESR. The reference values are determined with a
LCR meter at a measurement frequency of 10kHz.
96
328p
328
168p
168a
168
LCR
ESR / Ohm
5
4
3
2
1
0
100n
1u
10u
Capacity value / F
100u
1m
LCR-100Hz
LCR-1kHz
LCR-10kHz
LCR-100kHz
TTester
ESR / Ohm
10
1
0.1
0.47u/100V
1u/100V
1u/50V
2.2u/100V
2.2u/50V
3.3u/100V
4.7u/63V
4.7u/50V
10u/50V
22u/10V
22u/63V
33u/63V
47u/63V
100u/63V
220u/63V
470u/35V
500u/3V
0.01
0.2
m168
m168a
m168p
m328
m328p
0.15
difference / Ohm
0.1
0.05
0
-0.05
-0.1
-0.15
-0.2
0
6
8
10
Resistor value / Ohm
12
14
5.3.8
With the measurement of capacitors with big capacity values the voltage loss after the loading is
analysed. The reached load voltage is lost with electrolytic capacitors after a short periode. This
voltage loss can be caused by a parallel connected resistor. But I assume, that this voltage loss
of electrolytic capacitors is caused by a internal load dispersion directly after the load pulse. By
loading the capacitors with the 470k resistor, as it is done for little capacity values, this dispersion
is already done after switching off the current. No voltage loss is detectable for this case. But if you
load the same capacitor with a short current pulse, you can also detect the voltage loss for capacitors
with lower capacity. The same effect with lower loss can also be noticed for ceramic type capacitors.
I have noticed, that capacitors with more than some % voltage loss are suspect. Especially noticable
with respect to the voltage loss are older paper type capacitors, which are for other measurement a
problem too. Some measurement examples will be shown in the following table.
98
capacitor
type
paper
paper
unknown
foil
paper
foil
paper
ceramic
foil
Nenncapacity
4700pF
PeakTech
Voltcraft PeakTech TransistorLCR 2170
M2650-B
3315
Tester
6.75-10.36nF 8.00nF
25.40nF
10.71nF
Q=2.5-32
Vloss=11%
6800pF 9.40-11.40nF 10.41nF
23.30nF
11.65nF
Q=5-25
Vloss=5.0%
4700pF 5.85-6.33nF
6.12nF
6.90nF
6225pF
Q=16-87
Vloss=1.7%
7870pF 7.86-7.87nF
7.95nF
7.95nF
7872pF
Q= >1540
Vloss=0%
22000pF 37.4-57.5nF
52.8nF
112nF
118.5nF
Q=2.5-32
Vloss=12%
22600pF 22.4-22.5nF 22.57nF
22.69nF
22.54nF
Q= >1540
Vloss=0%
100nF
144-256nF
177nF
318nF
529.7nF
Q=2.6-28
Vloss=12%
100nF
97.7-102nF
103.7nF
103.3nF
103.1nF
Q=90-134
Vloss=0.1%
100nF
98.0-101nF
101.4nF
102.2nF
101.6nF
Q=58-700
Vloss=0%
In this table you will find, that the capacity of all foil type capacitors can be measured by all
intruments with good precision. The capacity values and the quality factor Q of the PeakTech LCR
meter are minimum and maximum values of the measurements in the frequency range 100Hz to
100kHz. At all examples in the table the voltage loss Vloss of the TransistorTester is big, if the
capacitors have a low quality factor. Only in this case the differences of the capacity measurement
results are also big. The TransistorTester can only determine the voltage loss, if the measured
capacity is more than 5000pF .
5.3.9
The separate capacity measurement and the afterwards measured ESR is only available for ATmega
with sufficient memory with the handling dialog. This way of measurement is usefull for measurement
of capacitors in the circuit without desoldering. Please take care, that all capacitors of the printed
board are discharched before starting any measurement! To realize the measurement in the soldered
state, the measurement voltage is hold to a low level of a little above 300mV only. In addition to that
the measurement is only done with the 680 resistor to prevent a big effect of connected components
on the printed board. To enable the measurement of capacitors with little capacity value, the first
load puls is only 200s short. If the loaded voltage let expect, that the 300mV would not be reached
with a load pulse of 2ms, the next load pulse is done with 2ms length. When the capacity value of
the measured capacitor is very high, the voltage grow is still low with the 2ms pulse. In this case
the next load pulse(s) will be done with 20ms length. If the loaded Voltage grow near to 300mV ,
the shorter load pulses will be used again. The total time of load pulses is added and after the
load voltage has passed over 300mV , the capacity value is computed from load time and the loaded
voltage. With this method capacity values of a little below 2F can be measured. The upper limit
for the capacity values is given with the restricted load time of 2.5s to about 50mF . If the capacity
value is successfully measured, the ESR value of the capacitor is measured with the method already
described in section 5.3.7. The result is shown only short and then the next measurement is started
immediately. The series of mesurement is stopped after 250 measurements or after pressing the start
key. After finishing the measurements the program returns to the handling dialog.
99
5.3.10
The results of my capacity measurements are shown in figure 5.47 for three ATmega8 processors.
Additionally some values of original software are shown with a correction factor of 0.88 (-12%). Other
measurement results of different ATmega8 versions are shown in figure 5.48a and 5.48b. The results
of the measurement of the same capacitors for a ATmega168 is shown in figure 5.49. The base for
the error computing are the measurement results of a PeakTech 2170 RCL-meter, not the printed
value of the parts. A part of the relative high measurement difference is caused by the too high
measurement frequency of the RCL-meter for big electrolytical capacitors. On the other side the bad
quality factor of the electrolytical capacitors may cause another percentage.
10
Error / Percent
Mega8-1
Mega8-2
Mega8-3
orig
6
4
2
0
-2
10p 100p 1n
Error / Percent
10
Mega8A-4
Mega8A-5
Mega8A-6
8
Error / Percent
10
6
4
2
0
Mega8L-7
Mega8L-8
Mega8L-9
6
4
2
0
-2
10p 100p 1n
-2
10p 100p 1n
100
10
Mega168
Mega168as8
Error / Percent
8
6
4
2
0
-2
10p 100p 1n
Multimeter
LCR
Mega168as
Error / Percent
4
3
2
1
0
-1
-2
-3
-4
10p 100p 1n
Figure 5.50. Comparison of capacity measurement results of Multimeter, LCR-meter and ATmega168
The differences of measurements of three different ATmega168 processors are shown in figure 5.51a
101
. In this case the results of the LCR meter is taken as base of comparison. The same results of
three different ATmega168A processors are shown in figure 5.51b and three different ATmega168PA
processors are shown in figure 5.52. The results of three ATmega328 are additianally shown in
figure 5.53a and the results from three ATmega328P are shown in figure 5.53b. At this only the zero
value of the capacity measurement of 39pF is respected, all other facility to correct the results are
not used. This zero value includes the 2  3pF , which are caused by the 12cm long cable with the
clips. The board layout can cause a different zero value, I have fixed this zero value with the board
DG2BRS V 5.2.1.
16
14
12
6
168A-4
168A-5
168A-6
4
Error / Percent
10
8
6
4
2
2
0
-2
-4
-6
-2
-8
-4
10p 100p
1n
1m
10m
-10
10p 100p
1n
10
168PA-7
168PA-8
168PA-9
8
Error / Percent
Error / Percent
168-1
168-2
168-3
6
4
2
0
-2
-4
10p 100p
1n
1m
10m
102
1m
10m
12
10
328-10
328-11
168-12
10
8
6
Error / Percent
Error / Percent
8
6
4
2
0
2
0
-2
-2
-4
-4
-6
-6
10p 100p
1n
1m
10m
328P-13
328P-14
328P-15
-8
10p 100p
1n
1m
10m
103
25
168-3-A
168-3-B
168-3-C
Error / Percent
20
15
10
5
0
-5
10p 100p
1n
1m
10m
5.3.11
The automatic calibration is build in two parts. The first part find out the zero offset of the capacity
measurement. For that the mean value of the capacity measured without connected capacitor is
build. A mean value for all 6 measurement combinations is build with 8 repetitions. After successfull
determination the zero offsets are written to the EEprom and will be used for further measurements.
More difficult was the clearance of the variance of the different ATmega processors for little capacitors
(<40F ), which is shown in Figure 5.51a, 5.51b and 5.52. As a significant reason for this is found
the different characteristic (Offset voltage) of the analog comparator.
The date of measurement of nine different processors is shown in figure 5.55 . The diff2ref points
show the difference of the voltage of a loaded capacitor of 660nF to the individual internal reference
voltages (band gap). Ideally this difference Voltage should be zero, if the analog comparator has
stopped the loading by the signal to the processor. The short handling time of the processor should
not result to a measurably rising of the capacitor voltage of this relative big capacitor. The CapErr
points show the estimated measurement errors of each processor out of figure 5.51a, 5.51b and 5.52
with per mill units. It is noticeable, how the CapErr points will follow the diff2ref points.
Therefore the diff points show the difference between the particular CapErr and diff2ref
points. With a mean value of the diff points we can get a good estimation for the correction
of the capacitor measurements together with the difference voltage of the loaded capacitor and the
internal reference.
For the second part of adjustment you must connect a capacitor to pin 1 and pin 3. This capacitor
should have a good quality factor and should have a capacity between 100nF and 20F . It should
be a film capacitor, as far as possible not a ceramic capacitor und in no case a electrolytic capacitor.
You dont need to know the exact value of this capacitor.
104
70
60
Difference to reference / mV
diff2ref
CapErr
diff
50
40
30
20
10
0
-10
-20
0
4
6
Number of ATmega168
10
7
6
Error / Percent
Error / Percent
168-1
168-2
168-3
4
3
2
1
5
4
3
2
1
-1
-1
-2
10p
100p
1n
10n 100n 1u
10u
Capacity value / F
100u
1m
10m
168A-4
168A-5
168A-6
-2
10p
100p
1n
10n 100n 1u
10u
Capacity value / F
105
100u
1m
10m
168PA-7
168PA-8
168PA-9
Error / Percent
5
4
3
2
1
0
-1
-2
-3
10p
100p
1n
10n 100n 1u
10u
Capacity value / F
100u
1m
10m
8
7
Error / Percent
Error / Percent
328-10
328-11
328-12
4
3
2
1
0
328P-13
328P-14
328P-15
4
2
0
-2
-1
-2
10p
100p
1n
10n 100n 1u
10u
Capacity value / F
100u
1m
10m
-4
10p
100p
1n
10n 100n 1u
10u
Capacity value / F
100u
1m
10m
106
20
168-3unc
168-3cal
168PA-7unc
168PA-7cal
328P-14unc
328P-14cal
Error / Percent
15
10
5
0
-5
-10
-15
10p 100p 1n 10n 100n 1u 10u 100u 1m
Capacity value / F
Figure 5.59. Error of capacitor measurement of three ATmega, before and after the calibration
The circuit with a ATmega644 or ATmega1284 provides a capacitor for calibration at the printed
board. The figure 5.60 shows the results of the capicitor measurements with a ATmega1284, with
the on board 100nF ceramic capacitor as well as with a external 220nF foil capacitor, compared to
the results of a ATmega328 on another printed board.
12
10
328-10
1284-int
1284-ext
Error / Percent
8
6
4
2
0
-2
-4
10p 100p
1n
1m
10m
Figure 5.60. Error of capacitor measurements with a ATmega1284 compared to the ATmega328
results
107
5.4
Measurement of inductance
The measurement of inductance values will be done as separate part with all found resistors with
less than 2100. The methode of measurement is based on the growing of current by formula
L
Il = Imax  (1  exp t
) after switching on the current. The time constant  = R
is proportional
to the inductance L, but reverse proportional to the resistor R. The current can only measured
indirectly with the potential drop of a resistor.
Unfortunately the time constant will be reduced additionally by the relative high resistance 680,
for that the measurement of little inductance values is additionally made difficult with the 8M Hz
clock. To get the time constant, the voltage at the 680 resistor will be monitored by the analog
comparator. If the voltage drop at the 680 resistor is higher than the voltage of the internal
reference, this event will be notified to the 16-bit counter, which is started at the same time of
switching current on. The counter will save the state of this event. If the counter will overrun, this
will be counted by the program. After the event, the counter will be stopped by the program and
the total time will be build with the saved counter stage and the overflow counter. The positive side
of the coil will be switched from VCC to GND and hold in this stage until monitoring of the voltages
of both pins shows, that no current is detected. The figure 5.61 shown a simplified diagram of the
measurement situation.
Bandgap
Reference
Clock
Control
Logic
ACBG
AIN0
Timer Counter
TCNT1
Noise
Canceler
AIN1
From ADC Multiplexor
ACME
Edge
Detector
22
TP3
Rx
Lx
Clear
Direction
TOV1
DATA BUS
Count
ICR1
VCC
ICFn
19
TP1
680
19
R1
the inductance can be calculated. The natural logarithm will be taken out of a build in table. A
inductance resolution of 0.1mH is taken for this type of measurement.
In order to also measure lower inductance values, the 680 resistor will be omitted in the current
loop, if the resistance value of the inductor is measured with less than 24. Only the output resistance
of the port (19) will be used for measurement of the current. In this special case the peak current
will be greater than the value, that the specification of the ATmega allows. Because this will be true
only for a very short time, I expect no damage of the ATmega ports. For this type of measurement
a resolution of inductance of 0.01mH is selected. To avoid a longer time with excessive current, the
additional measurement with delayed start of the counter will always be done with the 680 resistor.
To get better fitting measurement results, a zero offset of 6 is subtract from the counter reading, if
108
the measurement is done without the 680 resistor. Otherwise a zero offset of 7 or 8 is subtracted.
With great inductance values the parasitic capacity can cause a quick rise of current, so that the
comparator will responce inmmediately. To get the value of the inductance anyway, the measurement
will be repeated with a delayed start of the counter. With this methode the voltage grow caused by
the current increase of the inductor will be detected by the analog comparator instead of the current
peak of the parasitic capacity. The measurements are always done in both current directions. The
program will select the higher result of measurement in the same current direction, but the lower
result of the different current direction as the displayed result.
5.4.1
The figure 5.62 shows the results of the measurement of different inductors. The Inductors above
1H are relays or primary sides of power transformers, for which measurements are difficult because
the iron core has residual remanence.
20
328p
328
168p
168a
168
15
Error / Percent
10
5
0
-5
-10
-15
-20
10u
100u
1m
10m 100m
1
Inductance value / H
10
100
5.4.2
The smallest detectable inductance is 0.01 mH with the normal measurement technique. For high
frequency application the measurement of smaller inductances is required. The normal method use
the speed of the current grow to measure the inductance. This method can not be used for the
sampling technique, because the measurement circuit uses no additional resistors with the coil. The
current will grow to forbidden high values very fast. We can prevent a damage of the ATmega only
with a very fast break of the current flow. For the sampling method it is difficult to get this fast
current turning-off and additionally this critical process must be done many times in series. For this
reason the radio amateur Pieter-Tjerk (PA3FWM) has used another method to get the inductance
values. Together with a parallel connected capacitor the inductor build a resonant circuit. With a
short current pulse this circuit begins to oscillate some times without further stimulation. With the
sampling method the frequency of this oscillation can be measured. Because one side of the coil must
be connected to GND level for this measurenent, there are two problems with the measurement. Once
the negative voltage of the oscillation is limited by the internal protection diode of the ATmega to
109
about 0.6 V. For this reason the positive part of the oscillation will never reach a higher voltage than
0.6 V too. Additionally the ADC of the ATmega can only measure positiv voltage values. Therefore
all negative parts of the oscillation is read as zero. Anyway could Pieter-Tjerk find a solution,
to measure the resonant frequency with a practical precision. With the resonant frequency the
inductance can be computed, if the capacity value is known. For this reason the calibration program
is extended with a capacity measurement for later inductance measurement use. The capacitor will
3 10  30nF (L). A default value of 18 nF is preselected
be requested with the message  1
for the uncalibrated tester. The value of the parallel capacitor for inductance measurement should
be selected rather high to get a low resonant frequency with small inductance values. A capacitor
with high quality like foil-type should be selected because the quality factor of the resonant circuit
is additionally measured by monitoring the decrease of the amplitude. With a high quality capacitor
the total quality factor of the resonant circuit is build by the quality factor of the coil.
There is no additional operation required with the parallel connected capacitor. The resonant
circuit is usually detected automatically. When the resonant circuit is detected, the text if and
the expected value of the parallel capacity is written behind the inductance value in line 2. In this
case the resistance value of the coil is written at the end of line 1. You should check the resistance
value with a separate coil measurement without the capacitor, because the resistance measurement
of the resonant circuit often fail! A additional output line shows the measured resonant frequency
and the quality factor (Q=) of the resonant circuit.
If there is no resonant circuit detected, the resistance value and the inductance is shown in line
2. When a resonant frequency of a single coil is detected, the frequency value and the quality factor
of the coil is also shown in a additional line.
For a air coil with 6 turns and a parallel connected capacitor with 18 nF the sampling method
get the following result:
272nH if 18.0nF
2256kHz Q=38.7
This result was measured with a operation frequency of 8 MHz. A simular result was also measured
with a 25 cm long copper wire, which was formed to one big circle. Probably smaller inductance
values can be measured with a 16 MHz operation of the ATmega.
110
5.5
Selftest Function
Beginning with release 0.9k I have implemented a self test function. Usage is very simple. If you
have installed test terminal with clamps, put all clamps together to a piece of uninsulated wire and
press the start button. The program notice the shorten probes and start the self test function, if you
confirm within two seconds with pressing the start key. This confirmation is implemented to prevent
the tester going automatically to the self test by connecting a defect transistor. After finishing the
self test the transistor tester will continue with normal measurement. If no equipment is connected,
the program will end with part unknown or damaged. You can configure self test only for a
ATmega168 or ATmega328. Before the test steps begin, the zero resistance of the connected probes
is determined for all three combinations (T1:T3, T2:T3 and T1:T2). This zero resistances will be
subtracted for the future ESR and resistance measurements below 10. Only zero resistance values
below 0.90 are accepted, because this correction values are not uses for measurement of resistor
values above 10. If you use cables for measurement, you should only take cables with low resistance
values. If the later measured resistance results fall below the particular zero resistance for more than
0.2, the tester will be resetted to uncalibrated. This will be marked by a acticated cursor during
the tests. The separate steps of the self test function 1 to 7 is displayed on row 1 of the LCD display
with the letter T followed by the step number. Every step is repeated 4 times, before the program
continues with the next step. But if you hold the start key pressed, when the test cycle is finished,
this test is not repeated any more. If you leave the key pressed the total time, every test is executed
only once.
Without the AUTO CAL option only measurement results are displayed in every step, no error
analysis are done, you must interpret the results yourself. At this place I will give you an additional
important hint. Never do a measurement with connected ISP plug! The ISP interface influences the
measurement. Here is the list of currently implemented tests:
1. Measurement of the 1.3V (or 1.1V ) reference Voltage (band gap Reference). In row
1 the text Ref= and the measured Voltage in mV is displayed. For the ATmega8 the voltage
should be near to 1.3V . For the other processors the voltage should be near to 1.1V . The
second row shows the resulting factor for the capacity measurement with the 470k resistor.
2. Comparing of the 680 resistors. In row 1 the cryptic text +RL- 12 13 23 is shown.
Meaning of this is as follows: The RL is the short form of Resistor Low meaning the 680
resistors. The 12 stand for: resistor at pin 1 is connected to VCC (+) and resistor at pin 2
is connected to GND (-). The result of this measurement is displayed in row 2 at the first
place as difference to the theoretical value. In row 1 follows now a 13 which means, that the
first connection of measurement 1 is still connected with 680 to VCC but that the resistor of
pin 3 is connected to GND. The result is displayed in the middle place of row 2 as difference
to the theoretical value. The last measurement of this test 23. means that now the resistor
at pin 2 is connected to VCC (+) and the resistor of pin 3 is connected to GND. The result of
measurement is displayed at the last place of LCR row 2 as difference to the theoretical value.
Please remember, that the resolution of the ADC is about 4.88mV ! The measurement situation
is also shown in figure 5.63. The theoretical value with respect to the internal resistance of the
5001(19+680)
= 2493 .
pins should be: (19+680+680+22)
111
first measurement
22
19
22
19
22
19
GND
ADCMUX
second measurement
TP2
TP3
PB4
R5
PC2
R3
PB2 TP1
680
TP3
PC1
680
TP1
PB4
R5
PC2
680
PB0 TP2
R1
PC0
680
TP2
R3
TP1
PB2
680
PC1
R1
680
PB0 TP3
19
22
ADCMUX
PC0
22
GND
19
22
VCC
19
19
22
19
22
ADCMUX
22
GND
19
22
VCC
19
22
19
22
19
VCC
third measurement
112
22
19
PB4
TP2
second measurement
R5
PC2
680
680
first measurement
GND
ADCMUX
PB2
TP1
22
19
19
PC1
R1
680
GND
ADCMUX
PB0
PC0
VCC
R3
ADCMUX
22
GND
22
VCC
19
22
19
22
19
VCC
TP3
third measurement
TP1
first measurement
22
19
ADCMUX
PB2
TP2
second measurement
PC2
PB4
R5
PC1
R3
R1
680
PB0
GND
680
ADCMUX
PC0
22
19
22
VCC
GND
680
ADCMUX
19
GND
22
19
VCC
22
19
22
19
VCC
TP3
third measurement
If the tester is configured with the SamplingADC function, the zero capacity values is determined with double the count of all pin combinations. The reason for this is, that the zero
capacity is measured for the charge and the discharge of all pin combinations separately.
3
11. Wait for the connection of a capacitor to pin 1 and pin 3. The message 1
>100nF is shown in row 1 of LCD. To prepare the measurement of the comparator offset
voltage, you must connect a sufficient big capacitor to pin 1 and pin 3. It should be a capacitor
with a high quality factor and a capacity between 100nF and 20F . You should never use
electrolytical capacitors, use film capacitors instead.
12. Measurement of the comparator offset for capacitor measurement adjustment. To
get the offset of the analog comparator, a capacitor must already be connected to pin 1 and
pin 3. The capacitor is needed for buffering the load voltage of a capacitor, in order to get the
voltage difference of load voltage to the internal reference voltage (band gap). If measurement
is successfull, the correction value is short shown with the text REF C= in row 1 of the LCD
and written to the EEprom. You can give a additional offset to the automatic measured value
with the REF C KORR option.
If you have selected the AUTOSCALE ADC option, the gain of the ADC readings with the
internal reference will be adjusted by comparing a capacitor voltage below 1 V once readed
with VCC reference and once readed with the internal reference. The measurement result is
shown in row 2 with the text REF R=. Your REF R KORR value is a additional offset to
this automatic find out difference value.
13. Wait for a capacitor for measuring of low inductace values If the tester is configured
with the SamplingADC function, a known capacitor is required for the computation of the
inductance value from the resonant frequency of a parallel connected coil. Practical capacity
values can be choosed from 10nF to 27nF . A suitable capacitor must be connected to pin 1
3 10  30nF (L) is shown in line 1 of the display. Exaand pin 3, if the message 1
cly this capacitor should be connected later parallel to a little coil, if the calculation of the
coils inductance value from resonant frequency is desired. If your tester does not include the
SamplingADC function, this step is omitted.
At the end of test function the text Test End is shown in row 1 and the version number of
software is shown in row 2. If the Makefile option FREQUENCY 50HZ is set, a 50Hz rectangle
signal is generated on pin 2 and the same signal in opposite direction on pin 3. Pin 1 is switched to
GND . The current is limited with 680 resistors. This will be notified by the Output of 50Hz at
the end of row 1 of the LCD display. The 50Hz signal will be generated 30 times for 2 seconds each.
You can check the time of the wait calls, if you have an oscilloscope or frequency counter. Figure
5.66 shows the oscillograph curves of both 50Hz output pins with crystal operation.
114
Figure 5.66. Oscillograph curve with the 50Hz outputs of Port 2 and 3
If you dont use the crystal clock version, the result may be inexactly. A exactly clock frequency
and wait time are important for measurement of capacity values. You can abort the generation of
the 50Hz signal by long time pressing of the start button. Then the program continues with the
normal measurement task.
5.5.1
The results of the selftests of nine different ATmega168 processors and of six ATmega328 processors
will be shown in the following figures.
Test
Test
Test
Test
Test
Test
Test
Test
Test
Test
No.
measurement typ
1
band gap Ref
2
RL-Mean
3
RH-Mean
5
RH-Low
6
RH-High
8
R out Lo
9
R out Hi
10
Cap zero offset
11
Reference correction
theoretical figure
1100
5.67
0
5.68a
0
5.68b
0
5.69a
0
5.69b
131
5.70a
151
5.70b
30
5.71
0
5.72
115
1110
Reference
reference voltage / mV
1100
1090
1080
1070
1060
1050
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
Processor number
Figure 5.67. Selftest: Reference-Voltages
RHmiddle12
RHmiddle13
RHmiddle23
0
voltage / mV
0
voltage / mV
RLmiddle12
RLmiddle13
RLmiddle23
-5
-10
-15
-5
-10
-15
-20
-20
0
6 7 8 9 10 11 12 13 14 15 16
Processor number
6 7 8 9 10 11 12 13 14 15 16
Processor number
116
(voltage - VCC) / mV
4
voltage / mV
RHbottom1
RHbottom2
RHbottom3
RHtop1
RHtop2
RHtop3
-1
-2
-3
-4
-5
0
6 7 8 9 10 11 12 13 14 15 16
Processor number
6 7 8 9 10 11 12 13 14 15 16
Processor number
21.2
23.5
RiLo1
RiLo2
RiLo3
21
23
resistance / Ohm
20.8
20.6
20.4
20.2
20
22.5
22
21.5
19.8
19.6
21
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
Processor number
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
Processor number
44
CNULL1
CNULL2
CNULL3
42
Capacity / pF
resistance / Ohm
RiHi1
RiHi2
RiHi3
40
38
36
34
32
0
6 7 8 9 10 11 12 13 14 15 16
Processor number
117
80
REF C KORR
REF R KORR
Voltage correction / mV
60
40
20
0
-20
-40
-60
0
6 7 8 9 10 11 12 13 14 15 16
Processor number
AREF - REF
REF R KORR
Voltage difference / mV
30
20
10
0
-10
-20
-30
-40
0
6 7 8 9 10 11 12 13 14 15 16
Processor number
118
5.6
Measurement of frequency
Beginning with Version 1.10k the frequency measurement can be selected with a control menu. The
normal frequency measurement is done with counting the falling edges of input signal T0 (PD4) with
counter 0 for one second. For maintaining of a accurate second, the counter 1 is used with a 256:1
prescaler of the CPU frequency. The 16 bit counter of the ATmega can be used up to 16M Hz CPU
frequency with the prescaler to serve the second period in one pass. For the start and stop of the
counter 0 ist the compare register B and A of the counter 1 used. To prevent a unstable delay by
polling the compare event signals, for starting and stopping the Interrupt Service of both counter
1 compare events is used. The time delay of both Interrupt Service Routines is nearly equal. To
maintain a accurate second period is a constant delay insignificant. With analysing the assembler
code, the difference in time can be adjusted.
For frequencies below 25kHz the normal measurement is followed by a measurement of period
time. This additional measurement is only followed after a normal frequency measurement. This will
be done by measuring the time of a selectable count of the Pin Change interrupts of the PCINT20
(PD4) input with the counter 0. By measuring the period both, the negative puls width and the
positive puls width, should be at least 10s . The counter 0 is used with full clock rate. This results to
a resolution of 125ns for 8M Hz. With a greater count of measurements periods the resolution can be
reduced. By using a measurement period of 125 periods, the middle resolution for one period is 1ns.
To prevent the inexactness of start and stop the counter 0, the start of counter 0 is started within the
first pin change interrupt of PCINT20 and will be stopped with the last pin change interrupt with
the same interrupt service routine. The count of periodes is choosed, that the measurement time is
about 10 million clock tics. The part of error from one clock is only 0.1ppm with this choise. With
a 8M Hz clock the measurement time is about 1.25 seconds. From this mean value of one period a
frequency with better resolution is computed too.
For checking the procedure, two testers are measured against each other. First the test frequencies
are generated with tester 2 and measured with tester 1. After that the testers are swapped and the
measurement is repeated. Figure 5.74 shows the results of both measurement series. The nearly
constant errors can be explained with a little frequency difference of both crystals.
20
15
Error / ppm
10
5
0
-5
-10
-15
-20
-25
1
10
100
Tuning of the cystal frequency is possible with a adjustable capacitor (5-25pF) at the crystal.
The one pulse per second (1PPS) from the GPS receiver UP501 from Fastrax Ltd. and from the
GPS/GLONASS receiver GNS701 from Global Navigation Systems GmbH has been tested
successfully for the calibration of the crystal frequency. The measured period could be adjusted to
exactly 1000.000ms. Only the last digit can toggle with one unit. Of course the frequency of the
crystal is temperature dependent. Therefore you can not expect a very good long time stability.
The figure 5.75 shows the used circuits with a UM232 USB-serial converter as connection of the
receiver modules to a computer. The UM232 converter support the circuit sowohl with both, the 5V
and the 3.3V supply voltage from the USB supply voltage. No connection to a computer is required
for operating the receivers. Only the 5V supply voltage must be provided to the USB connector.
FTDIUM232R
FTDIUM232R
19
4
17
16
15
21
14
7
24
13
3V3
VIO
J1
1 2 3
TXD
DTR
RTS
3
5
VCC
VCC
USB 5V
GND
GND
RXD
6
RI
8
DSR
9
DCD
10
CTS
J2
SLD
CB0
CB1
CB2
CB3
CB4
RST
17
16
VDD
TXD
RXD
23
15
21
VDD_B
14
22
12
100n
4k7
1F
18
11
11
13
2xBC507C
470
2
3
GNS 701
VCC
VCC
1
3
6
USB 5V
J2
SLD
CB0
CB1
CB2
CB3
CB4
RST
23
22
100n
11
12
18
12
11
11
VCC
VBACKUP
ENABLE
NRESET
GND
GND
TX0
5
RX0
9
TX1
10
RX1
3DFIX
1PPS
470
1PPS
1PPS
(b) GPS/GLONASS
120
LEDrd
1k
BC507C
LEDrd
(a) GPS
4k7
GPS/GLONASS
USB
USB
470
RXD
6
RI
8
DSR
9
DCD
10
CTS
PU1
PU2
GND
24
GND
4k7
GPS
J1
PPS
GND
VIO
TXD
DTR
RTS
UP501
PU1
PU2
3V3
1 2 3
120
19
Chapter 6
Signal generation
The different signal generation modes are only available with a ATmega328 processor. You must also
enable the dialog function with the Makefile option WITH MENU. The menu is called by a long key
press. The available functions are shown in the second row of the LCD. You can select the shown
function by a long key press. The next function in automatically shown after 5 seconds or after a
short key press.
6.1
Frequency Generation
The frequency generation is started, if you select the f-Generator function by a long key press.
The frequency output is done with the 680 resistor at measurement port TP2. The measurement
port TP1 is switched to GND. The frequencies are build with the 16 bit counter from the CPU clock
frequency (8M Hz or 16M Hz). Currently a list of predefined frequencies (2M Hz down to 1Hz) can
be selected with short key press. If you hold the key pressed for a long time, you can return to the
dialog function and select the same or another function.
6.2
The Puls Width generator is started, if you select the 10-Bit PWM function by a long key press.
The frequency output is done with the 680 resistor at measurement port TP2. The measurement
port TP1 is switched to GND. The frequency of the output signal is always the CPU clock divided
by 1024. This gives a result of 7812.5Hz for the 8 MHz CPU clock. Only the positive pulse width
can be changed by a key press. With a short key press you can increase the positive puls width up to
99% in 1% increments. With a longer key press you can increase the pulse width in 10% increments.
The pulse width reaches a value above 99% 100 is subtract from the result. The pulse width 0%
generates a very small positive puls width.
121
Chapter 7
Known errors and unsolved problems
Software Version 1.12k
1. Germanium Diodes (AC128) are not detected in all cases. This is probably caused by the
residual current. Cooling of the diode can help to reduce the residual current.
2. With bipolar transistors a collector - emitter protection diode was not detected, if the collector
residual current ICE0 is high. The problm was only detected with germanium transistors,
which are complemented with a external diode.
3. The current amplification factor of germanium transistors can be measured too high because
of the high residual current. In this case the basis emitter voltage will be very low. Cooling of
the transistor can help to get a more correct current amplification factor.
4. Capacity value in reverse direction for Power Schottky Diodes such as MBR3045PT can not
be measured, if only one diode is connected. The reason is a too big residual current of this
diode. Sometimes the measurement is possible by cooling down the device (with cooling spray
for example).
5. Here and there a wrong detection of the 2.5V precision reference is reported, when the PC4 pin
(27) is unconnected. You can avoid this behaviour with a additional pull up resistor connected
to VCC.
6. The diode function of a triac gate can not be examined.
7. Sometimes a problem with the Brown Out level of 4.3V is reported for ATmega168 or ATmega328 processors. This will cause a reset during capacity measurement. A reason is not
known. The Resets will disappear, if the Brown Out level is set to 2.7V .
8. With the using of the sleep state of the processor, current of VCC power is changing more than
using previous software versions. You should check the blocking capacitors, if you notice any
problems. Ceramic capacitors with 100nF should be placed near the power pins of the ATmega.
The using of sleep state can be deselected by the Makefile option INHIBIT SLEEP MODE.
9. The measurement of tantalum based electolytical capacitors often make trouble. They can be
detected as diode or can also be not detected as known part. Sometimes the measurement with
swapped connection can help.
10. The Source and Drain pins can not be detected correctly with JFETs. The reason is the
symmetrical structure of this semiconductors. You can notice this problem with the effect,
that the display shows the same layout with the same parameters, if the Source and Drain pins
are swapped. I see no way to detect the Source and Drain pin correctly. But interchanging of
Source and Drain in any circuit should usually not cause any problem.
122
Chapter 8
Special Software Parts
Several modifications are done to save flash memory. The LCD-Output of probe-pin numbers
was done in the form lcd data(1+pin). To save the add operation for every call, the entry
lcd testpin(uint8 t pin) was added to the lcd routines.c.
The pseudo calls in the form  delay ms(200) are not implemented as library calls, but wait
loops are implemented for every call. This will consume much memory, if you have many calls at
different location in your program. All of this pseudo calls are replaced with calls to my special
assembly written library, which uses only 74 bytes of flash memory (@8MHz), but enables calls from
wait1us() to wait5s() in steps of 1,2,3,4,5,10,20. . . . The routines include the Watch Dog Reset for
all calls above 50ms. Every wait call usually only need one instruction (2 Byte). Wait calls with
interim value such as 8ms need two calls (5ms and 3ms or two times a 4ms call). I dont know any
implementation, which is more economical if you use many wait calls in your program. The calls
uses no registers, only the Stack Pointers for the return adresses in the RAM (at most 28 Byte stack
space in current release) is used. The total list of functions is:
wait1us(), wait2us(), wait3us(), wait4us(), wait5us(), wait10us(),
wait20us(), wait30us(), wait30us(), wait40us(), wait50us(), wait100us(),
wait200us(), wait300us(), wait400us(), wait500us(), wait1ms(),
wait2ms(), wait3ms(), wait4ms(), wait5ms(), wait10ms(),
wait20ms(), wait30ms(), wait40ms(), wait50ms(), wait100ms(),
wait200ms(),wait300ms(), wait400ms, wait500ms(), wait1s(),
wait2s(), wait3s(), wait4s() and wait5s();
That are 36 functions with only 37 instructions inclusive Watch Dog Reset! There is really no way to
shorten this library. Last not least matches the wait calls the exactly delay time, if the lowest wait
call does. Only the wait calls above 50ms are one cycle per 100ms to long because of the additionally
integrated watch dog reset.
Additionally the often used calling sequence wait5ms(); ReadADC. . . (); is replaced by the call
W5msReadADC(. . . );. The same is done for the sequence wait20ms(); ReadADC(. . . ); which
is replaced by one W20msReadADC(. . . ); call. The function ReadADC is additionally written in
assembly language, so that this add-on could be implemented very effective. The functional identical
C-version of the ReadADC function is also avaiable as source.
123
Chapter 9
To Do List and new ideas
1. Add more and better documentation.
2. Think about how we can get the real internal resistance of port B output (resistor switching
port) instead of assuming, that ports are equal.
3. Can discharging of capacitors be made more quickly, if the minus pin is additionally raised
with the 680 resistor to VCC (+)?
4. Check if the tester can use floating-point representation of values. The risk of overflow is lower.
There is no need to use multiplication and division together to build a multiplication with a
non integer factor. But I dont know how much flash memory must be spend for the library.
5. Write Users guide for configuring the tester with the Makefile options and description of the
build chain.
6. If the holding current of a thyristor can not be reached with the 680 resistor, is it harmless to
switch the cathode directly to GND and the anode directly to VCC for a very short time? The
current could reach more than 100mA. Will the port be damaged? What is with the power
supply (voltage regulator)?
7. Check the Port afterwards with self test function!
8. Idea for a New Projekt: USB version without LCD-Display, Power from USB, Communication
to PC over a USB-Serial bridge.
9. Replacement of samplingADC function, which make use of the counter1 to manage the shift of
the ADC S&H time.
10. Check the accuracy of measurement little capacitors with the samplingADC method.
11. Check the accuracy of measurement little coils with the samplingADC method.
124
Bibliography
[1] Markus Frejek AVR-Transistortester,. Embedded Projects Journal, 11. Ausgabe, 2011
[2] Atmel Corporation 8-bit AVR with 8KBytes In-System Programmable Flash - ATmega8(L),.
Manual, 2486Z-AVR-02/11, 2011
[3] Atmel Corporation 8-bit AVR with 4/8/16/32KBytes In-System Programmable Flash - ATmega48 - ATmega328,. Manual, 8271D-AVR-05/11, 2011
[4] Atmel Corporation Atmel AVR126: ADC of megaAVR in Single Ended Mode,. Application
Note, 8444A-AVR-10/11, 2011
[5] Atmel Corporation Atmel AVR121: Enhancing ADC resolution by oversampling,. Application
Note, 8003A-AVR-09/05, 2005
[6] http://en.wikibooks.org/wiki/LaTeX LaTeX documentation,. Guide to the LaTeX markup
language, 2012
[7] http://en.wikibooks.org/wiki/Gnuplot Gnuplot documentation,. Documentation for the
plotting tool gnuplot, 2012
[8] Wikipedia http://de.wikipedia.org/wiki/Equivalent_Series_Resistance Explanation
for ESR in german language. Standardization and equivalent circuit of a capacitor, 2012
[9] http://www.xfig.org/userman Xfig documentation,. Documentation of the interactive drawing
tool xfig, 2009
[10] http://docs.gimp.org/2.6/de gimp documentation. Documentation of the GNU Image Manipolation Program, 2010
[11] http://www.mikrocontroller.net/articles/AVR-Transistortester Online documentation
of the Transistortester, Online Article, 2009-2011
[12] http://www.mikrocontroller.net/articles/AVRDUDE Online documentation of avrdude programmer interface, Online Article, 2004-2011
[13] http://www.mikrocontroller.net/topic/131804 Thread from Markus, Forum thread, 2009
[14] http://www.mikrocontroller.net/articles/AVR_Transistortester Short description of
new features of the TransistorTester von Karl-Heinz K., Online Article, 2012
[15] http://www.mikrocontroller.net/topic/248078 Thread from Karl-Heinz, Thread and new
software versions, 2012
[16] http://www.mikrocontroller.net/articles/WinAVR Information about WinAVR in german
language, Online Article, 2012
125
126