Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
WEIGHTLESS BINARY N-TUPLE THRESHOLDING HIERARCHIES
Document Type and Number:
WIPO Patent Application WO/1999/032962
Kind Code:
A1
Abstract:
A novel architecture is described for applying a sum and threshold function to a weightless input string and a weightless threshold string. The sum and threshold function is carried out by distributing the input bits in random manner (12) between a number of sum and threshold devices (14), whose outputs are supplied to a second layer of one or more sum and threshold devices (16).

Inventors:
KING DOUGLAS BEVERLEY STEVENSO (GB)
MACDIARMID IAN PETER (GB)
MOORE COLIN (GB)
Application Number:
PCT/GB1998/003837
Publication Date:
July 01, 1999
Filing Date:
December 18, 1998
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
BRITISH AEROSPACE (GB)
KING DOUGLAS BEVERLEY STEVENSO (GB)
MACDIARMID IAN PETER (GB)
MOORE COLIN (GB)
International Classes:
G06F7/02; G06K9/64; G06N3/063; G06T5/20; H03M7/16; (IPC1-7): G06F7/02; G06F15/80
Foreign References:
US5623519A1997-04-22
Other References:
HANDS M A ET AL: "PROPOSAL FOR STOCHASTIC BIT STREAM PROCESSING USING OPTOELECTRONIC SMART PIXELS: A NEURAL NETWORK ARCHITECTURAL CASE STUDY", JOURNAL OF PARALLEL AND DISTRIBUTED COMPUTING, vol. 41, no. 1, 25 February 1997 (1997-02-25), pages 92 - 108, XP000655686
LEIGHTON T ET AL: "ON PROBABILISTIC NETWORKS FOR SELECTION, MERGING, AND SORTING", 7TH.ANNUAL ACM SYMPOSIUM ON PARALLEL ALGORITHMS AND ARCHITECTURES SPAA '95, SANTA BARBARA, JULY 17 - 19, 1995, no. SYMP. 6, 17 July 1995 (1995-07-17), ASSOCIATION FOR COMPUTING MACHINERY, pages 106 - 118, XP000659882
Attorney, Agent or Firm:
Newell, William Joseph (Laine and James 22 Rodney Road Cheltenham Gloucestershire GL50 1JJ, GB)
Download PDF:
Claims:
Claims
1. A weightless binary comparator for comparing the Hamming value of N weightless inputs with a threshold T and for indicating if said Hamming value passes said threshold, which comprises: means for applying respective subgroups of said weightless inputs to sum and threshold means, means for applying a threshold value to each of said sum and threshold means, and means for passing the outputs of said sum and threshold means to a sum and threshold means for providing an output indicative of whether the Hamming value of the weightless inputs passes said threshold.
2. A weightless binary comparator according to Claim 1, wherein said threshold T is a weightless binary value.
3. A weightless binary comparator according to Claim 1 or Claim 2, including means for randomising or distributing in nonordered fashion said inputs to said sum and threshold means.
4. A weightless binary comparator according any of the preceding Claims, which inclues a plurality of respective sum and threshold means for each of said sub groups of inputs, and the outputs of said plurality of sum and threshold means are passed to a further sum and threshold means.
5. A weightless binary comparator according to Claim 4, wherein the same threshold value is applied to each of said sum and threshold means.
6. A weightless binary comparator according to Claim 4, wherein different threshold values are applied to the sum and threshold means.
7. A weightless binary comparator according to any one of Claims 1 to 3, which inclues a hierarchy of more than two layers of sum and threshold means, wherein respective sub groups of said weightless inputs are applied to respective sum and threshold means in a first layer of said hierarchy, respective sets of the outputs of said first layer of sum and threshold means are applied to respective sum and threshold means in a second layer, and respective sets of said outputs of said second layer of sum and threshold means are applied to one or more further layers of one or more sum and threshold means, to obtain said output.
8. A weightless binary comparator according to Claim 1, which inclues means for supplying to a single sum and threshold means said sub groups of said weightless inputs in sequence, means for storing the output from the sum and threshold means for each said subgroup, and means thereafter for passing said stored outputs to said sum and threshold means to obtain said output indicative of whether the Hamming value of the weightless inputs passes said thresh old.
9. A method of comparing the Hamming value of N weightless inputs with a threshold T, which comprises applying a sum and threshold operation to respective subgroups of said inputs to obtain respective outputs, and applying a sum and threshold operation to said respective outputs to obtain an output indicative of whether the Hamming value of said weightless inputs passes said threshold.
10. A method according to Claim 9, wherein said threshold T is a weightless binary value.
11. Apparats for processing weightless binary input data, which comprises: a plurality of processing modules each for operating on a plurality of bits of said input data and providing an output, means for distributing respective bits from said weightless binary input data between respective processing modules, and means for passing output data from said processing modules to a processing module to provide a processed output.
12. Apparats according to Claim 11, wherein said processing modules each apply the same processing operation to input data.
13. Apparats according to Claim 11 or Claim 12, wherein said processed output comprises a single bit.
14. A method for processing weightless binary input data, which comprises: providing a plurality of processing modules each for operating on a plurality of bits of input data and providing an output; distributing respective bits from said weightless binary input data between respective processing modules, and passing output data from said processing modules to a processing module to provide a processed output.
Description:
Weiqhtless Binary N-Tuple ThresholdinqHierarchies This invention relates to weightless binary n-tuple thresholding hierarchies, and in particular, but not exclusively to weightless binary Hamming value comparators and related methods, for use, for example in weightless binary neural networks.

There are very many applications where a large number of weightless binary inputs need to be summed and compare to a threshold value. For example in the template matcher or neural pattern correlators described in our co-pending International Patent Applications Nos. PCT/GB98/......

PCT/GB98/....., PCT/GB98/....., or PCT/GB98/..... (our references 03-7127, XA1154, XA1155, XA1156), require or provide architectures for carrying out summing and thresholding of binary weightless strings. The entire contents of the above Applications are incorporated herein by reference.

Conventional systems are synchronous using clocked counters or registered accumulators or clock-based machine/processor technology, but these suffer from high noise, low speed and are not particularly fault tolerant.

It is therefore an aim of this invention to provide improved forms of weightless binary Hamming value comparators, and in particular tuple thresholding hierarchies for weightless binary neural networks. The inventors have found that it is practical to use probabilistic rather than deterministic methods for

performing a sum and threshold function for large numbers of inputs and have developed novel hierarchies for distributed template matching and weightless binary neural network pattern detection.

Accordingly in one aspect this invention provides a weightless binary comparator for comparing the Hamming value of N weightless inputs with a threshold T and for indicating if said Hamming value passes said threshold, which comprises:- means for applying respective sub-groups of said weightless inputs to sum and threshold means, means for applying a threshold value to each of said sum and threshold means, and means for passing the outputs of said sum and threshold means to a sum and threshold means for providing an output indicative of whether the Hamming value of the weightless inputs passes said threshold.

Preferably, said threshold is a weightless threshold.

In another aspect this invention provides a method of comparing the Hamming value of N weightless inputs with a threshold T, which comprises applying a sum and threshold operation to respective subgroups of said inputs to obtain respective outputs, and applying a sum and threshold operation to said respective outputs to obtain an output indicative of whether the Hamming value of said weightless inputs passes said threshold.

Preferably, said threshold is a weightless threshold.

In another aspect, this invention provides apparats

for processing weightless binary input data, which comprises:- a plurality of processing modules each for operating on a plurality of bits of said input data and providing an output, means for distributing respective bits from said weightless binary input data between respective processing modules, and means for passing output data from said processing modules to a processing module to provide a processed output.

In a further aspect, this invention provides a method for processing weightless binary input data, which comprises:- providing a plurality of processing modules each for operating on a plurality of bits of input data and providing an output; distributing respective bits from said weightless binary input data between respective processing modules, and passing output data from said processing modules to a processing module to provide a processed output.

Whilst the invention has been described above it extends to any inventive combination of the features set out above or in the following description.

The invention may be performed in various ways, and embodiments thereof will now be described in detail, by way of example only, reference being made to the accompanying

drawings, in which:- Figure 1 is a schematic view of an embodiment of a weightless binary N-tuple threshold comparator in accordance with this invention; Figure 2 is a diagram of an embodiment of a weightless binary N-tuple threshold hierarchy.

Figure 3 is a diagram of an embodiment of a distributed threshold N-tuple comparator in accordance with this invention; Figure 4 is a block diagram of an embodiment of a variable sum-and-threshold block size N-tuple comparator in accordance with this invention; Figure 5 is a schematic diagram showing random mapping of data projecte onto hierarchical threshold detectors; Figure 6 is an embodiment of a hybrid semi-parallel, semi-asynchronous N-tuple threshold comparator; Figure 7 is a block diagram of an embodiment of a hybrid semi-parallel, semi-asynchronous N-tuple threshold hierarchy as set out in Figure 6; Figures 8 (a), (b), (c), (d) and (e) are diagrams of various bit manipulation cells used in the comparator of Figure 7.

The embodiments described below address the problem of applying a sum and threshold operation when the number of weightless input and weightless threshold bits is very large. An example is given in Figure 1 of the accompanying drawings where there are 1024 weightless input bits and 1024 weightless threshold bits, and the sum and threshold device

must provide a single bit output indicating whether the sum of the weightless inputs exceeds the sum of the weightless threshold bits. The need for such a comparison is common in pattern matching and template matching in neural networks.

The embodiments described below take the threshold comparator and consider its hierarchical applications to distributed template matching and weightless binary neural network feature detection.

Referring to Figure 2, a device is shown for performing a sum and threshold operation on the 1024 template matcher bits in a template matcher. This could for example be a novel template matcher of the type described in one or more of our co-pending Applications referred to above. The block 10 of 1024 template matcher bits is randomise by a random connection block 12 to provide thirty two groups of thirty two bits. Each group of bits passes to a respective one of thirty two sum and threshold devices 14. The single bit outputs of the thirty two sum and threshold devices 14 pass as inputs to a single, second layer sum and threshold device 16 which provides a single bit result. In this example, the threshold supplie to all the sum and threshold devices 14 and to the output sum and threshold device 16 is the same and is a thirty two bit weightless input applied on a bus 18.

In a standard mode of operation, the actual required threshold is scaled by thirty two (because there are thirty two sum and threshold devices). Thus, with an input of 1024 bits, if the actual threshold required was 512, the thresh-

old applied on line 18 would be sixteen (512. 32). Each sum and threshold device may either be of conventional form or one of the novel Hamming value comparators described in one or more of our co-pending Applications.

Statistically it can be shown that it is important that there are many (for example more than sixteen) inputs to each sum and threshold element 14,16. The actual selection of the number of inputs is a trade-off between a higher number giving a better resolution and a lower number reducing the complexity of the device. The embodiments of this invention rely on a probabilistic rather than deterministic analysis.

In other words it is assumed that if, say, 640 input bits are 1's the random connection block will distribute these set bits evenly between the sum and threshold devices of the first layer, with each sum and threshold device receiving an average of twenty set bits. Of course, in practice, some sum and threshold devices are likely to receive more and some less. Assuming that the actual threshold against which the sum of the input bits is to be compare is 608, this will be scaled as described above so that the threshold bits supplie to each sum and threshold device 14,16, will be exactly 19. Provided that the input bits are randomly distributed between the sum and threshold devices 14 of the first layer, it is likely that most of the first layer sum and threshold devices will fire because the number of weightless inputs exceeds 19. The outputs of the first layer sum and threshold devices 14 will then be summed

and compare with the value 19 again and, in most instances, the second layer sum and threshold device will fire.

In the above example the number of trials, 1024, has been chosen for experimental reasons to form 32 tuples each of 32 weightless elements. Each tuple is a sample of the population. The"weak law of large numbers"states that the tuple mean approches the true mean as the tuple size approches infinity, in accordance with the central limit theorem. For small tuple sizes, an unacceptably large error is introduced. For tuple sizes greater than approximately 16, the technique is practically viable.

It is important to randomly connect the pattern matcher outputs between the data space and the hierarchical struc- ture because the pattern matchers can often"clump"results, e. g. 1111111011000000001 is typical of a non-random matcher result-in this case showing a skewing of 1's to the left.

In practice the skew may be in any position.

The matcher bit results are usually required to be of the form of a Bernouilli trial-i. e. the probability distribution for the 1's and O's should be uniformly distributed by deliberately making random wiring connec- tions. Each of the first layer sum and threshold devices 14 of Figure 2 is seen to randomly sample the data space.

There may be certain applications that do not want this random mapping-in general, if the trials are not of the Bernouilli form there will need to be a greater bias in the quantity of 1's before the n-tuple threshold detector "fires". In neural systems this could be important-data

uniformly distributed and applied will"fire"more readily than skewed data. Hence the network will tend to reject skewed data. This is a feature lacking in the prior art.

Hence the inclusion of the"randomiser"is application dependent. As the data size and tuple size increase, the result, statistically, tends towards ideal.

Figure 3 shows a second embodiment of generally similar form to that of Figure 2, except that it provides the use of different thresholds for each sum and threshold device 14, 16 in the hierarchy. The randomiser block 12 would not normally be used in this modification. There could exist threshold profiles e. g. for the n=32 bit example, the thresholds for the first layer could be:- For Tl to T32 12 12 13 13 14 14 14 15 15 15 16 16 16 17 18 19 19 18 17 16 16 16 12 12 15 14 14 14 13 13 12 12 (the threshold profile does not have to be symmetrical) The second layer threshold could be 17. Thresholds would be chosen according to application. This idea may be applied to the analysis of signals impinging a phased array signal detector. Also, in visual pattern detection, a bias in terms of exceeding a threshold may need to be given to certain areas of the image.

Another modification is shown in Figure 4 in which several layers of groups or cells of sum and threshold devices may be used. For example in the example shown the

template matcher has 30 x 27 x 24 bits, and this is accommo- dated by providing in the first layer 24 groups each of 27 sum and threshold devices each having 30 inputs, and ending in a third layer comprising a single 24 input sum and threshold device 18. Like components are given like reference numerals.

It should be noted that the embodiments described herein are applicable to 1D, 2D and 3D data spaces as highlighted in Figure 5. Figure 5 also shows that a system may comprise a plurality of hierarchical threshold detectors operating on a template matcher surface or volume.

Referring now to Figure 6, a combination of the prior art (clocked devices) with the sum and threshold (Hamming value comparator) techniques described in our co-pending International Patent Applications yields a hybrid solution.

Figure 6 shows a hybrid block diagram for the implementation of Figure 2. The random connections are not shown.

In the example of Figure 6 the comparator is shown performing a sum and thresholding operation on 1024 bits.

There is a single 32 bit sum and threshold device 20 receiving the usual 32 bit weightless threshold and provid- ing a single output bit which at intermediate stages of the sum and threshold operation is passed to a serial in parallel out (SIPO) shift register 22. At the final stage, the output bit of the sum and threshold device 20 is made available as the final result. Incoming randomise data of 32 bit width is supplie on line 26 to the multiplexer 24.

During intermediate stages, the select multiplexer passes

the 32 bit data to the input of the sum and threshold device 20. The SIPO shift register 22 operates as a partial result store and once 32 sum and threshold operations have been carried out the select multiplexer 24 passes the 32 bit data from the SIPO shift register 22 to the sum and threshold device 20 to obtain the final single bit result.

It should be noted that the above embodiment could be modifie to be either fully parallel or fully asynchronous.

Referring now to Figure 7 there is shown a more detailed view of an arrangement of the type shown in Figure 6 although the example of Figure 7 operates on 16 bit data.

In Figure 7, the sum and threshold device 20 is constituted by an array 28 of five different types of bit manipulation cells. The cells are identifie as weightless cross Hamming elimination cells 30 (Figure 8 (a)); weightless shift down cells 32 (Figure 8 (b)); weightless OR up edge cells 34; (Figure 8 (c)); weightless shift up cells 36 (Figure 8 (d)), and weightless OR down edge cells 38 (Figure 8 (e)). This device is similar to those described in our co-pending International Patent Applications. The array is symmetrical along the horizontal mid-line. Cells actually appearing on the mid-line comprise weightless cross Hamming elimination cells 30 having a structure and logic arrangement as shown in Figure 8 (a). Bit manipulation cells above the horizontal mid-line (and not affecte by truncation from layers five onwards) are weightless shift down cells 32 having a structure and a logic shown in Figure 8 (b). Truncated cells in the upper part comprise weightless OR down edge cells 34

of the structure and logic arrangement shown in Figure 8 (c).

In the lower half of the array, the complete cells not affecte by truncation are weightless shift up cells 36 of the type shown in Figure 8 (d) and those affecte by trun- cation are weightless OR up edge cells 38 of the type shown in Figure 8 (e). The array operates in a similar fashion to the Hamming value comparator and acts to aggregate set bits in the threshold tuple and the input tuple towards the centre whilst also performing an elimination operation to cancel bits which are set in the same bit position in the threshold and input tuples. The outputs from the final weightless cross Hamming elimination cell 30 are supplie to a decoder 40 which sets a bit at its output if the number of weightless bits at its input are greater than those at the threshold input. As in Figure 6, the output of the sum and threshold device passes to a SIPO shift register 22 whose output passes to one port of a select multiplexer 24, the other port receiving incoming data on line 26. The threshold is supplie along line 42.

It should be noted that the random connections are not shown in Figure 7.

In general the implementation of the above arrangement is technology independent; electronic, ionic, magnetic, or electro-magnetic (e. g. optical) implementations are all suitable.