CN117077607B - Large-scale linear circuit simulation method, system, circuit simulator and storage medium - Google Patents
Large-scale linear circuit simulation method, system, circuit simulator and storage medium Download PDFInfo
- Publication number
- CN117077607B CN117077607B CN202310929719.2A CN202310929719A CN117077607B CN 117077607 B CN117077607 B CN 117077607B CN 202310929719 A CN202310929719 A CN 202310929719A CN 117077607 B CN117077607 B CN 117077607B
- Authority
- CN
- China
- Prior art keywords
- matrix
- sub
- boundary
- diagonal
- distributed
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000004088 simulation Methods 0.000 title claims abstract description 82
- 238000000034 method Methods 0.000 title claims abstract description 66
- 239000011159 matrix material Substances 0.000 claims abstract description 213
- 230000008707 rearrangement Effects 0.000 claims abstract description 65
- 230000000295 complement effect Effects 0.000 claims abstract description 34
- 238000004422 calculation algorithm Methods 0.000 claims abstract description 21
- 238000004364 calculation method Methods 0.000 claims abstract description 11
- 230000006870 function Effects 0.000 claims description 21
- 230000008569 process Effects 0.000 claims description 19
- 238000012546 transfer Methods 0.000 claims description 7
- 238000000638 solvent extraction Methods 0.000 claims description 5
- 230000000903 blocking effect Effects 0.000 claims description 4
- 238000012216 screening Methods 0.000 claims description 2
- 238000012545 processing Methods 0.000 description 9
- 238000010586 diagram Methods 0.000 description 7
- 241001229889 Metis Species 0.000 description 5
- 238000004891 communication Methods 0.000 description 5
- 238000000354 decomposition reaction Methods 0.000 description 5
- 239000013598 vector Substances 0.000 description 4
- 238000013461 design Methods 0.000 description 3
- 230000002441 reversible effect Effects 0.000 description 3
- 230000009286 beneficial effect Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000005192 partition Methods 0.000 description 2
- 238000006467 substitution reaction Methods 0.000 description 2
- 230000009466 transformation Effects 0.000 description 2
- 230000001133 acceleration Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 239000000470 constituent Substances 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 230000000699 topical effect Effects 0.000 description 1
- 238000000844 transformation Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F30/00—Computer-aided design [CAD]
- G06F30/30—Circuit design
- G06F30/39—Circuit design at the physical level
- G06F30/392—Floor-planning or layout, e.g. partitioning or placement
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2111/00—Details relating to CAD techniques
- G06F2111/10—Numerical modelling
Landscapes
- Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Architecture (AREA)
- Evolutionary Computation (AREA)
- Geometry (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
The invention provides a large-scale linear circuit simulation method, a system, a circuit simulator and a storage medium, and particularly relates to the technical field of analog circuit numerical simulation. Carrying out row-column rearrangement on the coefficient matrix of the equation set by using a graph dividing algorithm to obtain a double-boundary diagonal matrix; adopting a plurality of calculation nodes to form distributed nodes, adopting a parallel calculation mode to solve local Shu's complement of each distributed node, and summing to obtain global Shu's complement; and according to the global Shu's complement and the state of each distributed node at the last moment, acquiring the state of each distributed node at the current moment, and further acquiring a large-scale linear circuit simulation result. The scheme can control the block number and the block size of the circuit matrix, and can obviously improve the circuit simulation efficiency on the premise of ensuring smooth performance of the simulation flow.
Description
Technical Field
The invention relates to the technical field of analog circuit numerical simulation, in particular to a large-scale linear circuit simulation method, a system, a circuit simulator and a storage medium.
Background
Large scale circuits have reached tens of millions of their to billions of scale under advanced nodes, and circuit simulators face significant challenges. For example, with the multi-functional and emerging mixed domain design requirements of modern electronics, the performance requirements of various analog, digital, electromagnetic, radio frequency and thermal modules at the chip, package and system level for very large scale integrated circuit designs are increasing. As another example, the continuously increasing operating frequency brings about a number of effects that are not negligible, such as delays, distortions, reflections, and crosstalk.
In the prior art, the core step of large-scale circuit simulation is sparse matrix decomposition, and at present, most sparse matrix decomposition is performed by adopting a method for rearranging sparse matrix, but the number of divided matrix blocks and the size of each matrix block cannot be obtained and controlled, so that the circuit simulation efficiency is lower.
Disclosure of Invention
In view of the above-mentioned shortcomings of the prior art, the present invention aims to provide a method, a system, a circuit simulator and a storage medium for large-scale linear circuit simulation, which aim to solve the problem of low efficiency of large-scale linear circuit simulation in the prior art.
In order to achieve the above object, a first aspect of the present invention provides a large-scale linear circuit simulation method, comprising the steps of:
Constructing a normal differential equation of a linear circuit according to the scale of the linear circuit, and converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method;
The coefficient matrix of the large-scale sparse linear equation set is rearranged in a column mode, so that the diagonal lines of the coefficient matrix are all non-zero elements, and a pre-rearranged matrix is obtained;
A graph dividing algorithm is utilized to conduct row-column rearrangement on the pre-rearranged matrix, so that non-zero elements of the pre-rearranged matrix are distributed on a diagonal line and two boundaries of the right and the lower, and a double-boundary diagonal matrix is obtained;
Adopting a plurality of computing nodes to form distributed nodes, solving local schulums of all the distributed nodes based on the double-boundary diagonal matrix data, and summing all the local schulums to obtain a global schulums;
according to the global Shu's complement and the solving result of each distributed node at the last moment, the state of each distributed node at the current moment is solved in parallel; and converting the solving results of all moments of each distributed node into the large-scale linear circuit simulation results according to the column rearrangement and the row and column rearrangement.
Optionally, the performing row-column rearrangement on the pre-rearranged matrix by using a graph partitioning algorithm, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line, a right boundary and a lower boundary, to obtain a dual-boundary diagonal matrix, including:
Creating an original graph stack for storing original graphs and a sub graph stack for storing sub graphs obtained by halving, wherein the original graphs refer to undirected graphs corresponding to the pre-rearranged matrixes;
Dividing the original image into two sub-images after the original image stack is taken out one by one, and obtaining two sub-images; and the two sub-graphs are input into the sub-graph stack until the original graph stack is empty, and the original graph stack and the sub-graph stack are exchanged;
repeating the process of dividing each original image into sub-images and exchanging the original image stack and the sub-image stack until the number of the sub-images in the sub-image stack or the exchange times of the original image stack and the sub-image stack reach a preset number;
And performing row-column rearrangement on the pre-rearranged matrix by using all the bipartite graphs, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line, a right boundary and a lower boundary, and a double-boundary diagonal matrix is obtained.
Optionally, the step of dividing the original graph into sub-graphs after the original graph is taken out of the original graph stack one by one, to obtain a sub-graph includes:
acquiring the sizes of all the original pictures popped from the original picture stack;
Presetting a bipartite graph size threshold based on global information of all the bipartite graphs obtained in the last bipartite, and if the original graph size exceeds the preset bipartite graph size threshold, bipartite the original graph into sub graphs to obtain the bipartite graphs; otherwise, the original graph is set as the bipartite graph.
Optionally, the row-column rearrangement is performed on the pre-rearranged matrix by using all the binary graphs, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries of diagonal lines, right and bottom, and a dual-boundary diagonal matrix is obtained, including:
presetting a column rearrangement matrix, a double boundary diagonal rearrangement matrix, a row expansion matrix and a column expansion matrix based on the dimension of the coefficient matrix;
based on the column rearrangement matrix, the row expansion matrix and the column expansion matrix, the diagonal lines of the coefficient matrix are provided with elements, the absolute value of the elements is 1, and the absolute values of the elements except the elements on the diagonal lines are not more than 1, so that a pre-rearrangement matrix is obtained;
And constructing a double-boundary diagonal rearrangement form based on the graph dividing algorithm, and rearranging rows and columns of the pre-rearranged matrix based on the double-boundary diagonal rearrangement form to obtain a double-boundary diagonal matrix.
Optionally, the adopting a plurality of computing nodes to form distributed nodes, solving local sull complements of the distributed nodes based on the double-boundary diagonal matrix data, and summing the local sull complements to obtain global sull complements, including:
Adopting a plurality of computing nodes to form distributed nodes, storing the data of the double-boundary diagonal matrix on a target node, marking the target node as a main node, and marking nodes except the main node as child nodes;
Broadcasting data on the main node to each child node through a first message transfer interface function, and solving local Shu's complements of all the distributed nodes;
And summing the local Shu's complements through a second message transfer interface function to obtain a global Shu's complement.
Optionally, the broadcasting the data on the master node to each of the child nodes through a first message transfer interface function, and solving local schuldering of all the distributed nodes includes:
based on the data on the master node, screening out elements in the double-boundary diagonal matrix corresponding to each distributed node, and constructing a block matrix by using the elements corresponding to each distributed node;
And solving each blocking matrix in a parallel computing mode to obtain the local Shu's complement of each distributed node.
Optionally, converting the solution result of each distributed node at all times into the large-scale linear circuit simulation result includes:
according to the global Shu's complement and the solving result of each distributed node at the last moment, the state of each distributed node at the current moment is solved in parallel;
According to the column rearrangement matrix and the double-boundary diagonal rearrangement matrix, finding out the rows of the large-scale linear circuit simulation results corresponding to the solving results of all the distributed nodes at all moments;
and scaling all elements on the row according to the column expansion matrix to obtain the large-scale linear circuit simulation result.
A second aspect of the present invention provides a large scale linear circuit simulation system, the system comprising:
The initialization module is used for constructing a normal differential equation of the linear circuit according to the scale of the linear circuit and converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method;
The matrix rearrangement module is used for rearranging the coefficient matrix of the large-scale sparse linear equation set to ensure that the diagonal of the coefficient matrix is all non-zero elements, so as to obtain a pre-rearranged matrix; a graph dividing algorithm is utilized to conduct row-column rearrangement on the pre-rearranged matrix, so that non-zero elements of the double-boundary diagonal matrix are distributed on a diagonal line and a right boundary and a lower boundary, and a double-boundary diagonal matrix is obtained;
The Shu's complement calculation module is used for adopting a plurality of calculation nodes to form distributed nodes, solving the local Shu's complement of each distributed node based on the double boundary diagonal matrix data, and summing each local Shu's complement to obtain a global Shu's complement;
The circuit simulation module is used for parallelly solving the state of each distributed node at the current moment according to the global Shu's complement and the solving result of each distributed node at the last moment; and converting the solving results of all moments of each distributed node into the large-scale linear circuit simulation results according to the column rearrangement and the row and column rearrangement.
A third aspect of the present invention provides a circuit simulator comprising a simulation chip, a memory, and a large-scale linear circuit simulation program stored on the memory and operable on the simulation chip, the large-scale linear circuit simulation program, when executed by the simulation chip, performing the steps of any one of the large-scale linear circuit simulation methods described above.
A fourth aspect of the present invention provides a computer-readable storage medium having stored thereon a large-scale linear circuit simulation program which, when executed by a processor, implements the steps of any one of the large-scale linear circuit simulation methods described above.
Compared with the prior art, the scheme of the invention has the following beneficial effects:
Firstly, constructing a normal differential equation of a linear circuit according to the scale of the linear circuit, converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method, converting a coefficient matrix of the linear equation set into all non-zero elements on a diagonal line after line-column rearrangement, and further carrying out line-column rearrangement by using a graph dividing algorithm to obtain a double-boundary diagonal matrix with expected dimension, so that the number and the size of blocks of the large-scale linear circuit can be effectively controlled, and the normal operation of a subsequent simulation flow is ensured; then a plurality of computing nodes are adopted to form distributed nodes, local Shu's complements of all the distributed nodes are solved based on double-boundary diagonal matrix data, and global Shu's complements are obtained by simply summing all the local Shu's complements, so that simulation efficiency is improved; then, the state of each distributed node at the current moment is solved in parallel through the solving result of each distributed node at the previous moment and the global Shu' er complement, so that the circuit simulation efficiency is improved; and finally, converting the solving results of all the moments of each distributed node into circuit simulation results.
Therefore, the invention converts the ordinary differential equation of the linear circuit into a large-scale sparse linear equation set with proper dimension based on the scale of the large-scale linear circuit, so as to control the block number and the size of the circuit matrix, and can perform circuit simulation by parallel processing of all sub-nodes on the premise of ensuring smooth simulation flow, thereby remarkably improving the circuit simulation efficiency.
Drawings
In order to more clearly illustrate the technical solutions of the embodiments of the present invention, the drawings used in the embodiments or the description of the prior art will be briefly described below, and it is obvious that the drawings in the following description are only some embodiments of the present invention, and other drawings can be obtained according to these drawings without inventive effort for a person skilled in the art.
FIG. 1 is a flow chart of a large-scale linear circuit simulation method of the present invention;
FIG. 2 is a flowchart illustrating a method for simulating a large-scale linear circuit according to the present invention;
FIG. 3 is a schematic diagram of a prior art rearrangement of matrices into BBD form;
FIG. 4 is a schematic diagram of a system architecture of the present invention;
Fig. 5 is a schematic diagram of a circuit simulator according to the present invention.
Detailed Description
In the following description, for purposes of explanation and not limitation, specific details are set forth such as the particular system architecture, techniques, etc., in order to provide a thorough understanding of the embodiments of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced in other embodiments that depart from these specific details. In other instances, detailed descriptions of well-known systems, devices, circuits, and methods are omitted so as not to obscure the description of the present invention with unnecessary detail.
It should be understood that the terms "comprises" and/or "comprising," when used in this specification and the appended claims, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
It is also to be understood that the terminology used in the description of the invention is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used in this specification and the appended claims, the singular forms "a," "an," and "the" are intended to include the plural forms as well, unless the context clearly indicates otherwise.
It should be further understood that the term "and/or" as used in the present specification and the appended claims refers to any and all possible combinations of one or more of the associated listed items, and includes such combinations.
The following description of the embodiments of the present invention will be made more fully hereinafter with reference to the accompanying drawings, in which embodiments of the invention are shown, it being evident that the embodiments described are only some, but not all embodiments of the invention. All other embodiments, which can be made by those skilled in the art based on the embodiments of the invention without making any inventive effort, are intended to be within the scope of the invention.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention, but the present invention may be practiced in other ways other than those described herein, and persons skilled in the art will readily appreciate that the present invention is not limited to the specific embodiments disclosed below.
The invention aims at a linear circuit, and based on a Metis library, a sparse matrix is rearranged into a form of non-zero elements distributed in a diagonal line, a right side and a lower side, which is called a BBD form for short. The method comprises the steps of constructing a normal differential equation of a linear circuit based on the scale of the linear circuit, converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method, modifying a recursion-based depth-first block strategy into a circulation-based breadth-first block strategy by modifying the existing block strategy of the Metis, and controlling the number and the size of blocks of a circuit matrix; an efficient solver for a circuit matrix is adopted for each distributed node, so that simulation time is remarkably reduced; according to the characteristics of the linear circuit equation, corresponding mathematical transformation processing is carried out, so that each distributed node in the simulation process does not need to obtain a complete simulation result and calculate complete simulation input, thereby reducing the calculated amount, reducing the memory occupation, reducing the communication times of the distributed nodes and increasing the speed-up ratio.
Exemplary method
The embodiment of the invention provides a large-scale linear circuit simulation method which is deployed on electronic equipment such as a computer, a server and the like, wherein the application scene is large-scale linear circuit simulation, and aims at the conditions of sparse matrix rearrangement and parallel processing. The type of the physical quantity represented by each node of the large-scale linear circuit is not limited, and may be physical quantities existing in various linear circuits such as voltage and current. Specifically, as shown in fig. 1 and fig. 2, the flow of the method in this embodiment includes:
step S100: and constructing a normal differential equation of the linear circuit according to the scale of the linear circuit, and converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method.
Specifically, since the core of the circuit simulation is to solve a large sparse linear equation set ax=b, in this embodiment, the number of processes N that are opened is set according to the scale of the linear circuit, and a large sparse linear equation set ax=b in BBD form is constructed according to the number of processes N that are opened, where a is an N-order nonsingular square matrix, and x and b are vectors of length N.
First, a mathematical form of BBD matrix solution is described, where definition A has a BBD form with non-zero bins distributed diagonally, to the right and below. The non-zero elements are distributed in blocks near the diagonal, denoted as a 0,...,AN-1. The non-zero elements distributed at the lower and right boundaries are divided into constituent matrix blocks E 0,...,EN-1 and F 0,...,FN-1 according to the block sizes on the diagonal. The area where the two boundaries and the diagonal line intersect is denoted as matrix block a N. The vectors x and b are divided into corresponding segments according to the partitioning of a. The corresponding large sparse linear equation set is
For x 0 to x N-1
Aixi=bi-FixN,i=0,…,N-1 (2)
For the equation in line with x N, after replacing x 0 to x N-1 with x N according to equation (2), the result is sorted
Wherein, is calledIs topical Shu Er Bu, but/>The global schulb is marked as S.
It should be stated that the size of N in equation (1) is the same as the number of processes that are turned on, and represents the sum of the master node and the child node in the circuit matrix (i.e., coefficient matrix), and there is only one master node.
According to the Euler iteration method, the ordinary differential equation of the linear circuit is converted into a large-scale sparse linear equation set, and the ordinary differential equation of the large-scale linear circuit is defined as:
Where x is the voltage value of each node of the circuit and the current value of part of the branches, u is the input of the circuit, C is the capacitance and inductance parts of the circuit, G is the resistance part of the circuit, and B is the input matrix of the circuit.
Since not all nodes have inputs, u needs to be processed, in this embodiment, the differential term is linearly approximated by h as a step length, and the ordinary differential equation is discretized into a form of backward euler iteration
(C+hG)x(k+1)=Cx(k)+hBu(k+1) (5)
This form is the ax=b form, and c+hg is a sparse matrix. In this embodiment, the above matrix is used as an input to perform circuit simulation.
Step S200: and (3) rearranging the coefficient matrix of the large-scale sparse linear equation set to ensure that the diagonal of the coefficient matrix is all non-zero elements, so as to obtain a pre-rearranged matrix.
Specifically, in order to apply the BBD algorithm, the original matrix rows and columns are rearranged into BBD form first, and the BBD matrix solving is feasible on the premise that each submatrix on the diagonal is reversible. Since the absolute reversibility of the submatrices is difficult to guarantee, the condition is relaxed to be structurally reversible, wherein the sparse matrix is structurally reversible equivalent to the matrix that has a rearrangement method such that all the diagonal lines of the diagonal matrix with double boundaries of rows and columns are non-zero elements. Therefore, the present embodiment adopts the existing rearrangement matrix of the MC64 library, where the MC64 library is one library of the collection HSL of the computation math set under the british research and innovation agency and the math library for large-scale scientific computation developed by other experts. The corresponding result after MC64 treatment is
C+hG→U(C+hG)QV
Wherein Q is a column rearrangement matrix which enables all diagonal lines of the double-boundary diagonal matrix to be nonzero; u and V are respectively a telescopic matrix of a row and a column, so that elements are arranged on diagonal lines of the matrix processed by MC64, the absolute value of each element is 1, and the absolute value of other elements does not exceed 1, and a pre-rearranged matrix is obtained, so that subsequent LU decomposition is facilitated.
Step S300: and (3) performing row-column rearrangement on the pre-rearranged matrix by using a graph dividing algorithm, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line, a right boundary and a lower boundary, and a double-boundary diagonal matrix is obtained.
Specifically, based on the metas, the matrix is rearranged into the form of the BBD by using a graph partitioning algorithm, the schematic diagram of which is shown in fig. 3, fig. 3 (a) is an undirected graph corresponding to the pre-rearranged matrix, and fig. 3 (b) is a matrix in the form of the BBD obtained by rearranging the sub-graph after two divisions. Reordering into the BBD form is equivalent to finding a set of vertices in the undirected graph, commonly referred to as vertex separator (hereinafter VS), i.e. the part of fig. 3 (a) that is coiled with a curve, by means of which the undirected graph can be divided into several sub-graphs that are not connected to each other. The method for searching the VS based on the Metis in the prior art is as follows: firstly, dividing the undirected graph corresponding to the matrix into two parts to obtain a left graph, a right graph and a VS; then recursively halving the left graph until the subgraph is small enough, then halving the right graph as well as the left graph; finally, the VSs of all the subgraphs are obtained, namely the VSs of the original image. Since this binary approach to undirected graph belongs to the depth-first recursion, the information of all sub-graphs cannot be obtained, and thus it is difficult to control the number of blocks and to obtain the size of each block. The root cause is that the goal of the meta is to reorder the matrix to reduce its LU decomposition complexity, rather than obtaining a BBD matrix.
Based on this, the present embodiment modifies it into a breadth-first traversal algorithm based on a loop, which is implemented in the following manner: creating an original graph stack for storing original graphs and a sub graph stack for storing sub graphs obtained by halving, wherein the original graphs are undirected graphs corresponding to coefficient matrixes; dividing the original image into sub-images after the original image stack is taken out one by one, and obtaining a sub-image; and pushing the binary image into the sub-image stack until the original image stack is empty, and exchanging the original image stack and the sub-image stack; repeating the process of dividing each original image into sub-images and exchanging the original image stack and the sub-image stack until the number of the sub-images in the sub-image stack or the exchange times of the original image stack and the sub-image stack reach the preset number; and (3) performing row-column rearrangement on the pre-rearranged matrix by using all the bipartite graphs, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line, a right boundary and a lower boundary, and a double-boundary diagonal matrix is obtained.
Specifically, firstly, preparing two stacks, namely an original image stack for storing each original image in the undirected image and a sub image stack for storing sub images obtained after two division, wherein the original image stack is an original image corresponding to a circuit matrix in an initial state, and the sub image stack is empty; then, the original pictures are popped from the original picture stacks one by one, each original picture is divided into two parts, and the sub pictures obtained by the two parts are input into the sub picture stacks until the original picture stacks are empty, and the two stacks are exchanged; repeating the steps of dividing the original image into two parts until the number of the sub-images in the sub-image stack is the expected number, and finally storing all obtained matrix blocks corresponding to the sub-images in a container. For example, if the number of times of performing the bipartite operation on each original graph is n, the number of matrix blocks (i.e., sub-graphs in the undirected graph) finally divided is 2 n, in the actual simulation process, the number of matrix blocks may be preset first, and the number of times of performing the bipartite operation on each original graph is set according to the preset number of matrix blocks. In the process of bisection operation, the graph dividing algorithm adopted in the embodiment can control the difference of the sizes of two subgraphs obtained after bisecting one graph to a certain extent, namely, the sizes of subgraphs obtained by the bisection operation can be controlled to a certain extent by setting corresponding parameters of staff of the graph dividing algorithm.
Meanwhile, the size of each corresponding sub-graph in the sub-graph stack can be queried through a container for storing the matrix blocks, and the circuit matrix blocks are pertinently secondarily segmented according to the queried size of the matrix blocks, so that the number and the size of the circuit matrix blocks are controlled, and the normal operation of a subsequent circuit simulation flow is ensured. In the last sub-graph stack, the size of each sub-graph is the size of the partition. The subgraphs are arranged according to a certain sequence, which can be the sequence in the subgraph stack, rearranged according to the calculation load according to the subgraph size and the calculation capacity of each node, or any sequence. Since the subgraphs correspond to matrix blocks, here the order of the subgraphs is also referred to as the left-right (up-down) order of the diagonal matrix blocks of the BBD matrix.
It is stated that after any one original image in the two-part original image stack is ended and the obtained sub image is input into the sub image stack, the information such as the sizes of all the original images and sub images in the current original image stack and sub image stack can be obtained, and the original images and sub images are independent of each other and can be operated independently.
Further, as another preferred embodiment, the balance processing may be performed based on the modified metas, so that the sizes of the matrix blocks on the main diagonal of the finally obtained BBD matrix are approximately equal. The specific implementation mode is that the original image sizes of all the stacks popped from the original image stack are obtained; presetting a bipartite graph size threshold based on global information of all bipartite graphs obtained by last bipartite, and if the original graph size exceeds the preset bipartite graph size threshold, bipartite the original graph into sub-graphs to obtain the bipartite graph; otherwise, the original image is set as a binary image. Therefore, the method only needs to perform bipartite processing on the subgraph with the size exceeding the set threshold value, and does not need to perform bipartite processing on all the graphs in the original graph stack for the same times, so that the number and the size of the circuit matrix blocks are controlled, and the follow-up circuit simulation flow is guaranteed to be normally performed.
According to the embodiment, through the breadth-first traversal algorithm based on the circulation, which is obtained after the Metis modification, when the two parts are carried out on each original image or sub image of the original image stack, a serial processing mode or a parallel processing mode can be selected according to actual requirements.
Based on the double-boundary diagonal rearrangement form constructed in the formula (1), the double-boundary diagonal rearrangement form is utilized to rearrange the rows and the columns of the pre-rearranged matrix obtained in the step, and the result after rearrangement is that the rows and the columns of the coefficient matrix are rearranged identically due to the Metis
U(C+hG)VQ→PU(C+hG)QVPT
Wherein, P is a rearrangement matrix, and the rearrangement matrix and the column rearrangement matrix Q are the same size, and the difference is only the position relationship between the two in the rearrangement process, so that the non-zero elements of the pre-rearrangement matrix are distributed on the diagonal and the right and lower two boundaries to obtain a double-boundary diagonal matrix.
Step S400: and adopting a plurality of computing nodes to form distributed nodes, solving local Shu's complements of each distributed node based on the double-boundary diagonal matrix data, and summing each local Shu's complement to obtain a global Shu's complement.
Specifically, a distributed node is formed by adopting a plurality of computing nodes, data of a double-boundary diagonal matrix is stored on a target node, the target node is marked as a main node, and nodes except the main node are marked as child nodes; broadcasting data on the main node to all child nodes through a first message transfer interface function, and solving local Shu's complement of all distributed nodes; and summing all local Shull complements through a second message transfer interface function to obtain the global Shull complements.
The present embodiment solves for local and global schulp for each node using a message passing interface (MESSAGE PASSING INTERFACE, MPI), MPI is a message passing programming model and standard for parallel computing, which allows communication and synchronization between multiple processors or computing nodes, thereby enabling parallel computation of programs. In MPI, processes communicate by sending and receiving messages between them. The present embodiment mainly uses two MPI communication functions: a broadcast message function (mpi_bcast) and a global reduction function (mpi_allreduce), the former function being to broadcast data from one node to all other nodes. The latter function is to collect data of all nodes, operate it and then return the result to all nodes. The operation used in the present embodiment is addition, i.e., addition of all node data is acquired.
After a plurality of computing nodes are adopted to form a distributed node, matrix data is generally stored in one node, the node is recorded as a main node, the number is 0, and the rest nodes are child nodes. Since the left and right sides of the circuit matrix are multiplied by the matrix, equation (5) is rewritten as
PU(C+hG)QVPT·(QVPT)-1x(k+1)=PUCx(k)+hPUBu(k+1)=b(k+1) (6)
For simplicity and convenience, record
A=PU(C+hG)QVPT (7)
Rewriting as (6)
The first equal sign side of formula (6) isThe other side is x, which means that equation (5) is calculated once for each solution. The rewriting type (6) includes:
For simplicity and convenience, record
Substitution of formulas (8), (5) into formula (6) has
The process of solving the local and global schulums of each distributed node is essentially to solve the local schulums in equation (3)And global Shu Er Bu/>
First, a local schulr patch is calculated, and in order to fully utilize hardware resources, each distributed node calculates a corresponding local schulr patch. The child node needs to obtain the matrix a i,Ei,Fi,AN from the master node to calculate the local schulp. Most straightforward is that the master node takes out each sub-matrix and sends it to the sub-nodes, but in case of a large number of sub-nodes hardware resources are wasted. Because the function MPI_Bcast is fast and the matrix A is a sparse matrix, elements in the double boundary diagonal matrix corresponding to each distributed node are screened out based on data on the main node, and a blocking matrix is constructed by utilizing the elements corresponding to each distributed node; and solving each block matrix by adopting a parallel computing mode to obtain the local Shu's complement of each distributed node.
The present embodiment chooses to use this function to broadcast a to all child nodes, which then acquire the corresponding partitions. For all nodes, a blocking matrix of formula (13), i.e
And solving the local Shu's complement by using a solver supporting partial LU decomposition to increase the solving speed, thereby being beneficial to reducing the simulation time, then calling a function MPI_Allreduce to obtain the sum of the local Shu's complement, and adding A N to the sum to obtain the global Shu's complement.
Step S500: according to the global Shu's complement and the solving result of each distributed node at the last moment, the state of each distributed node at the current moment is solved in parallel; and converting the solving results of all moments of each distributed node into a large-scale linear circuit simulation result according to the column rearrangement and the row and column rearrangement.
Then, the right side of the equal sign of equation (12) is calculated. Comparing equations (7), (11), it is noted that the set of non-zero-element positions of matrix C is a subset of the non-zero-element set of C+hG, so that the row and column reorder matrix of C+hG reorders C also into a BBD matrix. That is, a matrixIs a BBD matrix, i.e
And is also provided withIs identical in size to the corresponding sub-matrix of a.
Recording device
hPUB=[B0 T … BN-1 T BN T]T (15)
Wherein the number of rows of B i is the same as that of C i, in combination with the formulas (12), (14), (15)
In order to utilize hardware resources as much as possible, this embodiment requires that each node requires solution (3). Meanwhile, as the simulation result is a dense vector, in order to reduce the memory occupation, the matrix C and C+hG can be converted into a BBD matrix in the same way, and the obtained deformation formula (16) can know that each node only needs to be stored according to the formula (16)B i (k+1) can be solved independently so that the summation on the right side of the equal sign can be implemented by the function mpi_allreduce.
Combining the formulas (12), (14), (15) to obtain
Substituting the formulas (16), (17) into formula (3)
Recording device
Thus is provided with
And then
Recording device
Thus there is
So far, the solving result of all moments of each distributed node is obtainedAnd obtaining a circuit simulation result X according to a formula (23).
Specifically, according to the global Shu's complement and the solving result of each distributed node at the last moment, the states of each distributed node at the current moment are solved in parallel; according to the column rearrangement matrix and the double-boundary diagonal rearrangement matrix, finding out the rows of the large-scale linear circuit simulation results corresponding to the solution results of all moments of each distributed node; and scaling all elements on the rows according to the column expansion matrix to obtain a large-scale linear circuit simulation result.
The embodiment uses the characteristic that the matrix C can be converted into a BBD matrix in the same way with the C+hG, so that each distributed node only needs to store the unknown quantity (x i (k)) of the corresponding matrix block and the unknown quantity of the coupling partAnd independently calculating the right side vector/>, corresponding to the matrix block, of the equal signCompared with the traditional flow direct calculation formula (5), the equal sign right side measuring device has three advantages: firstly, the calculated amount of solving b (k+1) is distributed to each node, and compared with the traditional flow average, the calculated amount is reduced to 1/N; secondly, the memory required for storing x (k) is also allocated to each node, and the memory occupation is reduced to 1/N compared with the traditional flow average; third, because the whole x (k) is not required to be stored, compared with the traditional flow, the collection from each node is reducedThe invention reduces the number of times of communication at least once compared with the traditional flow.
The invention constructs the ordinary differential equation of the linear circuit based on the scale of the linear circuit, converts the ordinary differential equation of the linear circuit into a large-scale sparse linear equation set according to the Euler iteration method, and can effectively control the number and the size of the blocks of the large-scale linear circuit, thereby ensuring the normal operation of the subsequent simulation flow; and carrying out multiple mathematical transformations on the coefficient matrix according to a set rule to obtain the coefficient matrix meeting the BBD form, simplifying a large-scale sparse linear equation set, enabling each distributed node in the simulation process not to obtain a complete simulation result, calculating complete simulation input, and obtaining a circuit simulation result, thereby reducing the calculated amount, reducing the memory occupation, reducing the communication times of the distributed node, and increasing the acceleration ratio.
Exemplary System
As shown in fig. 4, corresponding to the above-mentioned large-scale linear circuit simulation method, the embodiment of the present invention further provides a large-scale linear circuit simulation system, where the large-scale linear circuit simulation system includes:
An initialization module 410, configured to construct a normal differential equation of the linear circuit according to a scale of the linear circuit, and convert the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an euler iteration method;
The matrix pre-rearranging module 420 is configured to rearrange the rows or columns of the coefficient matrix of the large-scale sparse linear equation set, so that the diagonal of the coefficient matrix is all non-zero elements, and obtain a pre-rearranged matrix;
the matrix rearrangement module 430 is configured to perform row-column rearrangement on the pre-rearranged matrix by using a graph partitioning algorithm, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely, a diagonal line, a right boundary and a lower boundary, to obtain a dual-boundary diagonal matrix;
The Shu's complement calculation module 440 is configured to adopt a plurality of calculation nodes to form distributed nodes, solve local Shu's complements of each distributed node based on the double-boundary diagonal matrix data, and sum each local Shu's complement to obtain global Shu's complement;
The circuit simulation module 450 is configured to solve the current state of each distributed node in parallel according to the global sull and the solution result of each distributed node at the previous moment; and converting the solving results of all moments of each distributed node into a large-scale linear circuit simulation result according to the column rearrangement and the row and column rearrangement.
In particular, in this embodiment, the specific function of the above-mentioned large-scale linear circuit simulation system may also refer to the corresponding description in the above-mentioned large-scale linear circuit simulation method, which is not described herein again.
Based on the above embodiment, the present invention also provides a circuit simulator, whose schematic block diagram can be shown in fig. 5. The circuit simulator comprises a simulation chip, a memory and a large-scale linear circuit simulation program which is stored in the memory and can run on the simulation chip, and the large-scale linear circuit simulation program realizes the steps of any large-scale linear circuit simulation method when being executed by the simulation chip.
It will be appreciated by those skilled in the art that the schematic block diagram shown in fig. 5 is merely a block diagram of some of the structures associated with the present inventive arrangements and is not limiting of the circuit simulator to which the present inventive arrangements are applied, and that a particular circuit simulator may include more or fewer components than shown, or may combine some of the components, or have a different arrangement of components.
The embodiment of the invention also provides a computer readable storage medium, and the computer readable storage medium stores a large-scale linear circuit simulation program, and when the large-scale linear circuit simulation program is executed by a processor, the steps of any one of the large-scale linear circuit simulation methods provided by the embodiment of the invention are realized.
It should be understood that the sequence number of each step in the above embodiment does not mean the sequence of execution, and the execution sequence of each process should be determined by its function and internal logic, and should not be construed as limiting the implementation process of the embodiment of the present invention.
It will be apparent to those skilled in the art that, for convenience and brevity of description, only the above-described division of the functional units and modules is illustrated, and in practical application, the above-described functional distribution may be performed by different functional units and modules according to needs, i.e. the internal structure of the apparatus is divided into different functional units or modules to perform all or part of the above-described functions. The functional units and modules in the embodiment may be integrated in one processing unit, or each unit may exist alone physically, or two or more units may be integrated in one unit, where the integrated units may be implemented in a form of hardware or a form of a software functional unit. In addition, the specific names of the functional units and modules are only for distinguishing from each other, and are not used for limiting the protection scope of the present invention. The specific working process of the units and modules in the above system may refer to the corresponding process in the foregoing method embodiment, which is not described herein again.
In the foregoing embodiments, the descriptions of the embodiments are emphasized, and in part, not described or illustrated in any particular embodiment, reference is made to the related descriptions of other embodiments.
Those of ordinary skill in the art will appreciate that the elements and algorithm steps of the examples described in connection with the embodiments disclosed herein may be implemented as electronic hardware, or combinations of computer software and electronic hardware. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the solution. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present invention.
In the embodiments provided in the present invention, it should be understood that the disclosed apparatus/terminal device and method may be implemented in other manners. For example, the apparatus/terminal device embodiments described above are merely illustrative, e.g., the division of the modules or units described above is merely a logical function division, and may be implemented in other manners, e.g., multiple units or components may be combined or integrated into another system, or some features may be omitted, or not performed.
The above embodiments are only for illustrating the technical solution of the present invention, and not for limiting the same; although the invention has been described in detail with reference to the foregoing embodiments, those of ordinary skill in the art will understand that; the technical scheme described in the foregoing embodiments can be modified or some technical features thereof can be replaced by equivalents; such modifications and substitutions are not intended to depart from the spirit and scope of the various embodiments of the invention, which are also within the spirit and scope of the invention.
Claims (10)
1. A large-scale linear circuit simulation method is characterized by comprising the following steps:
Constructing a normal differential equation of a linear circuit according to the scale of the linear circuit, and converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method;
The coefficient matrix of the large-scale sparse linear equation set is rearranged in a column mode, so that the diagonal lines of the coefficient matrix are all non-zero elements, and a pre-rearranged matrix is obtained;
A graph dividing algorithm is utilized to conduct row-column rearrangement on the pre-rearranged matrix, so that non-zero elements of the pre-rearranged matrix are distributed on a diagonal line and two boundaries of the right and the lower, and a double-boundary diagonal matrix is obtained;
Adopting a plurality of computing nodes to form distributed nodes, solving local schulums of all the distributed nodes based on the double-boundary diagonal matrix data, and summing all the local schulums to obtain a global schulums;
according to the global Shu's complement and the solving result of each distributed node at the last moment, the state of each distributed node at the current moment is solved in parallel; according to the column rearrangement and the row and column rearrangement, converting the solving results of all moments of each distributed node into the large-scale linear circuit simulation results;
The step of using a graph dividing algorithm to perform row-column rearrangement on the pre-rearranged matrix so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries of a diagonal line, a right boundary and a lower boundary to obtain a double-boundary diagonal matrix, the method comprises the following steps:
creating an original graph stack for storing original graphs and a sub graph stack for storing sub graphs obtained by halving, wherein the original graphs are undirected graphs corresponding to coefficient matrixes; dividing the original image into sub-images after the original image stack is taken out one by one, and obtaining a sub-image; and pushing the binary image into the sub-image stack until the original image stack is empty, and exchanging the original image stack and the sub-image stack; repeating the process of dividing each original image into sub-images and exchanging the original image stack and the sub-image stack until the number of the sub-images in the sub-image stack or the exchange times of the original image stack and the sub-image stack reach the preset number; and (3) performing row-column rearrangement on the pre-rearranged matrix by using all the bipartite graphs, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line, a right boundary and a lower boundary, and a double-boundary diagonal matrix is obtained.
2. The method of claim 1, wherein the performing row-column rearrangement on the pre-rearranged matrix by using a graph partitioning algorithm so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line and a right and a bottom boundary, to obtain a double-boundary diagonal matrix comprises:
Creating an original graph stack for storing original graphs and a sub graph stack for storing sub graphs obtained by halving, wherein the original graphs refer to undirected graphs corresponding to the pre-rearranged matrixes;
Dividing the original image into two sub-images after the original image stack is taken out one by one, and obtaining two sub-images; and the two sub-graphs are input into the sub-graph stack until the original graph stack is empty, and the original graph stack and the sub-graph stack are exchanged;
repeating the process of dividing each original image into sub-images and exchanging the original image stack and the sub-image stack until the number of the sub-images in the sub-image stack or the exchange times of the original image stack and the sub-image stack reach a preset number;
And performing row-column rearrangement on the pre-rearranged matrix by using all the bipartite graphs, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries, namely a diagonal line, a right boundary and a lower boundary, and a double-boundary diagonal matrix is obtained.
3. The method of claim 2, wherein the step of dividing the artwork into sub-graphs after the artwork is exported from the artwork stack one by one to obtain a two-component graph comprises:
acquiring the sizes of all the original pictures popped from the original picture stack;
Presetting a bipartite graph size threshold based on global information of all the bipartite graphs obtained in the last bipartite, and if the original graph size exceeds the preset bipartite graph size threshold, bipartite the original graph into sub graphs to obtain the bipartite graphs; otherwise, the original graph is set as the bipartite graph.
4. A method of large scale linear circuit simulation according to claim 2 or 3, wherein said using all the bipartite graphs to reorder the pre-reordered matrix such that the non-zero elements of the pre-reordered matrix are distributed at the diagonal and the right and bottom two boundaries, to obtain a double-boundary diagonal matrix, comprises:
presetting a column rearrangement matrix, a double boundary diagonal rearrangement matrix, a row expansion matrix and a column expansion matrix based on the dimension of the coefficient matrix;
based on the column rearrangement matrix, the row expansion matrix and the column expansion matrix, the diagonal lines of the coefficient matrix are provided with elements, the absolute value of the elements is 1, and the absolute values of the elements except the elements on the diagonal lines are not more than 1, so that a pre-rearrangement matrix is obtained;
And constructing a double-boundary diagonal rearrangement form based on the graph dividing algorithm, and rearranging the rows and the columns of the pre-rearranged matrix by utilizing the double-boundary diagonal rearrangement form to obtain a double-boundary diagonal matrix.
5. The method of claim 1, wherein the adopting a plurality of computing nodes to form distributed nodes, solving local sull complements of the distributed nodes based on the double boundary diagonal matrix data, and summing the local sull complements to obtain global sull complements, comprises:
Adopting a plurality of computing nodes to form distributed nodes, storing the data of the double-boundary diagonal matrix on a target node, marking the target node as a main node, and marking nodes except the main node as child nodes;
Broadcasting data on the main node to each child node through a first message transfer interface function, and solving local Shu's complements of all the distributed nodes;
And summing the local Shu's complements through a second message transfer interface function to obtain a global Shu's complement.
6. The method of claim 5, wherein said broadcasting data on said master node to each of said child nodes via a first message passing interface function, solving for local schulp for all of said distributed nodes, comprises:
based on the data on the master node, screening out elements in the double-boundary diagonal matrix corresponding to each distributed node, and constructing a block matrix by using the elements corresponding to each distributed node;
And solving each blocking matrix in a parallel computing mode to obtain the local Shu's complement of each distributed node.
7. The method of claim 4, wherein converting the solution results for all times of each of the distributed nodes into the large-scale linear circuit simulation results comprises:
according to the global Shu's complement and the solving result of each distributed node at the last moment, the state of each distributed node at the current moment is solved in parallel;
According to the column rearrangement matrix and the double-boundary diagonal rearrangement matrix, finding out the rows of the large-scale linear circuit simulation results corresponding to the solving results of all the distributed nodes at all moments;
and scaling all elements on the row according to the column expansion matrix to obtain the large-scale linear circuit simulation result.
8. A large scale linear circuit simulation system, the system comprising:
The initialization module is used for constructing a normal differential equation of the linear circuit according to the scale of the linear circuit and converting the normal differential equation of the linear circuit into a large-scale sparse linear equation set according to an Euler iteration method;
The matrix pre-rearranging module is used for rearranging the coefficient matrix of the large-scale sparse linear equation set to ensure that the diagonal of the coefficient matrix is all non-zero elements, so as to obtain a pre-rearranging matrix;
The matrix rearrangement module is used for carrying out row-column rearrangement on the pre-rearranged matrix by using a graph dividing algorithm, so that non-zero elements of the pre-rearranged matrix are distributed on a diagonal line and two boundaries of a right boundary and a lower boundary to obtain a double-boundary diagonal matrix; the step of using a graph dividing algorithm to perform row-column rearrangement on the pre-rearranged matrix so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries of a diagonal line, a right boundary and a lower boundary to obtain a double-boundary diagonal matrix, the method comprises the following steps: creating an original graph stack for storing original graphs and a sub graph stack for storing sub graphs obtained by halving, wherein the original graphs are undirected graphs corresponding to coefficient matrixes; dividing the original image into sub-images after the original image stack is taken out one by one, and obtaining a sub-image; and pushing the binary image into the sub-image stack until the original image stack is empty, and exchanging the original image stack and the sub-image stack; repeating the process of dividing each original image into sub-images and exchanging the original image stack and the sub-image stack until the number of the sub-images in the sub-image stack or the exchange times of the original image stack and the sub-image stack reach the preset number; the pre-rearranged matrix is subjected to row-column rearrangement by utilizing all the bipartite graphs, so that non-zero elements of the pre-rearranged matrix are distributed on two boundaries of diagonal lines and right and lower boundaries, and a double-boundary diagonal matrix is obtained;
the Shu's complement calculation module is used for adopting a plurality of calculation nodes to form distributed nodes, solving the local Shu's complement of each distributed node based on the double boundary diagonal matrix data, and summing each local Shu's complement to obtain the global Shu's complement;
The circuit simulation module is used for parallelly solving the state of each distributed node at the current moment according to the global Shu's complement and the solving result of each distributed node at the last moment; and converting the solving results of all moments of each distributed node into the large-scale linear circuit simulation results according to the column rearrangement and the row and column rearrangement.
9. A circuit simulator, characterized in that it comprises a simulation chip, a memory and a large-scale linear circuit simulation program stored on the memory and operable on the simulation chip, which when executed by the simulation chip implements the steps of the large-scale linear circuit simulation method according to any one of claims 1-7.
10. A computer readable storage medium, characterized in that the computer readable storage medium has stored thereon a large scale linear circuit simulation program, which when executed by a processor, implements the steps of the large scale linear circuit simulation method according to any of claims 1-7.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310929719.2A CN117077607B (en) | 2023-07-26 | 2023-07-26 | Large-scale linear circuit simulation method, system, circuit simulator and storage medium |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310929719.2A CN117077607B (en) | 2023-07-26 | 2023-07-26 | Large-scale linear circuit simulation method, system, circuit simulator and storage medium |
Publications (2)
Publication Number | Publication Date |
---|---|
CN117077607A CN117077607A (en) | 2023-11-17 |
CN117077607B true CN117077607B (en) | 2024-06-18 |
Family
ID=88717762
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310929719.2A Active CN117077607B (en) | 2023-07-26 | 2023-07-26 | Large-scale linear circuit simulation method, system, circuit simulator and storage medium |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN117077607B (en) |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2959525B2 (en) * | 1997-06-02 | 1999-10-06 | 日本電気株式会社 | Data processing apparatus and method, information storage medium |
US8065129B1 (en) * | 2004-11-19 | 2011-11-22 | Synopsys, Inc. | Methods and apparatuses for circuit simulation |
EP1964010B1 (en) * | 2005-12-19 | 2017-07-19 | Synopsys, Inc. | Parallel multi-rate circuit simulation |
US20100082724A1 (en) * | 2008-09-30 | 2010-04-01 | Oleg Diyankov | Method For Solving Reservoir Simulation Matrix Equation Using Parallel Multi-Level Incomplete Factorizations |
CN102087678B (en) * | 2011-01-07 | 2012-07-11 | 清华大学 | Circuit simulation method for realizing parallel computation through time domain division |
US9449129B2 (en) * | 2013-04-30 | 2016-09-20 | Freescale Semiconductor, Inc. | Method and apparatus for accelerating sparse matrix operations in full accuracy circuit simulation |
CN113032722B (en) * | 2021-03-29 | 2022-08-16 | 北京华大九天科技股份有限公司 | Method for reducing matrix decomposition in circuit simulation |
CN113255259B (en) * | 2021-05-21 | 2022-05-24 | 北京华大九天科技股份有限公司 | Parallel solving method based on large-scale integrated circuit division |
CN113486616B (en) * | 2021-07-21 | 2022-05-24 | 成都华大九天科技有限公司 | Block matrix storage method in circuit simulation |
CN113723032B (en) * | 2021-08-30 | 2023-08-15 | 全球能源互联网研究院有限公司 | Large-scale node-oriented circuit quick calculation method and system |
CN114580345B (en) * | 2022-04-29 | 2022-07-05 | 深圳鸿芯微纳技术有限公司 | Circuit simulation method and device, computer equipment and computer readable storage medium |
CN116070584B (en) * | 2023-03-06 | 2024-06-25 | 深圳市比昂芯科技有限公司 | Circuit simulation method, circuit simulation device, electronic equipment and computer readable storage medium |
-
2023
- 2023-07-26 CN CN202310929719.2A patent/CN117077607B/en active Active
Non-Patent Citations (2)
Title |
---|
丁硕 ; 张放 ; 巫庆辉.基于MATLAB/Simulink的正弦稳态电路建模与仿真.国外电子测量技术.2015,全文. * |
模拟集成电路的仿真与优化方法概述;杨帆;微纳电子与智能制造;20210615;全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN117077607A (en) | 2023-11-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110197270A (en) | Integrated circuit chip device and Related product | |
CN114004186B (en) | Method for simulating ultra-large scale power supply network in chip in parallel based on spectrogram sparsification | |
WO2023045445A1 (en) | Data processing device, data processing method, and related product | |
CN111796796A (en) | FPGA storage method, calculation method, module and FPGA board based on sparse matrix multiplication | |
CN114781629B (en) | Hardware accelerator of convolutional neural network based on parallel multiplexing and parallel multiplexing method | |
CN117077607B (en) | Large-scale linear circuit simulation method, system, circuit simulator and storage medium | |
CN114764615A (en) | Convolution operation implementation method, data processing method and device | |
Chan | Parallel algorithms for direct solution of large sparse power system matrix equations | |
CN116348882A (en) | Convolutional neural network data processing method and related equipment thereof | |
CN111667052B (en) | Standard and nonstandard convolution consistency transformation method of special neural network accelerator | |
CN117290653B (en) | Matrix solving method and system based on EDA system | |
CN112513861B (en) | Method and system for hierarchical circuit simulation using parallel processing | |
WO2024091298A1 (en) | Multiply-instantiated block modeling for circuit component placement in integrated circuit | |
US11113623B2 (en) | Multi-sample system for emulating a quantum computer and methods for use therewith | |
CN110197275B (en) | Integrated circuit chip device and related product | |
CN110598174B (en) | Back-substitution solving method of sparse matrix based on GPU architecture | |
CN114819167A (en) | Sparse approximate inverse quantum preprocessing method and device for sparse linear system | |
CN113469333A (en) | Artificial intelligence processor, method and related product for executing neural network model | |
CN110197265B (en) | Integrated circuit chip device and related product | |
CN113837923B (en) | Data processing device, data processing method and related products | |
CN111967590B (en) | Heterogeneous multi-XPU machine learning system oriented to recommendation system matrix decomposition method | |
Buurman | From Circuit to Signal: development of a piecewise linear simulator | |
Dong et al. | Caching Hybrid Rotation: A Memory Access Optimization Method for CNN on FPGA | |
CN118940710A (en) | Chip layout information generation method, device, computer equipment and storage medium | |
CN115222013A (en) | Execution unit and acceleration unit for sparse neural network model execution |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |