Maximal Entropy Reduction Algorithm for SAR ADC Clock Compression by Molev-Shteiman, Arkady & Qi, Xiao-Feng
Maximal Entropy Reduction Algorithm for SAR 
ADC Clock Compression  
 
Arkady Molev-Shteiman and Xiao-Feng Qi 
 
Radio Algorithms Research, Futurewei Technologies, New Jersey Research Center, Bridgewater, NJ 
 
 
ABSTRACT 
 
Reduction of comparison cycles leads to power savings of a 
successive-approximation-register (SAR) analog-to-digital 
converter (ADC). We establish that the lowest average 
number of comparison cycles of a SAR ADC approaches the 
entropy of the ADC output, and proposed a simple adaptive 
algorithm that approaches this lower bound. Today’s SAR 
ADC uses binary search, which consumes more power than 
necessary for non-uniform input distributions commonly 
found in practice. We refer to a SAR ADC employing such a 
search algorithm the maximal entropy reduction ADC (MER 
ADC). 
 
Index Terms— maximal entropy reduction, SAR ADC, 
ADC power consumption, decision tree, massive MIMO 
 
1. INTRODUCTION 
 
ADC is ubiquitous in every application that requires 
conversion of analog signals to digital form.  Due to its 
relatively low cost and power consumption, the SAR ADC 
architecture sees wide-spread applications where conversion 
speed is not extremely high.  However, minimizing SAR 
ADC power consumption is still critical for many 
applications that requires conversion of large amount of 
data. Examples include sensing, image processing and 
massive MIMO communication. The power consumption of 
SAR ADC is strongly dependent on the number of 
comparison cycles (clocks) required for each conversion. 
Conventional SAR ADC uses binary search algorithm with 
fixed number of cycles, which is equal to the number of 
ADC bits. However, it is optimal only for uniform input 
probability distribution. For other inputs, optimal strategy is 
to reduce the search length for high likelihood samples, to 
more than compensate for the increase in the search length 
for low likelihood samples. The average number of 
comparison cycles for such ADC decreases as a result, 
which means lower power consumption. 
The SAR ADC with variable number of comparison 
cycles was proposed recently in [1] and [2], where a few 
algorithms of non-binary search were proposed for specific 
types of inputs. 
Our work, on the contrary, generalizes to analysis of 
search algorithms from information theory point of view. 
We apply the method of Maximum Entropy Reduction 
(MER) decision tree ([3] and references therein) to the 
development of a generic search algorithm, which can be 
matched to any ADC output probability distribution. When 
ADC resolution approaches infinity, the average search 
length (number of comparison cycles consumed to determine 
the correct ADC output value) approaches the ADC output 
entropy. It matches theoretical lower bound for average 
decision cycles of binary decision tree presented in [3]. To 
our knowledge this is the first contribution applying decision 
tree bounds to comparison cycles of SAR ADC. 
We also propose a simple adaptive search algorithm that 
allows efficient hardware implementation. It estimates the 
change in ADC output probability distribution and adjusts 
the decision thresholds accordingly.  
Another method that benefit from non-uniform 
distribution of ADC input is non-linear quantization [4] 
[5]. It reduces the average quantization noise, by 
allocating low quantization steps in high likelihood regions 
and high quantization steps in low likelihood regions. 
However for many applications we cannot allow increase of 
quantization noise even in low likelihood region; 
Furthermore, if actual input distribution is different from the 
assumed one, ADC with non-linear quantization will suffer 
from performance degradation due to increase of average 
quantization noise. MER ADC is self-correcting: the number 
of comparison cycles increases momentarily, but settles to a 
new optimum through the ADC adaptation mechanism. 
 
2. CONVENTIONAL SAR ADC SYSTEM MODEL  
 
An ADC performs quantization  y round x  , where 
x is ADC input, y is ADC output, round ( ) denotes rounding 
operation and    is the quantization step.  
Assume that input to an N-bits ADC is limited by: 
 0.5 2 0.5Nx          (1.1)
Then y is any integer number from 0 to 2 1N   satisfying to:               
   0.5 0.5y x y         (1.2)
The SAR ADC provides iterative search of output y 
satisfying(1.2). Its block diagram is shown in figure 1. 
 
N bits 
DAC
Control
Logic
yˆ
YES or No
Comparator
Sample & 
Hold
ADC
Input
x
Sampling Clock
xˆ y
z
 
Figure 1  The block diagram of SAR-ADC 
A SAR ADC contains the following components. 
- A sample-and-hold unit that provides time domain 
sampling of input signal. 
- An N-bits Digital-to-Analog Converter (DAC) that 
generates analog reference based on digital hypothesis yˆ   
      ˆ ˆ ˆ 0.5x y y          (1.3) 
- A comparator which compares input signal with DAC 
output and produces binary outcome: 
        ˆ ˆ 0 or 1z x x y         (1.4) 
- Control logic that searches for the DAC input combination 
with guidance from comparator output, which 
satisfies    ˆ ˆ ˆ ˆx y x x y   . The  combination is 
taken as the ADC output, namely ˆy y . 
 Let ˆmy and mz denote DAC input and comparator output 
following comparison cycle m, respectively. 
 After each comparison cycle m we may conclude that 
ADC output satisfies  m mLB y UB  , where mLB and 
mUB  denote lower and upper bound of ADC output 
ambiguity interval, respectively:  ,m m mB LB UB . 
Obviously, before the search starts. 
0 0,2
NB     .  
 Each comparison cycle changes ADC output ambiguity 
interval according to the rule below. 
   1
1
ˆ ˆ ˆIf      
ˆElse                      
m m m m m
m m m m
x x y UB y LB LB
LB y UB UB


  
 
    (1.5)   
 A rational search algorithm chooses new comparison 
threshold 1ˆ  my  within previous ambiguity interval.  
Therefore each comparison cycle reduces the size of ADC 
output ambiguity interval until eventually (say after M 
comparison cycles) it shrinks to   1M MUB LB  , which 
means that there is no more ambiguity and we found the 
ADC output which is equal to  My LB . The above 
procedure is essentially a search over a decision tree.  
The conventional SAR ADC does binary search. Starting 
from ambiguity interval[0,2 ]
N
, each comparison cycle it 
cuts ambiguity interval by half, by choosing hypothesis right 
at the center of possibilities interval (ensuring equal size of 
each half). After N  comparison cycles it shrinks ambiguity 
interval to one, ending the search process. The flowchart of 
binary search algorithm is given in Figure 2: 
0 00  2
NLB UB 
For  1:m N
End
ADC output: Ny LB
 
  
1 1
1
1
ˆ 2
ˆ ˆ ˆIf     
ˆElse                     
m m m
m m m m m
m m m m
y LB UB
x x y UB y LB LB
LB y UB UB
 


 
  
 
 
Figure 2  The flowchart of binary search algorithm 
 
3. MAXIMUM ENTROPY REDUCTION SEARCH 
 
An analytical lower bound on average decision cycles for 
a generalized decision tree was presented in [3]. In the case 
of SAR ADC, this limit corresponds to the entropy of the 
ADC output, which can simultaneously be considered as the 
initial value of the ADC output entropy before the search 
outcomes are available: 
   
12
2
0
log
N
n n
n
H y p p


        (1.6) 
where np  denote the probability of the ADC output 
y taking on the value n:  
    Pr Pr 0.5 0.5np y n x n             (1.7) 
The m-th comparison changes ADC output ambiguity 
interval to
mB , and the ADC output entropy after m 
comparison cycle conditioned on 
m mB B  becomes 
   , 2 ,| log
m
m
UB
m m m n m n
n LB
H y B B p p

      (1.8) 
where:  
 
1
, Pr |
m
m
UB
m n m m n n
n LB
p y n B B p p


        (1.9) 
Search algorithm (1.5) ensures that each comparison cycle 
reduces ambiguity interval of ADC output, until it shrinks to 
one. When that happens the output entropy is equal to 0, and 
the search process ends. In order to minimalize search length 
we must choose threshold 1ˆmy   for the (m+1)-th 
comparison cycle in such a way that the post-comparison 
expectation of the ADC output entropy conditioned on the 
previous ambiguity interval
mB is minimal. 
According to (1.5) ambiguity interval 1mB   is fully 
determined by the previous ambiguity interval mB   and 
comparison result 1mz  . It follows that ADC output entropy 
after (m+1) comparison cycle is: 
   1 1 1 1| | ,m m m m m mH y B B H y B B z z        (1.10)
Therefore the expectation of the ADC output entropy after 
the (m+1)-th comparison given previous ambiguity interval 
mB  is average entropy over two possible realizations of 
comparator output 1mz  : 
   1 1
0,1
Pr | ,m m m m m m
z
E z z H y B B z z 

         (1.11) 
which happens to be the conditional entropy of ADC output 
y given comparison result 1mz   conditioned on  m mB B  
 1| ,m m m mE H y z B B       (1.12) 
According to chain rule   
[6]: 
   1 1, | |m m m m m m mE H y z B B H z B B      (1.13) 
where  1, |m m mH y z B B   is joint entropy of y and 1mz   
conditioned on  m mB B . Since the comparison result 
1mz  is completely determined by the ADC output y, 
   1| |m m m m m mE H y B B H z B B       (1.14) 
From (1.14) it follows that to minimize entropy expectation 
after comparison cycle (m+1) we must maximize entropy of 
comparator output in cycle (m+1) , i.e. 
    1min max |m m m mE H z B B    (1.15) 
Therefore we may also call  1 |m m mH z B B   the 
information gain (or entropy reduction) of comparison cycle 
(m+1). Because the comparator output 1mz   is binary, its 
entropy is equal to: 
     1 ,0 2 ,0 ,1 2 ,1| log logm m m z z z zH z B B p p p p         (1.16) 
Where:  
 
1ˆ 1 1
,0 1Pr 0 |
m m
m m
y UB
z m m m n n
n LB n LB
p z B B p p
  

 
       (1.17) 
 
1
1 1
,1 1
ˆ
Pr 1|
m m
m m
UB UB
z m m m n n
n y n LB
p z B B p p

 

 
       (1.18)  
The entropy of binary output is maximized when the 
absolute value of the difference ,0 ,1z zp p  is minimized   
[6]. Therefore optimal threshold for comparison (m+1) is: 
 
1ˆ 1
1 ,0 ,1
ˆ ˆ ˆ
ˆ arg min arg min
m
m
UBy
m z z n n
y y n LB n y
y p p p p


 
 
    
 
 
  (1.19) 
As can be seen the thresholds and comparison outcomes 
are solely determined by the ADC outputs probabilities. The 
flowchart of MER search algorithm is shown in 
Figure 3. 
 
0 0=0, 0,  2
Nm LB UB 
  While 1m mUB LB 
End
ADC output:  my LB
  
1
1
1ˆ 1
ˆ ˆ
1
1
1
ˆ arg min
ˆ ˆ ˆIf      
ˆElse                     
m
m
UBy
m n n
y n LB n y
m m m m m
m m m m
m m
y p p
x x y UB y LB LB
LB y UB UB



 


 
 
  
 
 
 
Figure 3  The flowchart of MER search algorithm 
 
If ADC resolution N is sufficiently high, each comparison 
splits the ADC output ambiguity intervals into two sub-
intervals with almost equal probability and chooses one of 
them, and the probability of the subsequent ambiguity 
interval is decreased by a factor of 2 from the previous one. 
Suppose the input corresponds to ADC output n, and it takes 
M comparison cycles for the MER ADC to locate this 
output. The probability of ambiguity interval after M cycles 
is 0.5M , which for sufficiently large N can always contain 
an arbitrarily small probability mass of a single element, 
np . Therefore the number of comparison cycles to find 
output n approaches  2log np from above, and average 
number of ADC comparison cycles is lower-bounded by 
 
12
2
0
log
N
n n
n
L p p


       (1.20) 
We established that if ADC resolution N is sufficiently large, 
average search length of MER algorithm converges to 
entropy of ADC output, which according to [3] is the lower 
bound. The higher the number of ADC bits, the tighter the 
bound. 
 
4. DECISION TREE EXAMPLE 
 
To illustrate MER ADC operation, let us take example of 
2 bits ADC with input 0.5 3.5x   , quantization step  
=1  and the following output probability distribution:   
0 1 2 30.125,  0.125,  0.25 , 0.5 p p p p      (1.21) 
The decision trees for MER search is shown in figure 4.  
11y 
10y 
01y 
00y 
Cycle  # 1 Cycle  # 2
2.5x 
Cycle  # 3
1.5x 
0.5x 
No
Yes
No
Yes
No
Yes
x
Pr 0.5  
Pr 0.25  
Pr 0.125  
Pr 0.125  
Figure 4  The SAR-ADC MER search decision tree 
The conventional ADC with binary search for every sample 
spends 2 comparison cycles. MER ADC in the worst case, 
for least likely sample spends 3 cycles. However, an average 
number of cycles is equal to: 
3 2 1 01 2 3 3 1.75L p p p p             (1.22) 
It illustrates the savings that MER ADC provides in the 
number of comparison cycles. 
 
5. HARDWARE IMPLEMENTATION 
 
The optimal threshold yˆ  for each comparison cycle may 
be pre-calculated according to (1.19) and stored in decision 
tree memory organized into ( 2 1N  ) nodes. Each node 
contains a comparison threshold yˆ  and two sub-nodes, for 
true and false comparison results respectively. Each sub-
node contains a search stop flag. If this flag is true, then the 
sub-node contains value of ADC output. Otherwise sub-node 
contains the address of a new node. 
Starting from node zero, the MER ADC reads threshold 
associated with current node and compares input signal with 
this threshold. Based on result of this comparison, the ADC 
either reads value of ADC output and stops search process, 
or proceeds to a new node.  
The flowchart of MER search algorithm with decision tree 
memory implementation is shown in Figure 5. The examples 
of memory for MER decision tree which was shown in 
figure 4 is shown in Figure 6. The architecture that 
implements MER ADC with adaptation mechanism is shown 
in Figure 7. 
0Pntr 
 
  ˆIf .   0
Else                             1
Node NodeMemory Pntr
x x NodeThr z
z

 

  .if Node Flag z
 .Pntr Node Pntr z
 ADC output:  .y Node Output z
Yes
No
 
Figure 5  The flowchart of MER search algorithm with 
decision tree memory implementation 
 
ˆNode 0 - 2.5y   ˆ if  =11x y y  else go to Node 1
 ˆ if  =10x y y  else go to Node 2
 ˆ if  =01x y y  else =00y
ˆNode 1 - 1.5y 
ˆNode 2 - 0.5y 
 
Figure 6 The MER search decision tree memory. 
 
N bits 
DAC
Control
Logic
ADC
 Output
y
Comparator
Sample & 
Hold
ADC
Input
x
Sampling 
Clock
xˆ
Calculate
Decision Tree
Decision Tree
Memory
Calculate
PDF
DSP
yˆ
z
 
Figure 7  The adaptive MER SAR ADC 
 
The MER ADC repeats the architecture of conventional 
SAR-ADC (see figure 1) with the following modifications: 
Control logic is equipped with decision tree memory. The 
Digital Signal Processor (DSP) has the ability to modify 
contents of the decision tree memory. At the beginning, 
when there is no prior information about signal statistics it 
stores binary decision tree and ADC operates as the 
conventional SAR ADC.  As the conversion proceeds over 
successive samples, DSP collects statistics of ADC output. 
When statistics of ADC output settles down and input 
probability vector can be calculated, DSP calculates a new 
decision tree and stores it into ADC decision tree memory. 
The ADC starts operating in power saving mode.    
In general, MER ADC needs input elastic buffer to absorb 
the sample-by-sample fluctuation of its cycle number. 
However, many applications that benefit from the ADC 
power saving do not need elastic buffer. Such applications 
typically require transferring a large array of analog data to 
digital form under a total time constraint, but do not impose 
a per-element time constraint. Examples of such applications 
are image processors and massive MIMO receivers. 
 
6. SIMULATION RESULTS 
 
For MER ADC simulation we choose signals with the 
following input distributions: A Gaussian distribution with 
peak-to-RMS ratio 10dB, and a Gaussian mixture that 
consists of two Gaussian distributions, one with a peak-to-
RMS ratio of 10dB, the other 30dB, with likelihood of 0.1 
and 0.9 respectively. First distribution is typical for OFDM 
signal and second one for medical imaging. Simulation 
results are shown in figure 7 and 8. From these figures we 
conclude that when ADC resolution is sufficiently high, the 
average number of MER ADC’s comparison cycles 
approaches the ADC output entropy. 
 
Figure 8  The average number of ADC comparison cycles 
for Gaussian (left) and Gaussian Mixture (right) input 
distributions 
7. CONCLUSIONS 
 
The MER search algorithm provides potentially 
significant reduction of SAR-ADC power consumption for 
signal with low entropy at the ADC output, without 
sacrificing ADC resolution. It may benefit power-sensitive 
applications such as image processing and Massive MIMO. 
  
8. ACKNOWLEDGEMENT 
 
We thank Dr. Matt Miller of Futurewei for his helpful 
comments. 
9. REFERENCES 
 
[1] W.S Liew; L. Yao; Y. Lian, "A moving binary search SAR-
ADC for low power biomedical data acquisition system", 
APCCAS 2008 - 2008 IEEE Asia Pacific Conference on 
Circuits and Systems 
[2]  A.Parthasarathy, “Design and analysis of search algorithms 
for lower power consumption and faster convergence of DAC 
input of SAR-ADC in 65nm CMOS“, 2015 IFIP/IEEE 
International Conference on Very Large Scale Integration   
[3]  Q.R Wang; C.Y. Suen,”Analysis and Design of a Decision 
Tree Based on Entropy Reduction and Its Application to 
Large Character Set Recognition”, IEEE Transactions on 
pattern analysis and machine intelligence, Vol. 6, July 1984   
[4] J. Max, “Quantization for minimum distortion,” IRE 
Transactions on Information Theory, pp. 7–12, March 1960. 
[5] L. Pinals; M. Mai Vu, “Maximum entropy quantization for 
link-state adaptation in two-way relaying”,  MILCOM 2015 
IEEE Military Communications Conference  
[6] T.M Cover, Elements of Information Theory, 2nd Edition, 
Willey, 2006 
 
