# Formal Verification of Integer Multiplier Circuits

Jonathan Wang Price College of Engineering Price College of Engineering Price College of Engineering Price College of Engineering University of Utah Salt Lake City, Utah u1306458@utah.edu

Henry Silverman University of Utah Salt Lake City, Utah henry.silverman@utah.edu

Garrett Slack University of Utah Salt Lake City, Utah u1315263@utah.edu

**Dmitry Panin** University of Utah Salt Lake City, Utah dmitry.panin@utah.edu

Abstract—This paper employs advanced mathematical techniques, specifically polynomials, and ideals, to rigorously verify the correctness of an integer multiplier circuit. By leveraging algebraic methods, this approach will provide a deeper understanding of the circuit's behavior and enable a more robust verification process.

*Index Terms*—polynomials, vanishing polynomials  $(J_0)$ , ideals (J), multiplier circuit

#### I. Introduction

In the field of digital circuit design, integer multiplier circuits stand as fundamental components with critical applications in various computing systems, ranging from embedded devices to high-performance computing architectures. The accurate and efficient operation of these multiplier circuits is crucial for ensuring the reliability and correctness of arithmetic computations. As technology advances and design complexities escalate, the need for rigorous verification methodologies has become increasingly pronounced to guarantee the integrity of digital circuits. Our project tests and verifies these integer multiplier circuits by employing the various methods studied in class on smaller circuits and circuits over fields.

#### II. APPROACH

Ideal membership testing is a great method to test and verify a 2-bit, 3-bit, 4-bit integer multiplier circuit. We manually designed the 2-bit and 3-bit multiplier from scratch and generated the larger circuits utilizing the (.blif writing capabilities of the?) ABC synthesis tool. Next, we converted the blif files to sing files using our parsing python script. The reverse topological term order (RTTO) was then derived from the circuit, and used to represent the minimal Gröbner Basis. In digital circuit verification, there are several approaches to ensure a multiplier circuit implementation performs the same function as its specification. The first option could be creating a miter between the specification polynomials and the implementation, then checking if the Gröbner Basis (GB) is 1. Other approaches will be necessary at larger circuit sizes, such as weak Nullensatz, where the GB of the ideals and vanishing polynomials is 1 (GB( $J + J_0$ ) = 1). Another form of verification is checking if the Gröbner Basis of  $J + J_0$  equals  $0 (GB(J + J_0) = 0).$ 

### III. PROCESS

## A. Singular

The Singular file consists of a ring, polynomials, ideals, and other code to define the behavior of a circuit and interpret its output. A ring is defined by properties, including the type of coefficients, number and names of variables, and arithmetic operations. The ordering of the inputs and outputs in the ring R should follow RTTO, consisting of the following order: outputs, internal gate outputs, and primary inputs. A polynomial (poly) is the algebraic representation of the logic in the circuit. This can mean a poly is defined for each logic gate in the circuit or a more complex poly may be used to represent the functions of groups of gates. For example,  $f_{spec}$  represents the desired mathematical functionality of the implemented circuit. Ideals are a subset of the polynomial ring that consists of all polynomials satisfying certain conditions. Vanishing polynomials are polynomials over a ring that output 0 for all elements in the ring. Algorithm 1 shows the pseudocode for an integer arithmetic circuit.

## B. Singular results for 2-bit, 4-bit, and 16-bit multipliers

First we tested the 2-bit multiplier for simplicity. If the Gröbner Basis of ideal J is 0 (empty), the variety of ideal J is empty or the miter is infeasible, shown in Fig. 1. After

```
J[3]=B+b 0+(X)*b 1
[9]=s 1+s 2+r
J[10]=s_0+s_
|[11]=s_3+r_0+z_1
|[12]=Z_s*t+Z*t+1
Groebner basis G of ideal J:
          then variety of ideal J is empty
```

Fig. 1. Gröbner Basis = 1 without any bugs.

introducing the bug(changing an AND gate to an OR gate), ideal J equals to 1, shown in Fig. 2. It means the variety is not empty, which also means solutions exist to ideal J. Later, we

# Algorithm 1 Example Singular code for arithmetic circuit

```
// Declare ring ring R = 0, (outputs, internal outputs, inputs), lp;
```

```
// Declare f_{spec} and polys of internal gates poly f_{spec} = specification equation of the circuit; 
// f_4 is an example of a polynomial describing gate behavior 
//z is an output, s and e are internal signals 
//z = s_0 - e_0 + 2*s_0*e_0 poly f_4 = z_0 - s_0 - e_0 + 2*s_0*e_0; 
//Continue to model logic gates over Q
```

```
// Declare ideals
ideal J = f4, f5, f6, f7, f8, f9, f10, f11, f12, f13, f14, f15,
f16;
ideal J0 = vanishing polynomials;
```

//Finding Gröbner Basis of the ideals plus the vanishing polynomials groebner  $(J + J_0)$ ;

//Membership test using a condition checking statement to explicitly state membership

```
NF(f_{spec}, J + J_0, 1);
```

```
Groebner basis G of ideal J:

G[1]=s_3+r_8+z_1
G[2]=s_2*2*+s_2*z_3*+s_2*z_1*t+(X+1)*s_2*s_3*r_8*t+s_3*z_1*t+r_8*z_8*z_1*t
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8
G[3]=s_1*s_2*r_8*s_2*r_8*s_2*r_8*s_8*r_8*s_8*r_8*s_8*r_8*t*x_1*t+(X+1)*s_8*t+z_1*t+(X+1)
G[3]=s_0*s_2*t*s_0*s_2*s_1*s_2*r_8*s_8*r_8*s_8*r_8*s_8*t
G[3]=s_0*s_2*t*s_0*s_1*s_1*s_1*s_1*s_2*s_2*r_2*s_2*r_8
G[3]=s_0*s_2*t*s_0*s_1*s_1*s_1*s_2*s_2*r_2*s_2*r_8
G[3]=s_0*s_2*r_8*s_1*s_1*s_1*s_2*s_2*r_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*g_1*s_2*s_1*s_2*s_2*r_1*t+(X+1)*s_1*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*g_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*g_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*g_1*s_1*s_3*s_1*s_2*s_3*s_1*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_1*s_2*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_3*s_2*s_3*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_3*s_2*s_3*t+s_3*r_8*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_3*t+s_3*s_3*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t
G[3]=s_0*s_1*s_1*s_3*s_3*t+s_3*s_3*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s_3*r_8*t+s
```

Fig. 2. Gröbner Basis = lots of polynomials = solutions exist.

introduced minimal and reduced Gröbner Basis for the larger 4-bit and 16-bit multiplier circuits. A minimal Gröbner basis is a special case of a Gröbner Basis that has the fewest number of elements possible while generating the same ideal. A reduced Gröbner Basis is a further refinement of the minimal Gröbner basis, which means the leading coefficient of each polynomial is 1 and no monomial of another polynomial is divisible by the leading monomial of another polynomial in the basis.

#### IV. ALGORITHMS AND TECHNIQUES

Techniques for ideal membership testing:

- 1) Setup the verification formulation over the polynomial ring R.
- 2) Declare a specification polynomial from circuit  $f_{spec}$ .
- 3) Derive the polynomials from the gates of the circuit  $\{f_1, ..., f_s\}$ .
- 4) Set ideal  $J = f_1, ..., f_s$ .
- 5) Create the ideal of vanishing polynomials for each variable  $J_0$

- 6) Take the Gröbner Basis:  $G = GB(J + J_0)$ .
- 7) The circuit implements  $f_{\rm spec} \iff f_{\rm spec} \in (J+J_0)$  if and only if  $f_{\rm spec}$  is divisible by G

The steps to run Singular, ABC, and the Python script are provided in the README.

## V. SOFTWARE IMPLEMENTATIONS

We implemented a Python function with assistance from ChatGPT to convert blif files to sing files. The code defines a gate mapping dictionary that maps gate types from the blif file to their corresponding names in Singular. It iterates through and searches for lines starting with '.gate' and extracts the gate type and its inputs, parsing and separating them accordingly into the Singular file. Additionally, we added code for error handling because the Singular file was empty when experimenting. Below is the pseudo-code for the Python file.

```
Function parse_blif_file(file_path):
Initialize gates, inputs, and outputs
Open file_path
For each line in file:
   If line starts with '.gate':
   Parse gate type, inputs, and output
   Replace 'new_n' with 'n' in input
   Add gate information to gates
   Update outputs and inputs set
   If line starts with '.inputs':
      Update inputs set
   If line starts with '.outputs':
      Update outputs set
   Return gates, inputs-outputs, outputs
```

```
Function topological_sort:
    Create a graph from gates
    Initialize order and visited sets
    Define topological sorting function
    For each output in graph:
        Visit(output)
    Return sorted order
```

Function generate\_ring\_declaration:
Return ring declaration string

```
Function write_singular_file:
Open output_path file
Write ring declaration
Wtite polynomial equations
Generate vanishing polynomials
Write ideal declarations
```

Function main():

```
Prompt user for BLIF file path
Prompt user for output path
Parse BLIF file
Perform topological sort on gates
Set ring size (default 2)
```

Write .sing file Print completion message

Execute main()

#### VI. CONCEPTS LEARNED

# A. Mathematical Ideals

Ideals ensure the accuracy of electronic systems In circuit testing and verification. Ideal membership testing involves using mathematical models to assess whether a circuit aligns with specified ideal characteristics. Engineers compare these models with real-world circuit implementations to identify discrepancies to help detect potential faults in the design. This approach enhances precision and provides a systematic framework for validating complex circuits, contributing to the development of high-quality electronic systems.

#### B. Gröbner Basis

Gröbner Basis in-circuit testing and verification is a powerful method that involves algebraic techniques to analyze and validate complex electronic systems. Gröbner Bases provide a systematic way to address polynomial equations representing circuit behaviors. Gröbner Bases are a fundamental concept in algebraic geometry and computer algebra systems, and they play a crucial role in solving systems of polynomial equations. The primary idea behind Gröbner Bases is to provide a systematic method for transforming a set of polynomials into a more manageable and structured form.

# C. blif to sing conversion

By using a python script to parse our mapped blif files (lib2.genlib), we can convert the list of gates contained in the blif file to a list of corresponding polynomials for our sing file. By splitting the blif file line by line and parsing for key words such as ".gate," "XOR," "NAND," and "INV" to create the different polynomial equations to model logic gates over Q. For example, "XOR" uses the equation z - a - b + 2ab, and "AND" uses the equation z = a \* b for the corresponding polynomials. Python makes this very easy with its parsing functionalities.

# D. Ideal Membership Testing

Ideal membership testing is a mathematical approach used in circuit verification to determine whether a given circuit satisfies ideal properties or conditions. It involves algebraic structures known as ideals, particularly in the context of polynomial rings. An ideal is a subset of the polynomial ring that consists of all polynomials that satisfy certain conditions. In the context of circuit verification, the ideal encapsulates the set of polynomials representing the desired ideal behavior of the circuit. The core of the process involves determining whether a given polynomial, representing the behavior of the actual circuit, belongs to the ideal. If the polynomial is an element of the ideal, it indicates that the circuit satisfies the ideal properties. Otherwise, it suggests a deviation from the expected behavior.

#### E. Miters

Miters play a crucial role in circuit testing and verification. A model of the circuit is integrated into the testing process, allowing for comprehensive analysis. The miter compares the expected behavior with the actual circuit response using an xor gate to highlighting any discrepancies based on the model. By using miters, we can identify and address potential issues before moving to further stages of development or production, ensuring that the circuit functions as intended.

#### VII. LABOUR DIVISION

- Jonathan: Generated the blif files and converted it to Singular files and wrote the report
- Henry: Debugged Python Code and helped write report
- Garrett: Help write the report
- Dmitri: Provided Singular code for 2-bit,3-bit and 4-bit multipliers and visuals

#### VIII. CONCLUSION

## REFERENCES

- D. Ritirc, A. Biere and M. Kauers, "Column-wise verification of multipliers using computer algebra," 2017 Formal Methods in Computer Aided Design (FMCAD), Vienna, Austria, 2017, pp. 23-30, doi: 10.23919/FMCAD.2017.8102237.
- [2] T. Pruss, P. Kalla and F. Enescu, "Efficient Symbolic Computation for Word-Level Abstraction From Combinational Circuits for Verification Over Finite Fields," in IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 35, no. 7, pp. 1206-1218, July 2016, doi: 10.1109/TCAD.2015.2501301.
- [3] Jerry R. Burch. 1991. Using BDDs to verify multipliers. In Proceedings of the 28th ACM/IEEE Design Automation Conference (DAC '91). Association for Computing Machinery, New York, NY, USA, 408–412. https://doi.org/10.1145/127601.127703