4-digit Up/Down counter with preset, reset, hold and overflow output using PIC16F88
A four digit decimal counter for the PIC 16F88 with the following features:
- Count up / down
- Free running or hold on count over/underflow
- User count preset
- Over/underflow output
This is a 4 digit decimal counter which can operate as a free running counter or in count and hold mode with manual reset. In either mode the counter can be preset to count to a specified value. Clock edge and leading zero suppression can also be configured.
The 7-segment display and indicator LEDs are multiplexed. It will drive most common anode 7 segment LEDs. I used four single digit LEDs but a four digit LED module could also be used.
In free running mode the overflow output resets on the next clock pulse. Therefore the pulse duration is directly related to the input clock frequency.
The clock input goes to a Schmitt trigger input pin on the PIC. It will accept a 0-5V input signal only. If it’s used with a mechanical switch you should use the debounce circuit shown on the schematic.
I’ve had the circuit clock reliably at 200Hz and it should be able to operate without missing a clock pulse at frequencies up to 5Khz.
The counter can be configured for either a rising or falling clock edge and leading zero suppression. Once applied these settings are stored in NVRAM and retained across a power cycle. To enter config mode, hold down the ‘set’ switch at power-on.
The counter normally runs from 0000 to 9999.
It can be configured to count up to, or down from a preset number using the set and adjust keys.
The preset number is used until it is manually changed. When it has been changed the preset is saved to EEPROM and will be restored at power on.
Active when count reaches preset value
On – Counter in Hold mode
Off – Counter in free running mode
Count Up / Count Down :-
indicates the count direction
Current Project / Post can also be found using:
- Reset proof counter using pic
- 4 digit up down counter circuit
- 4digit up down counter
- pic16f88 clock project