High-Speed constant weight codeword generators by Sasao, Tsutomu & Butler, Jon T.
Calhoun: The NPS Institutional Archive
Faculty and Researcher Publications Faculty and Researcher Publications
2011
High-Speed constant weight codeword generators
Sasao, Tsutomu
J. T. Butler and T. Sasao, "Index to constant weight codeword converter," 7th International
Symposium on Applied Reconfigurable Computing, (ARC 2011), March 23-25, 2011, Belfast.
Lecture Notes in Computer Science , 6578, pp.193-205.
http://hdl.handle.net/10945/35822
High-Speed Constant Weight Codeword
Generators
Jon T. Butler1 and Tsutomu Sasao2,
1 Naval Postgraduate School, Monterey, CA, 93921-5121, USA
jon_butler@msn.com
2 Kyushu Institute of Technology, Iizuka, Fukuoka, 820-8502, Japan
sasao@cse.kyutech.ac.jp
Abstract. A constant weight codeword is a binary n-tuple with exactly
r 1’s. We show two circuits that generate constant weight codewords. The
first is based on the combinatorial number system. Its input is an index





n-bit codewords with exactly





)−1. Such a circuit is useful for encoding data. If a ran-
dom constant weight codeword is needed, as in Monte Carlo simulations,
then the index is random. If a random constant weight codeword only is
needed, then our other circuit is even more compact. It is based on a trel-
lis configuration. Both designs can be pipelined to produce one constant
weight codeword per clock period. We give experimental results showing
the efficiency of our designs on the SRC-6 reconfigurable computer.
1 Introduction
The generation of an arbitrary n-bit binary word with a fixed weight r (number
of 1’s) is surprisingly difficult. It is convenient to describe such a word as a
constant weight codeword, even when discussing a non-coding application.
A constant weight code generator is useful in the enumeration of bent Boolean
functions by reconfigurable computer [4,20]. Bent functions are used in crypto-
graphic applications because they are resilient to a linear attack. It is known
that the truth tables of n-variable bent functions have one of only two weights,
2n−1±2n/2−1 [16]. Therefore, instead of testing all 22n n-variable truth tables for
bentness, it is sufficient to enumerate only functions with these weights. Because
the search space of this reduced space is still large, one seeks a Monte Carlo
approach, in which random binary numbers, representing truth tables with a
fixed number of 1’s, are generated.
 We thank Jon Huppenthal, President and CEO of SRC Computers, Inc., Colorado
Springs, CO for data used in this paper. This research is supported by a Grant-in-Aid
for Scientific Research of the Japan Society for the Promotion of Science (JSPS) and
a Knowledge Cluster Initiative (the second stage) of MEXT (Ministry of Education,
Culture, Sports, Science and Technology). Two referees provided suggestions that
improved the manuscript.
A. Koch et al. (Eds.): ARC 2011, LNCS 6578, pp. 193–205, 2011.
c© Springer-Verlag Berlin Heidelberg 2011
194 J.T. Butler and T. Sasao
We have used the constant weight codeword generator in the enumeration
of Boolean functions by reconfigurable computer to determine their correlation
immunity [6]. Correlation immunity is a cryptographic property of Boolean func-
tions used in encryption/decryption to determine the extent to which the input
values can be determined from the output value. We were able to test one func-
tion in each clock period because the index to constant weight code converters
shown here can process at one constant weight code per clock period.
Such circuits have application in other areas. For example, Yamanaka,
Shimizu, and Shan [23] program the lexicographical generation of constant weight
codewords on a reconfigurable computer to analyze energy efficient networks.
Balanced codes, in which there are as many 0’s as 1’s, are useful for encoding
data transferred on and off VLSI chips in a way that minimizes the current fluc-
tuation during switching [21]. In other instances of VLSI data transfer, codes
with small weight are desired because they yield faster and more compact cir-
cuits [21]. Constant weight codes are a countermeasure to “side-channel” attacks
[8]. Such attacks use data dependent differences in power consumption to extract
secret information. Constant weight codes have been used in asynchronous logic
as a means to implement delay-insensitive codes [22]. Three-out-of-six and two-
out-of-seven constant weight codes have been used to build a parallel processor
for neural simulation [9].
The generation of constant weight codewords in lexicographic order has re-
ceived much attention spanning 40 years (c.f. [14]). One of the earliest contri-
butions, Gosper’s “Hack” [7], is an elegant sequence of basic instructions that
can be easily programmed (see also Knuth’s MMIX version [10]). The output is
a sequence of constant weight codewords whose binary number representation
increases each time a codeword is generated. Both normal and reverse lexico-
graphical sequences are useful in heuristics for the generation of sets of codewords
with large cardinality [15]. That is, the generation of codewords in either normal
or reverse lexicographical order is useful in producing large sets of codewords
each a minimum Hamming distance from all other codewords in the set. In-
terestingly, this bin-packing problem, in which one seeks the largest number of
constant weight codewords each no less than a specified Hamming distance from
another codeword, has remained unsolved for 50 years [1,13].
Unfortunately, Gosper’s Hack is not able to convert an index to a constant
weight code corresponding to that index. Thus, it cannot be used in an encoding
algorithm for constant weight codewords or in a Monte Carlo simulation. In both
cases, there is a need to freely choose the sequence of constant weight codewords.
A software version of such an encoding algorithm was developed more than 30
years ago [2], but as far as we know, a hardware implementation has never been
reported.






bit codewords with exactly three 1’s. These can be indexed by a five bit index,
whose value ranges from 0 to 19. The index values 20 through 31 are unused. In
a coding application, the index will be determined by the plaintext message. In
a Monte Carlo simulation, there is an issue related to the index value because
High-Speed Constant Weight Codeword Generators 195
typical random number generators produce a value from 0 to 2n− 1. We discuss
how to deal with this mismatch. Our architecture is a LUT cascade and is simple.
Yet, it produces one constant weight codeword every clock period.
In Section 2, we discuss the combinatorial number system. We show how
it can be used to generate constant weight codes, and we discuss its circuit
implementation. Then, in Section 3, we discuss a trellis circuit for computing
random constant weight codewords and compare its complexity/speed with that
derived from the combinatorial number system. The trellis circuit is an especially
efficient way to generate random constant weight codes. Finally, in Section 4, we
give concluding remarks.
2 The Combinatorial Number System
2.1 Introduction
As in the standard binary number system, in the combinatorial number system,
each number is represented by a unique vector of basis values.


























such that cr > cr−1 > . . . > c1 ≥ 0.






torial number system, where 010 ≤ N ≤ 1910. The rightmost column of Table 1
shows the 6 bit constant weight code corresponding to N . The constant weight,
in this example, is 3, as there are three 1’s in each word. Note that the three
elements of the vector representation of N correspond to the position of the 1 in
the constant weight codeword. For example, 1910 or 543 corresponds to 111000,
while 010 or 210 corresponds to 000111.
(End of Example)
We can make the following observations.






combinatorial number system also has three “digits”.







2. Each set of digits, such that c3 > c2 > c1 ≥ 0, corresponds to a unique
value of N . Each value of N corresponds to a unique set of digits, such that
c3 > c2 > c1 ≥ 0. It can be seen to be true in this example. This was proven





combinatorial number system by Lehmer [12].






Combinatorial Number System for 010 ≤ N ≤ 1910
N c3 c2 c1 Value of N Constant Weight
for k = 3 for k = 3 Codeword















= 10 + 6 + 3 111000















= 10 + 6 + 2 110100















= 10 + 6 + 1 110010















= 10 + 6 + 0 110001















= 10 + 3 + 2 101100















= 10 + 3 + 1 101010















= 10 + 3 + 0 101001















= 10 + 1 + 1 100110















= 10 + 1 + 0 100101















= 10 + 0 + 0 100011















= 4 + 3 + 2 011100















= 4 + 3 + 1 011010















= 4 + 3 + 0 011001















= 4 + 1 + 1 010110















= 4 + 1 + 0 010101















= 4 + 0 + 0 010011















= 1 + 1 + 1 001110















= 1 + 1 + 0 001101















= 1 + 0 + 0 001011















= 0 + 0 + 0 000111
3. Given N , a greedy algorithm derives cr cr−1 . . . c1. For example, in Table
1, the first digit for 1910 can be obtained by finding the largest c3, such that(
c3
3

























= 2010, . . .,




) ≤ 1910−1010 = 910,
etc.
2.2 Circuit Implementation
The keystone of our contribution is a circuit that produces constant weight






number system. Consider, for example, the generation of 6-bit binary words
with three 1’s. Let index be a 5-bit index whose value specifies which of these





= 20 codewords, which we assume are
specified by 0 ≤ index ≤ 19. Let output be a vector of six bits ordered as
output(5) output(4) output(3) output(2) output(1) output(0), three of which are
1 and three of which are 0’s. The pseudo-code for this circuit is as follows.
High-Speed Constant Weight Codeword Generators 197
Set output := 000000.
IF index ≥ (53
)
= 10, Set output(5) := 1 and index := index− 10.
ELSEIF index ≥ (43
)
= 4, Set output(4) := 1 and index := index− 4.
ELSEIF index ≥ (33
)
= 1, Set output(3) := 1 and index := index− 1.
ELSEIF index ≥ (23
)
= 0, Set output(2) := 1 and index := index− 0.
IF index ≥ (42
)
= 6, Set output(4) := 1 and index := index− 6.
ELSEIF index ≥ (32
)
= 3, Set output(3) := 1 and index := index− 3.
ELSEIF index ≥ (22
)
= 1, Set output(2) := 1 and index := index− 1.
ELSEIF index ≥ (12
)
= 0, Set output(1) := 1 and index := index− 0.
IF index ≥ (31
)
= 3, Set output(3) := 1 and index := index− 3.
ELSEIF index ≥ (21
)
= 2, Set output(2) := 1 and index := index− 2.
ELSEIF index ≥ (11
)
= 1, Set output(1) := 1 and index := index− 1.
ELSEIF index ≥ (01
)
= 0, Set output(0) := 1 and index := index− 0.
Each of the three IF statements corresponds to the generation of one 1 bit in the
codeword, where the first generates the leftmost 1 bit, the second the middle 1
bit and the third the rightmost 1 bit. Fig. 1 shows the circuit that computes the
description above. index comes in from the left, and output exits to the right.
Between is a circuit that performs the four operations above. This includes test-
ing the index against a threshold and then performing two operations. The first
sets the output to an appropriate value and the second subtracts an appropriate
value from the index and passes it on to the next stage, which performs a similar
operation. Note that this circuit can be implemented as an r-stage cascade of
combinational circuits [17].
> ( ) 31 
> ( ) 01 
> ( ) 11 
> ( ) 21 
0 
> ( ) 42 
> ( ) 12 
> ( ) 22 









( ) 31 ( ) 21 ( ) 11 ( ) 01 
One-Hot MUX 
> ( ) 43 
( ) 53 ( ) 43 ( ) 33 ( ) 23 
One-Hot MUX 
( ) 53 
> ( ) 23 


































Fig. 1. Example of a Constant Weight Codeword Generator Circuit
198 J.T. Butler and T. Sasao
At each stage, there are inputs and outputs that carry a partially completed
output. Also, there are inputs and outputs that carry index reduced by the values
contributed by higher order digits. The rightmost stage produces a 0 value at
its index output, since there are no digits to the right.
Note that this is easily pipelined. Pipeline registers can simply be inserted
between stages. Doing so, causes the latency to be r, the weight. Note that,
after the first codeword emerges, a codeword emerges at each clock period.
2.3 Results
Fig. 2 shows the result of a program on the SRC-6 reconfigurable computer to
produce random constant weight codewords. The SRC-6 uses the Xilinx Vir-
tex2p XC2VP100 FPGA with Package FF1696 and Speed Grade -5. Here, the
distribution of constant weight codes with n = 6 bits and r = 3 1’s is plotted. A
total of 1,048,576 (= 220) 64-bit random numbers were generated and converted
into random integers from 0 to 19 and applied as indices to the constant weight
code generator. For example, the leftmost bar in Fig. 2 corresponds to 52,079
codewords of the form 000111 (=7), and the rightmost bar corresponds to 52,285
codewords of the form 111000 (=56).















Fig. 2. Distribution of Constant Weight Codewords Produced By the Combinatorial
Number System
The circuit that produced the results in Fig. 2 is shown in Fig. 3. If the
index is a uniformly distributed random integer over the range 010 ≤ N ≤ 1910,
then the output is a uniformly distributed set of constant weight codewords.
However, if index is uniformly distributed over the full range of 5-bit binary
numbers, as is common, then 12 index values have no corresponding constant
weight code. We propose to handle this with a random number to random integer
converter. In this case, we view the random number generator as producing R,
where 0 ≤ R < 1. For example, if the random number generator has 8 bits, then
its output is viewed as 0.0000000 ≤ R ≤ 0.11111111 < 1. To produce a random
integer of value i, where 0 ≤ i ≤ v − 1, we form v × R, which can be achieved
by integer multiplication of v times the 8 bit integer associated with R following
by a division by 256, which corresponds to a right shift by 8 bits. The product
vR involves multiplication by a constant. This is done quickly by addition, shift,
















0 R 1 0 i v-1 0 Rv v 
Fig. 3. Block Diagram of a Random Constant Weight Code Generator
and truncate. Fig. 3 shows the circuit that realizes this. Note that the random
number to random integer converter (i.e. domain converter) consists of all blocks
in Fig. 3 except the CWC Generator.
The complete circuit uses 2,880 out of 88,192 4-input LUTs (3%) and 3,804
out of 88,192 slice flip-flops (4%). It can run at 100.1 MHz, which is slightly
greater than the SRC-6’s operating frequency of 100 MHz. The random number
generator is a cellular automata system proposed by Shackleford, Tanaka, Carter,
and Snider [19]. As shown in Fig. 3, this is multiplied by v (in this specific
example, v = 20). The product is right shifted by 64 bits and truncated. The
result is a uniformly distributed random integer from 0 to 19. This is applied to
the CWC Generator in Fig. 3, which produces the corresponding constant weight
code. A random constant weight codeword is produced at each clock period of
the SRC-6’s 100 MHz clock. This accounts for 1,048,576 clock periods. However,
a total of 1,048,770 clock periods are required. This includes 194 additional clock
periods for initialization, data collection, and overhead. Neglecting the overhead,
this constant weight codeword generator produces 100 million codewords per
second. A C code version of the circuit in Fig. 3 was written and run on the SRC-
6’s 2.8 GHz Xeon microprocessor. Despite its much higher clock frequency, this
implementation produced only 7.6 million random constant weight codewords
per second.
2.4 Complexity of Implementation





combinatorial number system con-
stant weight code generator depends on n and r, we programmed this system for
various n and r. Because the SRC-6, with its 130 nm Xilinx Virtex 2p XC2VP100,
is a legacy system, we chose the 40 nm Altera Stratix IV EP4SE530F43C3NES
FPGA. This is to be used on the SRC Company’s newest version of the SRC-7.
Table 2 shows the frequency obtained and the resources used in this implementa-
tion. A large codeword is achievable (128 bits using 91% of the available ALMs).
Although this table shows only balanced constant weight code generators where
the number of bits is a power of 2, our approach applies to any number of bits
and to any weight.
200 J.T. Butler and T. Sasao
Table 2. Frequency and resources used to realize combinatorial number system con-
stant weight code generators on the Altera Stratix IV EP4SE530F43C3NES FPGA




































125 95.8 163 1,422 15,902 14,551 354,448 194,950(91%) 430,608(3%)
The second column in Table 2 also shows the number of bits needed to rep-











) + 1. A naive description in which this was computed as
log2 n!r!(n−r)! + 1 was not able to give correct results for the bottom half of
the table because of the very large value of n!. Therefore, this computation was
performed as ∑ni=1 log2i− 2
∑n/2
i=1 log2i+ 1. The Verilog compiler used to im-
plement the circuits lacks the word size to compute n! for moderate n. Also, it is
not capable of computing the log2 function. Instead, a MATLAB program was
used. This produced values that were written to a header file that was included
in the Verilog code. Similarly, to realize the circuits represented in Table 2, it





, which cannot be realized by 32 bits for moderate
values of n and r. Another MATLAB program was written that computed these
values and printed them to a header file that was included in the Verilog code.
3 Trellis Generator
3.1 Introduction
An alternative approach for generating random constant weight binary num-
bers is the trellis circuit. We know of no prior work on this approach except a
description in a Japanese book [18] of a program to generate random constant
weight codes. A hardware implementation of this is as follows. Fig. 4 shows the
trellis circuit of a random constant-weight binary number generator with 6 bits
of weight 3. Each bit is generated one at a time starting at top. A complete n-bit
number is generated after n clock periods. However, this circuit is pipelined, so
that thereafter, a 6-bit binary number of weight 3 is generated at every clock
period.
At the top node, the left bit is 0/1 with probability 50%/50%. Depending











(1). At this point, a similar process takes place. In this case, the













  1 
0 1 
 ( ) 21 
 ( ) 63 
 ( ) 00 
 ( ) 43  ( ) 42  ( ) 41 
 ( ) 33  ( ) 32  ( ) 31  ( ) 30 
 ( ) 22  ( ) 20 
 ( ) 11  ( ) 10















1 0 0 









0 1 1 1 0 0 
0 1 1 1 0 
1 0 1 1 
0 1 1 1 
Random 
Integers 
Fig. 4. Trellis Circuit
probability of a 0 or 1 bit adjusts so that each n-bit number of weight r has the






, 0 and 1 are generated with probability 40% and 60%, while, in the





, 0 and 1 are generated with probability 60% and
40%.
The probabilities required for each level are generated by the circuit along the
right side of Fig. 4. This circuit generates an integer between 0 and m− 1 > 1,
where m is the level. The top level corresponds to m = n, the next lower level
to m = n − 1, etc.. The nodes in the trellis then convert this number into a
0 or 1, as needed at that node. For example, for m = 4, the right-side integer




, a threshold of 1 is used to produce 0 with a probability of 25% (0) and









use thresholds 2 and 3, respectively. We note that the generation of one
uniformly distributed integer at level n is sufficient because only one bit of a
random constant-weight binary number is generated at that level.
3.2 Circuit Implementation
The trellis can be implemented by a pipeline with n stages. In each stage, the
(partially completed) constant weight code is processed and passed to the next
stage, as suggested by the words shown along the right side of Fig. 4. Fig. 5
shows the pipeline implementation of the trellis circuit. The block labeled RNG
(random number generator) in each stage determines exactly one bit. Whether
it is a 0 or 1 is determined at random by a probability that depends on the
number of 1 bits generated so far. For example, if all of the r 1 bits occur in the
previous stages, then the probability that a 0 is produced by RNG is 100%.




























Fig. 5. Block Diagram of the Trellis Constant Weight Code Generator
3.3 Results
Fig. 6 shows the distribution of constant weight codes when 1,048,576 (= 220)
sets of random numbers are generated and applied to the trellis circuit. This was
programmed on the SRC-6. For the Xilinx Virtex2p XC2VP100 FPGA used in
this system, the complete circuit uses 2,767 out of 88,192 4-input LUTs (3%)
and 3,795 out of 88,192 slice flip-flops (4%). It can run at 106.2 MHz, which ac-
commodates the SRC-6’s fixed 100 MHz clock. It produces one constant weight
codeword at each 100 MHz clock cycle, and takes a total of 1,048,766 clock cy-
cles. This includes 90 clock periods in addition to those 1,048,576 clock cycles
that each produce a constant weight codeword. Each level in the trellis uses a
16 bit random number generator that creates a random integer generator, as de-
scribed above. Note that the resources just described include circuits needed to
implement overhead functions like data collection. Neglecting the overhead, the
trellis random constant weight codeword generator produces 100 million code-
words per second. A C code version of the circuit in Fig. 5 was written and run
on the SRC-6’s 2.8 GHz Xeon microprocessor. Despite its much higher clock fre-
quency, this implementation produced only 57.2 million random constant weight
codewords per second.















Fig. 6. Distribution of Constant Weight Codewords Produced by the Trellis Circuit
High-Speed Constant Weight Codeword Generators 203
3.4 Complexity of Implementation
Like the combinatorial number system constant weight codeword generator, the
trellis was programmed on the Altera Stratix IV EP4SE530F43C3NES FPGA.
Table 3 shows the resource usage and frequency for various types of constant
weight codewords. Unlike the combinatorial number system constant weight
codeword generator, 256-bit constant weight codewords with 128 1’s can be easily
implemented within one FPGA. The Estimated Number of ALMs increases by
a factor of more than 2 for each one line advance in Table 3. A similar statement
is approximately true of the column labeled Total Number of Registers. The
resources shown in Table 3 do not cover the circuits that perform the overhead
functions, such as data collection; they include only the trellis circuit.
Table 3. Frequency and resources used to realize a trellis constant weight code gener-
ator on the Altera Stratix IV EP4SE530F43C3NES FPGA









































174.9 1 2,757 2,363 10,653 4,673 11,309 (5%) 8,011 (1%)
4 Concluding Remarks
Although there is a need for a circuit that computes constant weight code-
words from indices, we have not seen an implementation. Our results are useful,
for example, in the encoding/decoding of data, such as between on-chip and
off-chip and in asynchronous circuits. We show two approaches 1) a combi-
natorial number system implementation and a 2) trellis implementation. The
combinatorial number system can be implemented as a pipeline producing a
constant weight codeword at each clock. For a constant weight code of n bits,
of which r are 1, the pipeline is r stages long. If one only wants to produce
random constant weight codewords, for example in Monte Carlo simulations,
the trellis is also implemented efficiently. Its pipeline is n stages long. The trel-
lis requires less resources and operates at a higher frequency. We have imple-
mented both designs on the SRC-6 reconfigurable computer and on an Altera
Stratix IV EP4SE530F43C3NES FPGA. This has shown that both are efficiently
implemented.
204 J.T. Butler and T. Sasao
We remark on two extensions of our results. First, both circuits can be im-
plemented as combinational logic. Indeed, the diagrams, Figs. 1 and 5, show
them as combinational logic. Second, in both circuits, the probability of certain
codewords can be controlled.
References
1. Brouwer, A.E., Shearer, J.B., Sloane, N.J.A., Smith, W.D.: A new table of constant
weight codes. IEEE Trans. Infor. Theory 36(6), 1134–1380 (1990)
2. Buckles, B.P., Lybanon, M.: Algorithm 515: Generation of a vector from the lexico-
graphical index [G6]. ACM Transactions on Mathematical Software 3(2), 180–182
(1977)
3. Bubniak, G., Goralczyk, M., Karp, M., Kokosinski, Z.: A hardware implementation
of a generator of (n,k)-combinations. In: Proc. IFAC Workshop Programmable
Digital Systems, PDS 2004, Krakow, pp. 228–231 (2004)
4. Butler, J.T., Sasao, T.: Boolean functions for cryptography. In: Progress in Appli-
cations of Boolean Functions, pp. 33–54. Morgan & Claypool Publishers (2010)
5. Combinadic, http://en.wikipedia.org/wiki/Combinadic
6. Etherington, C.: An analysis of cryptographically significant functions with high
correlation immunity by reconfigurable computer, M.S. Thesis (December 2010)
7. Gosper, R. W. Item 175 in Beeler, M., Gosper, R. W., and Schroeppel, R., HAK-
MEM, MIT Artificial Intelligence Laboratory, Memo AIM-239, Cambridge (Febru-
ary 1972), http://www.inwap.com/pdp10/hbaker/hakmem/hacks.html#item175
8. http://en.wikipedia.org/wiki/Side_channel_attack
9. Khan, M.M., Lester, D.R., Plana, L.A., Rast, A., Jin, X., Painkras, E., Furber, S.B.:
SpiNNaker: mapping neural networks onto a massively-parallel chip multiprocessor.
In: Inter. Joint Conf. on Neural Networks (IJCNN), pp. 2850–2857 (2008)
10. Knuth, D.E.: The Art of Computer Programming. Bitwise Tricks and Techniques
4(Fascicle 1), 152, ISBN 0-321-58050-8
11. Knuth, D.E.: The Art of Computer Programming. Generating All Combinations
and Partitions 4(Fascicle 3), 5–6 (2009) ISBN 0-321-58050-8
12. Lehmer, D.H.: The machine tools of combinatorics. In: Beckenbach, E.F. (ed.)
Applied Combinatorial Mathematics, pp. 5–30. Wiley, New York (1964)
13. MacWilliams, F.J., Sloane, N.J.A.: The Theory of Error-Correcting Codes. North-
Holland, Amsterdam (1977)
14. Nijenhuis, A., Wilf, H.S.: Combinatorial Algorithms, 2nd edn. Academic Press,
London (1978)
15. Montemanni, R., Smith, D.H.: Heuristic algorithms for contructing binary constant
weight codes. IEEE Trans. on Inform. Theory 55(10), 4651–4656 (2010)
16. Rothaus, O.S.: On ‘bent’ functions. J. Combinatorial Theory, Ser. A 20, 300–305
(1976)
17. Sasao, T.: Memory Based Logic Synthesis, 1st edn. Springer, Heidelberg (2011)
ISBN 978-1-4419-8103-5
18. Senba, I.: Combinatorial Algorithms (in Japanese). Science Inc., Tokyo (1989)
19. Shackleford, B., Tanaka, M., Carter, T., Snider, G.: High-performance cellular au-
tomata random number generators for embedded probabilistic computing systems.
In: Proc. of 2002 NASA/DOD Conf. on Evolvable Hardware, July 2002, pp. 191–
200. IEEE Computer Society, Los Alamitos (2002)
High-Speed Constant Weight Codeword Generators 205
20. Shafer, J.L., Schneider, S.W., Butler, J.T., Stanica, P.: Enumeration of bent
Boolean functions by reconfigurable computer. In: The 18th Annual Inter. IEEE
Symp. on Field-Programmable Custom Comput. Mach. (FCCM 2010), Charlotte,
NC, May 2-4, pp. 265–272 (2010)
21. Tallini, L.G., Bose, B.: Design of balanced and constant weight codes for VLSI
systems. IEEE Trans. on Computers 47(5), 556–572 (1998)
22. Verhoeff, T.: Delay-insensitive codes - an overview. Distr. Comp. 3(1), 1–8 (1988)
23. Yamanaka, N., Shimizu, S., Shan, G.: Energy efficient network design tool for
green IP/ethernet networks. In: ONDM 2010, Kyoto, Japan, January 31-February
3 (2010)
