
 2002 Microchip Technology Inc.
Preliminary
DS40044A-page 63
PIC16F627A/628A/648A
The code example in Example 10-1 depicts the steps
required to configure the Comparator module. RA3 and
RA4 are configured as digital output. RA0 and RA1 are
configured as the V- inputs and RA2 as the V+ input to
both comparators.
EXAMPLE 10-1:
INITIALIZING 
COMPARATOR MODULE
10.2
Comparator Operation
A single comparator is shown in Figure 10-2 along with
the relationship between the analog input levels and
the digital output. When the analog input at V
IN
+ is less
than the analog input V
IN
-, the output of the comparator
is a digital low level. When the analog input at V
IN
+ is
greater than the analog input V
IN
-, the output of the
comparator is a digital high level. The shaded areas of
the output of the comparator in Figure 10-2 represent
the uncertainty due to input offsets and response time.
See Table 17-2 for Common Mode Voltage.
10.3
Comparator Reference
An external or internal reference signal may be used
depending on the comparator Operating mode. The
analog signal that is present at V
IN
- is compared to the
signal at V
IN
+, and the digital output of the comparator
is adjusted accordingly (Figure 10-2).
FIGURE 10-2:
SINGLE COMPARATOR
10.3.1
EXTERNAL REFERENCE SIGNAL
When external voltage references are used, the
Comparator module can be configured to have the
comparators operate from the same or different
reference sources. However, threshold detector
applications may require the same reference. The
reference signal must be between V
SS
 and V
DD
, and
can be applied to either pin of the comparator(s).
10.3.2
INTERNAL REFERENCE SIGNAL
The Comparator module also allows the selection of an
internally generated voltage reference for the
comparators. Section 11.0, Voltage Reference Manual,
contains a detailed description of the Voltage Refer-
ence Module that provides this signal. The internal ref-
erence signal is used when the comparators are in
mode CM<2:0>=010 (Figure 10-1). In this mode, the
internal voltage reference is applied to the V
IN
+ pin of
both comparators.
10.4
Comparator Response Time
Response time is the minimum time, after selecting a
new reference voltage or input source, before the
comparator output is to have a valid level. If the internal
reference is changed, the maximum delay of the inter-
nal voltage reference must be considered when using
the comparator outputs. Otherwise, the maximum
delay of the comparators should be used (Table 17-2
).
FLAG_REG
CLRF
CLRF
MOVF
ANDLW
IORWF
MOVLW
MOVWF
BSF
MOVLW
MOVWF
EQU
0X20
FLAG_REG
PORTA
CMCON, W
0xC0
FLAG_REG,F ;Store bits in flag register
0x03
;Init comparator mode
CMCON
;CM<2:0> = 011 
STATUS,RP0 ;Select Bank1
0x07
;Initialize data direction
TRISA
;Set RA<2:0> as inputs
;RA<4:3> as outputs
;TRISA<7:5> always read ‘0’
STATUS,RP0 ;Select Bank 0
DELAY10
;10
μ
s delay
CMCON,F
;Read    CMCONto end change
;condition
PIR1,CMIF
;Clear pending interrupts
STATUS,RP0 ;Select Bank 1
PIE1,CMIE
;Enable comparator interrupts
STATUS,RP0 ;Select Bank 0
INTCON,PEIE ;Enable peripheral interrupts
INTCON,GIE ;Global interrupt enable
;Init flag register
;Init PORTA
;Load comparator bits
;Mask comparator bits
BCF
CALL
MOVF
BCF
BSF
BSF
BCF
BSF
BSF
–
+
Vin+
Vin-
Result
Result
V
IN
-
V
IN
+