**Presentation Slides** 

### Chapters 1 and 2

### A Sufficiently Expressive Logic

### Logically Determined Design: Clockless System Design With NULL Convention Logic

by Karl Fant

#### John Wiley & Sons, Inc.

Introduce NULL Convention Logic

Diagrams by permission of John Wiley & Sons, Inc.

# **Boolean Logic is an Insufficient Logic**

- The mathematical notion of the function is a stateless data mapping with no expression of coordination.
- A composition of functions forms a concurrent network.
- The behavior of the network of functions is traditionally coordinated by a mathematician with a pencil who manages the flow of data and the instantiation of each function in its proper order.





- Without the coordinating mathematician Boolean logic is insufficiently expressive.
- Transitions race indiscriminately through the concurrent network causing a large number of erroneous values before the expression stabilizes to a correct resolution of the presented input



|           |         | ບາທານຕ    |         |           |         |
|-----------|---------|-----------|---------|-----------|---------|
| erroneous | correct | erroneous | correct | erroneous | correct |
|           |         |           |         |           |         |

• There is no way to determine from the behavior of the network of functions when the output has stabilized to the correct resolution of presented data or even when new data has been presented.

# **Boolean Logic Cannot Work Alone**

### The Crux of the Matter The missing coordination behavior of the absent mathematician Supplement Boolean Logic

With stable input the circuit will eventually settle to a correct result.



Express correct logical behavior with a time interval.

Ignore the erroneous behavior and sample the correct output at the end of the interval.

error isolating

memory

result sampling

Logical behavior blurrs into

interval signal

a single timed behavior.

Further composition is in terms of identical time intervals and shared memories bounding the instantiation and resolution of each logic expression.



Coordination is restored with the imposition of a non-logical expression of time and memory

#### Not the mathematician's coordination behavior, but the scheme can be made to work with sufficient engineering attention.

Page 3

### Define A Sufficient Logic The NULL Convention

We assume a representation of data with two disjoint value domains, one expressing "data" and one explicitly expressing "not data", which we will call NULL. A data path presents successive data sets by monotonically transitioning between "completely data" and "completely



### **The Completeness Criterion**

An operation;

- transitions its output to DATA only when its input is "completely DATA,
- transitions its output to NULL only when its input is "completely NULL" and
- maintains its output when its input is neither "completely DATA nor "completely NULL"

A two input operator will transition its output to D only when both inputs are D and transition its output to N only when both inputs are N. Otherwise it will not transition its output –.



#### The transition of the output implies the completeness of the input.

### **NULL Convention Logics** 3 value NULL convention Logic: 3NCL

The completeness criterion applied to Boolean Logic results in a three value logic



2 value NULL convention Logic: 2NCL

One data value and NULL With only one data value the only discriminable property when presenting input data is how many data values are presented so 2NCL is a threshold logic with state holding behavior.

When the number of input data values matches the threshold the threshold operator transitions its output to DATA.

When all input values become NULL the threshold operator transitions its output to NULL.



# **NULL Convention Logic**

The number inside the operator is the threshold for the number of indicated inputs.



# **NCL Example Circuits**

2NCL is a subvariable logic operating directly on values between variable boundaries.



Binary-trinary-quaternary adder Page 7

Х

Binary full-adder as two half-adders and OR

### **Multi-Rail/Multi-Value Variables**

The most primitive element of a data path, a single wire, can assert only two values. One value must represent NULL so there can only be one data value which we will call DATA. With only one data value, an M value variable is expressed with M wires only one of which will express its DATA value at a time.

|                              | Wire numeric base 2 meanings |                                              |                                                           |                                           |                            |   | Wire Logical meanings                                                                                     |               |
|------------------------------|------------------------------|----------------------------------------------|-----------------------------------------------------------|-------------------------------------------|----------------------------|---|-----------------------------------------------------------------------------------------------------------|---------------|
|                              |                              | NULL                                         | 0                                                         | 1                                         |                            |   | NULL TRUE FALSE                                                                                           |               |
|                              | #1                           | <sup>-</sup> N                               | D                                                         | Ν                                         |                            |   | #1 — N D N                                                                                                |               |
|                              | #2 —                         | - N                                          | Ν                                                         | D                                         |                            |   | #2 — N N D                                                                                                |               |
| Wire numeric base 4 meanings |                              |                                              |                                                           |                                           | eanings                    |   | Wire general meanings                                                                                     |               |
|                              | NULL                         | 0                                            | 1                                                         |                                           | 2                          | 3 | NULL Animal Vegetable Mineral                                                                             |               |
| #1 —                         | — N                          | D                                            | Ν                                                         |                                           | N                          | N | #1 N N N                                                                                                  |               |
| #2 —                         | — N                          | Ň                                            | D                                                         |                                           | N                          | N | #2 — N N D N                                                                                              |               |
| #3 —                         | — N                          | N                                            | N                                                         |                                           | D                          | N | #3 — N N N D                                                                                              |               |
| #4 —                         | — N                          | Ν                                            | Ν                                                         |                                           | Ν                          | D |                                                                                                           |               |
| Wire<br>#1<br>#2<br>#3       | n<br>N<br>N<br>N<br>N        | umeric<br>1 2 3 4<br>D N N<br>N D N<br>N N D | <b>base 1</b><br>4 5 6 7<br>N N N N<br>N N N N<br>N N N N | 0 mea<br>8 9 (<br>1 N N<br>1 N N<br>1 N N | anings<br>)<br>N<br>N<br>N | _ | Wire control meanings<br><u>NULL Select A Select B Select C</u><br>#1 N D N N<br>#2 N N D N<br>#3 N N N D |               |
| #4                           | — N                          | NNN                                          | DNNN                                                      | INN                                       | N                          |   | Wire other meanings                                                                                       |               |
| #5                           | — N                          | ΝΝΝ                                          | NDNN                                                      | INN                                       | N                          |   | <u>NULL First Second Third Fo</u>                                                                         | <u>ourt</u> h |
| #6                           | — N                          | ΝΝΝ                                          | NNDN                                                      | INN                                       | N                          |   | #1 N D N N                                                                                                | Ν             |
| #7                           | — N                          | NNN                                          | NNNC                                                      | ) N N                                     | Ν                          |   | #2 — N N D N                                                                                              | Ν             |
| #8                           | — N                          | ΝΝΝ                                          | ΝΝΝΝ                                                      | I D N                                     | Ν                          |   | #3 — N N N D                                                                                              | Ν             |
| #9                           | — N                          | NNN                                          | ΝΝΝΝ                                                      | I N D                                     | Ν                          |   | #4 — N N N N                                                                                              | D             |
| #10                          | — N                          | NNN                                          | ΝΝΝΝ                                                      | I N N                                     | D                          |   |                                                                                                           |               |
| e 8                          |                              |                                              |                                                           |                                           |                            |   |                                                                                                           |               |

### **Completeness Behavior Composes**

#### An NCL expression as a whole exhibits the completeness criterion.



#### Orderly collective behavior follows from orderly individual behavior.

When the output monotonically transitions to "completely data", it means that the input is "completely data" and the data output is the correct result of the presented input.

When the output monotonically transitions to "completely NULL", it means that the input is "completely NULL" and the NULL has propagated through the circuit.

It does not matter in what order the values transition at the input of the expression. Nor does it matter how long transitions take to propagate within the expression.

The expression as a whole:

- recognizes when new input is presented,
- announces when it is done with the resolution of presented input and
- announces when it is ready to receive a new data presentation.

# NCL is a Fully Sufficient Logic

#### An NCL expression is complete and sufficient in itself: Purely in terms of logical relationships

No supplementary expression such as a time interval, memory, controller or mathematician is required.



The coordinating behavior of the mathematician and her pencil are fully restored. The expression behaves exactly as if a mathematician was coordinating it.

No races, no hazards, no glitches, no indeterminate behavior.

The behavior of the expression, fully determined by the logic, is reliable, repeatable, testable and trustable.

# Self Coordination: The Cycle

Any expression expressing the completeness criterion can coordinate its own input with a feedback acknowledge signal generated from its own output completeness. The inversion in the feedback creates an oscillator continually striving to transition between complete data and complete NULL.



When acknowledge is DATA, the input regulator will pass and maintain data values. When acknowledge is NULL, the input regulator will pass and maintain NULL values.

No new concepts or behaviors have been introduced. The expressions are still purely in terms of logical relationships

# **Composing With Coupled Cycles**

Cycles can be coupled such that the completeness detection of a presenting cycle is after the input regulation of a receiving cycle.



The presenting cycle will maintain its output wavefront until it detects output completeness which will occur strictly after the receiving cycle has accepted the wavefront and is stably maintaining it.

Wavefronts are handed stably from cycle to cycle.

#### Complete systems can be composed as a structure of coupled cycles expressed purely in terms of local logical relationships.

Page 12

# An NCL circuit cannot tell a lie

At any variable completeness boundary an NCL expression will

- present a correct result
- indicate that it is presenting an incorrect result by presenting more than one DATA value per variable which is logically detectable
- fail to achieve completeness



Page 13

# The 2NCL Orphan

An effective data path participates in generating the next variable and is always fully delay insensitive

An orphan is an ineffective data path that branches off an effective data path internal to the circuit and does not participate in generating the result variable. It is called an orphan because it loses all its relationships with other signals.

It cannot be logically determined that the current wavefront has propagated over an orphan before the next wavefront arrives. Therefore, the expression must include an assumption that all orphan paths propagate before a next wavefront can arrive.

Because an orphan does not participate in generating the next variable an orphan does not cross a variable boundary consequently it is always isolated between variable (completeness) boundaries.



# The NCL Orphan in the Cycle

Every NCL circuit resides in a cycle and the cycle period determines when a next wavefront can arrive.

An oprhan path must propagate strictly faster than the period of its cycle

The branches within the pink must propagate strictly faster that the cycle paths under the blue.



### **Generic Transistor Design Templates**



Generic static CMOS implementation

Generic semi-static CMOS implementation

## 2 of 2 Operator Transistor Design

A Z Z



Static CMOS implementation Faster, lower power, easier to design and fab.



Semi-static CMOS implementation Fewer transistors

### 2 of 3 Operator Transistor Design







Static CMOS implementation

Semi-static CMOS implementation

### This page intentionally blank

### This page intentionally blank