The present disclosure relates to methods and systems for analogue circuit design, and in particular, methods and systems for automating the design process for analogue circuits.
Analogue components cause the most chip production test failures and up to 95% of field failures. While circuit design for digital circuits has become automated to some degree in recent times, the automation of analogue circuit design has proven problematic, not least due to e.g. parasitic effects. Conventional approaches to analogue circuit design might involve “best guess” estimates or specification guard-banding performed manually by engineering teams relying on prior knowledge and experience, often with the result that circuits are over-engineered and inefficient, or prone to failure. There is therefore a desire to create a more efficient and reliable process for designing analogue circuits.
Aspects of the invention are as set out in the independent claims and optional features are set out in the dependent claims. Aspects of the invention may be provided in conjunction with each other and features of one aspect may be applied to other aspects.
In a first aspect there is provided an analogue circuit design apparatus. The apparatus comprises at least one design unit configured to:
It will be understood that obtaining information relating to parasitics may comprise extracting information relating to parasitics.
Advantageously such a design apparatus allows parasitics to be estimated and considered as part of the initial design process, which has previously been very difficult to achieve for analogue circuits. Moreover, the analogue circuit design apparatus can automatically design analogue circuits to meet customer requirements an implementation of machine learning. Hence it is not necessary for the designer to (re)design analogue circuits manually.
In some examples information relating to the context of that component or portion of the circuit may be obtained and used as part of the design process—in other words, what that portion or component of the circuit will experience when placed in the completed circuit in situ (in some examples the context may be provided as part of the technical criteria, although in other examples it may be provided as something in addition to the technical criteria). The context may comprise parameters and variables that the portion or component of the circuit experiences in use. The context of any given circuit portion or component may be generated based on simulating the performance of a circuit portion(s) or component(s) that interact with that given circuit portion or component, or even by simulating a completed circuit comprising that given circuit portion or component. For example, the at least one design unit may be configured produce at least one respective design for a corresponding circuit portion based on the context of at least one other circuit portion.
It will be understood that the analogue circuit design apparatus may comprise a primary design unit and a plurality of secondary design units. The primary design unit may be configured to:
Each of the plurality of secondary design units of the analogue circuit design apparatus may be configured to:
The primary design unit may be further configured to:
At least one of the secondary design units may be configured to adapt the design of its respective circuit portion based on the information relating to parasitics; and the primary design unit may be configured to output the complete circuit design including the at least one adapted circuit portion.
In some examples the analogue circuit design unit is configured to populate a database of parasitics and circuit designs by repeating the steps a) to e) a plurality of times, wherein each time the steps a) to e) are repeated new technical criteria are provided by the primary design unit. The analogue circuit design unit may be configured to repeat the steps a) to e) for pre-defined circuit portions or elements that match an identified or selected circuit structure, and/or for known or selected structures or functional blocks (e.g. DACs, level shifters, comparators etc.). The pre-defined circuit portion may be sensitive to variation. For example, the bridge cap on a DAC is dependent on the total capacitance to the input stage of the comparator which includes the parasitic capacitance of the input device and any routing.
The analogue circuit design apparatus may be configured to obtain information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by mathematically simulating the performance of at least one of (i) the designed circuit portion and (ii) a complete analogue circuit comprising the designed circuit portion, in a virtual test bench.
Additionally or alternatively the design apparatus may be configured to obtain information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by performing a lookup in a database of circuit designs and parasitics. The parasitics may, for example, be derived from a database lookup of individual circuit elements (portions of a circuit) using various terms including but not limited to configuration, process, topology and any other sizing factors.
Additionally or alternatively the analogue circuit design apparatus may be configured to obtain information relating to parasitics experienced by that generated design by performing a lookup, in a database of circuit designs and parasitics, for similar generated designs, It will be understood that similar generated designs may comprise designs having greater than a selected threshold level of similarity, for example greater than a selected threshold level of features in common.
Additionally or alternatively the design apparatus is configured to perform a lookup, in a database of circuit designs and parasitics, for at least one of the respective circuit portions for similar respective circuit portions, and wherein the design apparatus is configured to obtain information relating to parasitics experienced by the generated design based on the values of parasitics obtained via the lookup for the at least one of the respective circuit portions.
In some examples the design apparatus is configured to obtain information relating to parasitics experienced by that generated design by using a machine learning model to predict the parasitics. Additionally or alternatively the design apparatus may be configured to obtain information relating to parasitics experienced by each respective circuit portion using a machine learning model to predict the parasitics. In some examples the machine learning model may have been trained using the design apparatus.
It will be understood that the parasitics include at least one of parasitic capacitances, parasitic resistances, and parasitic inductances.
In some examples the analogue circuit design apparatus is configured to adapt the design of its respective circuit portion in the event that the information relating to parasitics experienced by the generated design indicates that the parasitics are greater than a selected threshold level of parasitics. In some examples the technical criteria may specify an acceptable threshold level of parasitics. In such examples the information relating to parasitics experienced by the generated design may indicate that the circuit (and/or portions of the circuit) no longer meets technical criteria. In such examples adapting the design of the respective portion based on the information relating to parasitics may comprise adapting the technical criteria, for example adapting the technical criteria of at least one respective circuit portion.
In another aspect there is provided a method of training a machine learning model for predicting parasitics in designed analogue circuits. The method comprises: at each of a plurality of secondary design units of an analogue circuit design apparatus:
It will be understood that in some examples step d) is optional and the information relating to parasitics of a circuit portion may be obtained before an initial design for the analogue circuit is generated. It will also be understood that obtaining information relating to parasitics may comprise extracting information relating to parasitics.
In some examples the method may further comprise a step f) of populating a database of the parasitics and corresponding circuit design. This step may be repeated when steps a) to e) are repeated. The database may then be used to train a machine learning model (such a neural network, a convolutional neural network or a deep learning module) to estimate parasitics for circuit designs, for example for circuit designs that are not contained in the database. The neural network may comprise at least one of a Deep Residual Network (ResNet), a Highway Network, a Densely Connected Network (DenseNet) and a Capsule Network.
In another aspect there is provided a method of designing an analogue circuit. The method comprises: receiving information representing technical requirements for the analogue circuit;
The method may further comprise, at a primary design unit of an analogue circuit design apparatus:
The method may further comprise, at each of a plurality of secondary design units of the analogue circuit design apparatus:
It will be understood that obtaining information relating to parasitics may comprise extracting information relating to parasitics.
The method may further comprise:
The method may comprise populating a database of parasitics and circuit designs by repeating the steps a) to e) a plurality of times, wherein each time the steps a) to e) are repeated new technical criteria are provided by the primary design unit. The method may comprise repeating the steps a) to e) for pre-defined circuit portions or elements that match an identified or selected circuit structure, and/or for known or selected structures or functional blocks (e.g. DACs, level shifters, comparators etc.). The pre-defined circuit portion may be sensitive to variation. For example, the bridge cap on a DAC is dependent on the total capacitance to the input stage of the comparator which includes the parasitic capacitance of the input device and any routing.
In some examples the method comprises obtaining information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by mathematically simulating the performance of the generated design in a virtual test bench.
Additionally or alternatively the method may comprise obtaining information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by performing a lookup in a database of circuit designs and parasitics.
Additionally or alternatively the method may comprise obtaining information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by performing a lookup, in a database of circuit designs and parasitics, for similar generated designs. It will be understood that similar generated designs may comprise designs having greater than a selected threshold level of similarity, for example greater than a selected threshold level of features in common.
Additionally or alternatively the method may comprise performing a lookup, in a database of circuit designs and parasitics, for at least one of the respective circuit portions for similar respective circuit portions, and obtaining information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, based on the values of parasitics obtained via the lookup for the at least one of the respective circuit portions.
Additionally or alternatively the method may comprise obtaining information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by using a machine learning model to predict the parasitics. Additionally or alternatively the method may comprise obtaining information relating to parasitics experienced by each respective circuit portion using a machine learning model to predict the parasitics. In some examples the machine learning model may have been trained using the design apparatus.
It will be understood that the parasitics include at least one of parasitic capacitances, parasitic resistances, and parasitic inductances. In some examples adapting the design of its respective circuit portion is performed in the event that the information relating to parasitics indicates that the parasitics are greater than a selected threshold level of parasitics. In some examples the technical criteria may specify an acceptable threshold level of parasitics. In such examples the information relating to parasitics experienced by the generated design may indicate that the circuit (and/or portions of the circuit) no longer meets technical criteria. In such examples adapting the design of the respective portion based on the information relating to parasitics may comprise adapting the technical criteria, for example adapting the technical criteria of at least one respective circuit portion.
In some examples adapting the design of the respective portion based on the information relating to parasitics comprises adapting the corresponding technical criteria of the respective circuit portion.
It will be understood that the method may further comprise fabricating an analogue circuit to the output design.
In another aspect there is provided a computer readable non-transitory storage medium comprising a program for a computer configured to cause a processor to perform any of the methods described above.
Embodiments of the disclosure will now be described, by way of example only, with reference to the accompanying drawings, in which:
Embodiments of the claims relate to a method and system for automating the design of analogue circuits that can predict or anticipate parasitics in designed circuits or portions of the designed circuit so that a more efficient circuit can be designed. The inventors in the present case have done that by developing a computer-implemented model that delegates responsibility for designing portions or components of the analogue circuit to respective units or “blocks”. An example of this model is shown in
The instructions may also include information relating to the context of that component or portion of the circuit—in other words, what that portion or component of the circuit will experience when placed in the completed circuit in situ (in some examples the context may be provided as part of the technical criteria, although in other examples it may be provided as something in addition to the technical criteria). The context may comprise parameters and variables that the portion or component of the circuit experiences in use. The context of any given circuit portion or component may be generated based on simulating the performance of a circuit portion(s) or component(s) that interact with that given circuit portion or component, or even by simulating a completed circuit comprising that given circuit portion or component. For example, the parent block 900 may be configured to assemble a completed circuit from the portions or components designed by each child block 950a-d and simulate the assembled circuit's operation. The context of any given circuit portion or component may additionally or alternatively be generated based on mathematical calculations or extraction.
By designing an analogue circuit in this way, the parasitics that will be experienced by a respective circuit portion, or a circuit comprising a number of respective circuit portions, can be estimated (for example, by the parent block 900) and, if necessary, an adapted circuit can be created that can mitigate against parasitics.
The computer-implemented hierarchical model is iterative. Once the parent block 900 has instructed each child block 950a-d to design their respective portions, it is likely that a degree of redesign of the circuit and its respective portions is required to take into account the parasitics and/or optionally the context arising from the respective circuit portions designed by the other child blocks 950a-d
In particular, once an initial design of a circuit portion or completed analogue circuit has been designed, the design of one of the circuit portions and/or the completed analogue circuit may need to be adapted due to the estimated parasitics that may be experienced either by a particular circuit portion or by the completed analogue circuit. The process of designing the circuit portions may therefore be repeated to adapt the designs of one or more circuit portions to take into account the estimated parasitics in an attempt to mitigate and reduce them. This process of adapting designs of circuit portions may be repeated iteratively by the child blocks 950a-d, for example until any change in estimated parasitics caused by any adjustments to any other portions or components of the analogue circuit have been taken into account. For example, the process may iteratively repeat until any changes in estimated parasitics are less than a selected threshold level of change in parasitics.
The parasitics of any given circuit portion may be generated based on simulating the performance of a circuit portion(s) that interact with that given circuit portion, or even by simulating a completed circuit comprising that given circuit portion. For example, the parent block 900 may be configured to assemble a completed circuit from the portions designed by each child block 950a-d and simulate the assembled circuit's operation. The parasitics of any given circuit portion may additionally or alternatively be generated based on mathematical calculations or extraction. Additionally or alternatively, the parasitics of any given circuit portion may be obtained by performing a lookup in a database of circuit designs and parasitics and/or predicted using a machine learning model.
The present inventors have found that advantageously such an iterative hierarchical model allows the design of analogue circuits to be automated. As a result, advantageously this means that over-engineered analogue circuits and/or circuits with unacceptable parasitics can be avoided, and instead more efficient circuits designed and created.
As noted above,
The present inventors have recognised that the design and selection of the respective circuit portions should therefore be performed in a manner that takes into account the parasitics experienced by the completed circuit and/or the respective circuit portions (optionally as well as the interactions arising from each respective circuit portion's context), such that a completed analogue with minimised parasitics is designed.
A non-exhaustive list of examples of the parameters and variables that may affect the selection and design of these different blocks may include: silicon process, temperature range, output load, output impedance, input capacitance, input common mode range, input differential swing, supply voltage, types of transistors available, output common mode range, output swing, settling time, noise tolerance; power supply rejection ratio (PSRR); common mode range—input (Input CMR); common mode range—output (Output CMR); linearity; maximum offset; bandwidth; minimum slew rate; intrinsic delay; minimum phase margin; active power consumption; static power consumption; IP3 point; filter centre-frequency; filter band-pass range; load step response; line step response; output accuracy; noise figure; calibration range; noise floor; SNR; ENOB; SINAD; output frequency range; jitter—ptp; jitter—RMS; output ripple ptp; total harmonic distortion; start-up time; channel isolation; reference voltage; gain error; offset error; gain drift. These parameters and variables may be called the “context” or environment in which the block is in. To create an optimal analogue circuit, knowledge of the context can improve the design of the circuit.
However, it will of course be appreciated that the design of an analogue circuit is an iterative process, whereby the selection and adjustment of one block may affect the context of another block, and so on. Thus once the components of one block have been selected/adjusted to form a circuit portion, the components of another block may need to be adjusted or re-selected to take into account the parasitics experienced by the completed circuit/circuit portion and/or optionally the new context in which that block is in. Such an iterative process is not practical to perform manually, is error-prone and can only be detected through communication.
As noted above, an example computer-implemented model for use in a method of automating the design of analogue circuits is shown in
In the example shown in
While each respective circuit portion may initially be designed by corresponding respective blocks in isolation, the context in which each respective circuit portion operates when applied in the circuit as a whole in situ may affect how both the respective circuit portions, as well as the circuit as a whole, operates. This operation will also include the parasitics that the circuit as a whole will experience when in use. Therefore while the parent block may instruct each child block to design their respective portions, once an initial version of the designed circuit is assembled by the parent 900 from the portions or components designed by each child block 950a-d, it is likely that a degree of adaption or even redesign of the circuit 1000 and its portions or components is required to take into account the resulting parasitics and optionally the context created by portions designed by the other child blocks 950a-d. As noted above, this will be an iterative process.
The parent block 900 is therefore configured to act as a controller, processing and handling the design process carried out by each of the child blocks. To perform this function, as shown in
The instructor module 901 is configured to receive customer requirements for the circuit to be designed, along with other requirements such as the PDK/conditions/control parameters e.g. dictated by the foundry, and to convert these into a series or set of technical criteria that each child block 950a-d needs to meet when designing their respective components of the circuit. It is also configured to prepare and send the instructions to each child block 950a-d as to what they need to design and what criteria they need to meet in doing this. The instructions may also include the context of other designed portions of circuits designed by other child blocks and the wider context of the circuit in which that component or portion of the circuit is intended to be operated in. For example, the technical criteria may be adjusted to take into account the context.
The assembly module 902 is configured to receive and collate all of the respective designed portions or components of the analogue circuit provided by each of the child blocks 950a-d, and to assembly a complete analogue circuit based on the respective designed portions or components. The completed analogue circuit may then be tested by the verification and simulator module 903.
The verification and simulator module 903 is configured to receive the designed components from each of the child blocks and to compare these to the technical set of requirements to determine whether the designed portions or components are satisfactory or not. This may comprise comparing their performance to the customer requirements, for example by verifying whether or not a designed respective circuit portion or component meets its corresponding technical criteria and/or whether or not the designed analogue circuit meets the customer requirements. It may additionally or alternatively comprise a validation check to determine whether or not the circuit that is designed is valid in the sense that it can operate within certain technical limitations.
The verification and simulator module 903 is also configured to act as a “test bed” and simulate the functioning of the assembled components of the circuit. Such a simulation may yield the parasitics information, as well as optional context information. For example, the verification and simulator module 903 may be configured to obtain information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by mathematically simulating the performance of at least one of (i) the designed circuit portion and (ii) a complete analogue circuit comprising the designed circuit portion, in a virtual test bench. Additionally or alternatively, the verification and simulator module 903 may be configured to obtain information relating to parasitics, that will be experienced in the analogue circuit if the analogue circuit were to include that designed circuit portion, by performing a lookup in a database of circuit designs and parasitics, for example by performing a lookup, in a database of circuit designs and parasitics, for similar generated designs. Additionally or alternatively the verification and simulator module 903 may be configured to perform a lookup, in a database of circuit designs and parasitics, for at least one of the respective circuit portions for similar respective circuit portions, and obtain information relating to parasitics experienced by the generated design based on the values of parasitics obtained via the lookup for the at least one of the respective circuit portions. In other examples the verification and simulator module 903 is configured to obtain information relating to parasitics experienced by that generated design by using a machine learning model to predict the parasitics.
The verification and simulator module 903 may also be configured to populate a database of parasitics and circuit designs, for example if the instructor module 901 instructs the child blocks 950a-d to repeat the process of designing circuit portions based on (new or adapted) corresponding technical criteria a plurality of times.
The verification and simulator module 903 may additionally compare the simulated functioning of the circuit to the customer requirements, and optionally verify whether or not a designed circuit portion meets its corresponding technical criteria and/or whether or not the designed analogue circuit meets the customer requirements. In some examples it will be understood that the simulator module may replace the verification module 903.
Each child block 950a-d also comprises a number of different modules each configured to perform different functions as part of the design process. In the example shown in
The converter module 951a-d of each child block 950a-d is configured to receive the technical criteria received from the parent block 900 and optionally the context of the circuit as a whole, as well as the context of the other components of the circuit, and convert these into a set of requirements for designing a portion or component of the analogue circuit to meet those criteria. It will be understood that in some examples the context information may be provided and received as part of the technical criteria, but in other examples it may be provided in addition to (e.g. separate from) the technical criteria.
The assembly module 952a-d is configured to select and/or design electronic components to satisfy the requirements being asked of it that meet the criteria dictated by the parent block and the context of the circuit as a whole and/or the context of the other components of the circuit.
The simulator module 953a-d may also be configured to simulate how those components would run in situ to check/verify whether the designed portions or components designed by the assembly module are technically feasible. In some examples the simulator module 953a-d may also obtain information relating to the parasitics of the respective circuit portion that its block has designed, in a manner similar to the verification and simulator module 903 of the parent block 900 described above (it will be understood that in such examples the verification and simulator module 903 of the parent block 900 may not need to obtain information relating to parasitics as this may have already been performed by the simulator module 953a-d of each child block 950a-d).
In use, the parent block 900 receives a set of requirements for an analogue circuit 1000 to be designed. In the example shown in
The instructor module 901 may send these technical criteria to each of the child blocks 950a-d in parallel (i.e. all at the same time) or in series (e.g. where the criteria are sent to child 1, then child 2, then child 3 and so on). In some examples the instructor module 901 may wait until it receives a designed circuit from the first child before sending a set of technical criteria to the next child, and in some examples the instructor module may be configured to adjust the technical criteria sent to the next child based on the designed circuit received from the preceding child—in other words based on the context of the designed circuit received from the preceding child.
In examples where the technical criteria are sent to the child blocks 950a-d in series, the technical criteria may comprise means to distinguish which portions of the technical criteria are relevant to which child blocks 950a-d—for example, the technical criteria may comprise headers or flags that identify whether or not a particular portion of the technical criteria is relevant to a child block 950a-d or not. These headers or flags may be determined by the parent block 900, and the technical criteria adjusted accordingly to incorporate them.
Each child block 950a-d receives these technical criteria from the parent block 900 and each respective converter module 951a-d converts these into a set of requirements for designing a portion or component of the analogue circuit to meet those technical criteria. The assembly module 952a-d receives these requirements and designs components/a portion of the circuit that meets these requirements. It will be understood that this design process may comprise a lookup in a database of known circuit designs (or portions therefore) and finding a circuit design that best matches the technical criteria.
The simulator module 953a-d then simulates how these components/portion of the circuit would work in situ to check whether the designed components/portion of the circuit designed by the assembly module is technically feasible and/or to verify whether or not the corresponding designed respective circuit portion meets its corresponding technical criteria. If the designed circuit portion meets its corresponding technical criteria, the child block 950a-d is then configured to send or output the designed portion or component of the circuit back to the parent 900. If the designed circuit portion does not meet its corresponding technical criteria, the child block 950a-d is then configured to adapt the design of its circuit portion and repeat the process.
Once the parent 900 receives all of the designed portions or components of the circuit back from all the child blocks 950a-d, the assembly module 902 of the parent 900 then assembles the completed circuit (in this case the ADC) from the portions or components designed by each child block and verifies whether the designed circuit meets the technical requirements via the verification and simulator module 903. It may do this by simulating how the assembled circuit performs and comparing this simulated performance to the customer requirements and/or the technical requirements. It will be understood that in some examples this simulated performance of the completed analogue circuit design may be used to obtain the parasitics and/or the optional context information (e.g. for another design unit), and the parent 900 may adjust the technical criteria based on the parasitics and/or optional context information obtained via the simulation of the completed analogue circuit design.
If the simulated performance of the designed circuit does not meet the customer requirements or the technical requirements (for example, a parameter of the simulated circuit is greater than a threshold level of different from a parameter dictated by the technical requirements such as the parasitics being above a threshold level of parasitics) then the verification module 903 communicates this to the instructor module 901. The instructor module 901 may then adjust the technical criteria based on the difference between the simulated performance of the circuit and the technical requirements, and send these revised technical criteria back to the child blocks 950a-d.
In some examples the parent block 900 (for example, the verification module 903/instructor module 901) may be configured to determine which portion or component of the circuit is responsible for the circuit not meeting the technical requirements (for example which portion is responsible for a large proportion of the parasitics), and in the event that a child block(s) 950a-d can be identified, the parent block 900 may be configured to send the revised technical criteria only to the child block responsible for the offending portions or components of the circuit. However, in other examples the revised criteria may be sent back to all child blocks 950a-d, It will also be appreciated that in some examples the parent module 900 may determine that additional and/or alternative child blocks 950a-d and/or grandchild blocks may be required to design the relevant portions or components of the circuit, for example to meet the revised technical criteria.
The process then continues in an iterative manner, where the converter module 951a-d of each child block 950a-d receives these revised or adapted technical criteria from the parent block 900 and converts these into a new set of requirements for designing a portion or component of the analogue circuit to meet those adapted technical criteria. The assembly module 952a-d receives these new requirements and designs components/a portion of the circuit that meets these requirements. The simulator module 953a-d may then simulate how the redesigned components/portion of the circuit would work in situ to check whether the designed components/portion of the circuit designed by the assembly module is technically feasible. The child block 950a-d is then configured to send the (re)designed components/portion of the circuit back to the parent 900.
Once the parent 900 receives all of the (re)designed components/portions of the circuit back from all the child blocks 950a-d, the parent 900 then assembles the completed circuit (in this case the ADC) from the components/portions designed by each child block and verifies whether the designed circuit meets the technical requirements via the verification and simulator module 903 which may simulate how the assembled circuit performs and compares this simulated performance to the technical requirements. If the simulated performance does not meet the technical requirements, then the process repeats whereby a revised set of criteria are sent back to the child block(s) 950a-d. In some examples the parent 900 (such as the verification and simulator module 903) may populate a database with the design circuits/circuit portions and their simulated parasitics, for example for use in training a machine learning model or for use in estimating parasitics in future.
It will be understood that the child blocks 950a-d and/or the parent block 900 may also comprise a loop mitigation module to stop endless redesign loops occurring. For example, the loop mitigation module may be configured to have a record of previously designed circuits and output a loop indication if a redesigned component/portion of a circuit, or completed circuit, is identical to a previously designed component/portion of a circuit, or completed circuit, or only differs from a previously designed component/portion of a circuit, or completed circuit by less than a selected threshold level of difference. For example, the parent block 900 may comprise the loop mitigation module and may be configured to end the design process and accept the last designed circuit as the completed circuit in the event that the loop mitigation module provides the loop indication. Additionally or alternatively the parent block 900 may be configured to reduce the selected threshold level of difference, for example if the design process repeats for a selected number of iterations. This may have the effect of finding the “best compromise” functioning circuit that meets the technical requirements.
In more detail, as shown in
Beneath the core design layer sits a first design layer. The first design layer comprises secondary design units or child blocks 950 coupled to the parent block 900 of the layer above (in this case the core design layer). In the example shown there are six child blocks, all coupled to the parent block of the core design layer. The child blocks 950 are grouped into two different groups: a first group comprising child blocks 1, 2 and 3; and a second group comprising child blocks 3, 4 and 5. Each child block 950 is coupled to the parent block 900. The two groups may represent different functional regions or areas of an analogue circuit which the parent block 900 instructs to be designed in parallel.
In the example shown, the child blocks 950 of the first group are coupled in parallel to the parent block 900 of the core design layer, and the child blocks 950 of the second group are coupled in parallel to the parent block 900 of the core design layer. The child blocks 950 may be grouped in this way to design different areas or aspects (e.g. functionally and/or structurally different from each other) of an analogue circuit. However, it will be understood that in some examples not all child blocks 950 of the first design layer need to be coupled in parallel to the parent block of the core design layer. For example, child blocks 1 and 3 of the first design layer may be coupled to the parent block 900 of the core design layer, and child block 2 of the first design layer may be coupled in series to child blocks 1 and 3 of the first design layer respectively.
The grouping of the child blocks 950 may be determined by the parent block 900 of the core design layer. For example, the parent block 900 may be configured to group the child blocks of the first design layer so as to design different aspects (e.g. functionally and/or structurally different from each other) of an analogue circuit. The parent block 900 of the core design layer may be configured to do this based on a determination of requirements from a customer specification.
Beneath the first design layer sits a second design layer. The second design layer comprises tertiary design units or grandchild blocks 1, 2, 3, 4, 5, 6, 7 and 8960. The grandchild blocks 960 are coupled to child blocks of the layer above (the first design layer). Not every child block of the first design layer is coupled to a grandchild block of the second design layer. In the example shown, grandchild blocks 1, 2 and 3 of the second design layer are coupled in parallel to child block 2 of the first design layer. However, as described above for the child blocks 950 of the first design layer, it will be understood that in some examples not all grandchild blocks of the second design layer need to be coupled in parallel to the child block of the first design layer. For example, grandchild blocks 1 and 3 of the second design layer may be coupled to the child block 2 of the first design layer, and grandchild block 2 of the second design layer may be coupled in series to grandchild blocks 1 and 3 of the second design layer respectively.
Beneath the second design layer sits another (nth) design layer. The nth design layer comprises greatgrandchild blocks 1, 2, 3 and 4970 The greatgrandchild blocks 970 are coupled to grandchild blocks 960 of the layer above (the second design layer) in much the same way that the grandchild blocks 960 of the second design layer are coupled to the child blocks 950 of the first design layer. It will therefore be understood that there may a plurality of further design layers sitting below the second design layer each comprising their own blocks coupled to blocks of the layer above.
The structure of the block hierarchy shown in
The parent block 900 (of the core design layer) may be configured to determine the level of complexity a block of a selected layer is configured to design, and/or the blocks of one layer may be configured to determine the level of complexity that the blocks of the layer below are configured to design.
Additionally or alternatively, the structure of the block hierarchy shown in
For example, one layer may comprise blocks configured to design aspects or portions of an analogue circuit based on one functional requirement (e.g. size) and another layer may comprise blocks configured to design another functional requirement (e.g., current or voltage).
In more detail, at step 300 the parent block 900 receives the customer requirements.
The customer requirements may, for example, define the functionality of the circuit and certain limits that will be required from it—such as peak current, voltage etc. The customer requirements may also specify other features such as the PDK/foundry that the circuit will be manufactured by. The parent block 900 is configured to convert 302 the customer requirements into a set of technical criteria. The parent block 900 may additionally or alternatively be configured to determine whether to send these technical criteria to child blocks 950 in parallel, or in series, and/or whether to send different sets of criteria to child blocks 950 of a layer below.
At this stage the parent block 900 may also be configured to determine the number of layers of the model, or alternatively the block of each layer may be configured to determine if blocks of an underlying layer are required when designing portions of the circuit they are tasked with designing by a block in a layer above.
Once the parent block 900 has converted 302 the customer requirements into criteria, it then sends 304 these to the child blocks of the first layer. In the example shown, the parent block 900 sends 304 the technical criteria to child 1, child 2 and child 3 in parallel.
Upon receiving the technical criteria, in this example, child 1 determines 306 that it needs to engage blocks (grandchild blocks 960) of a layer below, and instructs grandchild 1 to design a first portion of the circuit based on the criteria. At the same time, child 2 designs 307 an initial third portion of the circuit based on the technical criteria and child 3 designs 308 an initial fourth portion of the circuit based on the technical criteria.
Grandchild 1 designs 308 the first portion of the circuit based on the technical criteria, and sends 312 this designed first portion back to child 1 which may then forward this on to the parent (optionally after having performed some simulation/verification first). Child 1 then instructs 314 grandchild 2 to design a second portion of the circuit based on the criteria. Grandchild 2 designs 316 the second portion of the circuit based on the criteria and sends 318 this back to child 1 which may then forward this on to the parent.
Once child 1 (via grandchild 1 and grandchild 2) has designed the first and second portions of the circuit, child 1 sends 320 context information to child 2. Child 2 may adapt or adjust the technical criteria received from the parent based on the context information obtained from child 1. Child 2 then adapts the initial designed third portion of the circuit based on the context information received from child 1.
In the example shown in
Once the parent block 900 has received all the designed portions of the circuit, the parent block 900 generates an initial design for the analogue circuit based on the set of designs obtained from the child blocks, and checks or verifies 330 whether the designed initial design for the analogue circuit meets the customer requirements. As noted above, the parent block 900 may do this by employing a verification and simulation module to simulate the performance of the completed circuit. The parent block 900 also obtains information relating to parasitics that will be experienced in the analogue circuit if the analogue circuit were to include all of the designed circuit portions.
In the event that the designed completed circuit does not meet the customer requirements, the parent block may resend 332 adjusted criteria directly to the block responsible for designing the portion of the circuit responsible for the failure to meet requirements with additional information on what needs adjusting (and optionally by which block)—for example the criteria may be adjusted to take into account the additional information for redesigning the block to meet the customer requirements. In some examples, the parent block 900 may only send 332 only a portion of the designed circuit back to the block responsible for designing that portion—for example, the parent block 900 may send the first portion of the analogue circuit back to grandchild 1, for example with information as to what needs adjusting and/or with adjusted criteria.
It will be understood in the above example that the first, second, third and fourth portions of the analogue circuit may be independent portions of the circuit and/or be functionally dependent on each other. In other examples the first, second, third and fourth portions of the analogue circuit may be selected subsets of the analogue circuit. For example, the second portion may comprise portions of the first portion, the third portion comprises portions of the first and second portions, and the fourth portion comprise portions of the first, second and third portions.
While the example shown in
At step 500 the parent block 900 receives the customer requirements. As for the method described above in relation to
The parent block 900 may additionally or alternatively be configured to determine whether to send these criteria to child blocks 950 in parallel, or in series, and/or whether to send different sets of criteria to child blocks 950 of a layer below.
At this stage the parent block 900 may also be configured to determine the number of layers of the model, or alternatively the block of each layer may be configured to determine if blocks of an underlying layer are required when designing portions of the circuit they are tasked with designing by a block in a layer above.
Once the parent block 900 has converted 502 the customer requirements into criteria, it then sends 504 these to child 1 of the first design layer. These criteria may specify how many child blocks 950 of this layer are to be used, and which child block 950 is to be tasked with designing each portion of the analogue circuit.
Upon receiving the criteria, the child 1 designs 506 a first portion of the analogue circuit based on the received criteria. It will be understood that child 1 may be configured to design a first portion of the analogue circuit based on a subset/a first portion of the criteria applicable to it, as determined by the parent block.
Once child 1 has designed the first portion of the analogue circuit, the criteria received from the parent block 900 may dictate that child 1 is to send 508 the designed first portion of the circuit and the criteria on to a second child (child 2) of the same layer. Child 2 may design 510 a second portion of the analogue circuit based on the received criteria, and in some examples may design the second portion of the analogue circuit based on only a subset of the criteria (e.g. only those portions applicable to it) or based on all of the criteria.
Child 2 also adapts the design of the second portion of the analogue circuit based on the context created by the designed first portion of the analogue circuit designed by child 1. In some examples this context may be expressed in the form of an adjusted set of criteria—for example, child 1 and/or the parent block may be configured to adjust the criteria based on the context and/or parasitics provided by the designed first portion of the circuit designed by child 1, although it will be understood that in other examples the context and/or parasitics may be provided in addition to/separately to the criteria. For example, in examples where the parent block comprises a verification and simulator module, the verification and simulation module may simulate the performance of the designed portion or component of the circuit to obtain the context and/or parasitics information. Additionally or alternatively, in examples where each child block comprises a verification and simulator module, the verification and simulation module may simulate the performance of the designed portion or component of the circuit to obtain the context and/or parasitics information.
In some examples, child 2 may determine that it needs to employ blocks of a lower layer to design portions of the circuit that it is tasked with designing, and/or determine whether to employ these blocks of a lower layer in series and/or in parallel. Additionally or alternatively, the criteria received by the child 2 may dictate (for example, as determined by the parent block) that child 2 is to employ blocks of a lower layer to design portions of the circuit that child 2 is tasked with designing (and whether to employ these blocks in series or in parallel). For example, as shown in
Child 2 then sends 514 the designed first portion, the designed second portion and the criteria to child 3. In some examples, the criteria may be modified by a preceding child. For example, the criteria may be modified by child 1 and/or child 2 before being sent to the next child. For example, child 2 may be configured to modify the criteria it sends to child 3 based on the designed first portion of the circuit and/or the designed second portion of the circuit.
Child 3 then designs 516 a third portion of the analogue circuit based on the received criteria and additionally or alternatively the designed first portion and/or the designed second portion of the circuit,
Child 3 then sends 518 the completed circuit to the parent block, and the parent block generates an initial design for the analogue circuit based on the set of respective circuit portion designs, and checks or verifies 520 whether the designed completed circuit meets the customer requirements. As noted above, the parent block may do this by employing a verification and simulation module to simulate the performance of the completed circuit. The parent block 900 also obtains information relating to parasitics that will be experienced in the analogue circuit if the analogue circuit were to include all the designed circuit portions.
If the designed completed circuit does not meet the customer requirements, the parent block may resend 522 the designed completed circuit to child 1 with additional information on what needs adjusting (and optionally by which block). Additionally or alternatively, in the event that the designed completed circuit does not meet the customer requirements, the parent block may send 524 only a portion of the designed circuit back to the block responsible for designing that portion—for example, the parent block may send the second portion of the analogue circuit back to child 2, for example with information as to what needs adjusting and/or with adjusted criteria. Child 2 may then design that portion of the circuit and either send it directly back to the parent block for checking as to whether to meets the customer requirements, or to child 3 which may then redesign the third portion of the circuit based on the redesigned second portion of the circuit (and/or optionally based on the adjusted criteria).
It will be understood in the above example that the first, second, third and fourth portions of the analogue circuit may be independent portions of the circuit and/or be functionally dependent on each other. In other examples the first, second, third and fourth portions of the analogue circuit may be selected subsets of the analogue circuit. For example, the second portion may comprise portions of the first portion, the third portion comprises portions of the first and second portions, and the fourth portion comprise portions of the first, second and third portions.
While the example shown in
The examples shown in
In the designed circuit shown in
As noted above, the analogue circuit design apparatus may make use of a machine learning model to estimate parasitics for any circuit or circuit portion that it has designed.
The machine learning model may comprise a neural network. The neural network may comprise at least one of a deep residual network, a highway network, a densely connected network and a capsule network.
For any such type of network, the network may comprise a plurality of different neurons, which are organised into different layers. Each neuron is configured to receive input data, process this input data and provide output data. Each neuron may be configured to perform a specific operation on its input, e.g. this may involve mathematically processing the input data. The input data for each neuron may comprise an output from a plurality of other preceding neurons. As part of a neuron's operation on input data, each stream of input data (e.g. one stream of input data for each preceding neuron which provides its output to the neuron) is assigned a weighting. That way, processing of input data by a neuron comprises applying weightings to the different streams of input data so that different items of input data will contribute more or less to the overall output of a neuron. Adjustments to the value of the inputs for a neuron; e.g. as a consequence of the input weightings changing, may result in a change to the value of the output for that neuron. The output data from each neuron may be sent to a plurality of subsequent neurons.
The neurons are organised in layers. Each layer comprises a plurality of neurons which operate on data provided to them from the output of neurons in preceding layers. Within each layer there may be a large number of different neurons, each of which applies a different weighting to its input data and performs a different operation on its input data. The input data for all of the neurons in a layer may be the same, and the output from the neurons will be passed to neurons in subsequent layers.
The exact routing between neurons in different layers forms a major difference between capsule networks and deep residual networks (including variants such as highway networks and densely connected networks).
For a residual network, layers may be organised into blocks, such that the network comprises a plurality of blocks, each of which comprises at least one layer. For a residual network, output data from one layer of neurons may follow more than one different path. For conventional neural networks (e.g. convolutional neural networks), output data from one layer is passed into the next layer, and this continues until the end of the network so that each layer receives input from the layer immediately preceding it and provides output to the layer immediately after it. However, for a residual network, a different routing between layers may occur. For example, the output from one layer may be passed on to multiple different subsequent layers, and the input for one layer may be received from multiple different preceding layers.
In a residual network, layers of neurons may be organised into different blocks, wherein each block comprises at least one layer of neurons. Blocks may be arranged with layers stacked together so that the output of a preceding layer (or layers) feeds into the input of the next block of layers. The structure of the residual network may be such that the output from one block (or layer) is passed into both the block (or layer) immediately after it and at least one other later subsequent block (or layer). Shortcuts may be introduced into the neural network which pass data from one layer (or block) to another whilst bypassing other layers (or blocks) in between the two. This may enable more efficient training of the network, e.g. when dealing with very deep networks, as it may enable problems associated with degradation to be addressed when training the network (which is discussed in more detail below). The arrangement of a residual neural network may enable branches to occur such that the same input provided to one layer, or block of layers, is provided to at least one other layer, or block of layers (e.g. so that the other layer may operate on both the input data and the output data from the one layer, or block of layers). This arrangement may enable a deeper penetration into the network when using back propagation algorithms to train the network. For example, this is because during learning, layers, or blocks of layers, may be able to take as an input, the input of a previous layer/block and the output of the previous layer/block, and shortcuts may be used to provide deeper penetration when updating weightings for the network.
For a capsule network, layers may be nested inside of other layers to provide ‘capsules’.
Different capsules may be adapted so that they are more proficient at performing different tasks than other capsules. A capsule network may provide dynamic routing between capsules so that for a given task, the task is allocated to the most competent capsule for processing that task. For example, a capsule network may avoid routing the output from every neuron in a layer to every neuron in the next layer. A lower level capsule is configured to send its input to a higher level (subsequent) capsule which is determined to be the most likely capsule to deal with that input. Capsules may predict the activity of higher layer capsules. For example, a capsule may output a vector, for which the orientation represents properties of an object in question. In response, each subsequent capsule may provide, as an output, a probability that the object that capsule is trained to identify is present in the input data, This information (e.g. the probabilities) can be fed back to the capsule, which can then dynamically determine routing weights, and forward the input data to the subsequent capsule most likely to be the relevant capsule for processing that data.
For either type of neural network, there may be included a plurality of different layers which have different functions. The neural network may include at least one convolutional layer configured to convolve input data across its height and width. The neural network may also have a plurality of filtering layers, each of which comprises a plurality of neurons configured to focus on and apply filters to different portions of the input data. Other layers may be included for processing the input data such as pooling layers (to introduce non-linearity) such as maximum pooling and global average pooling, Rectified Linear Units layer (ReLU) and loss layers, e.g. some of which may include regularization functions. The final block of layers may receive input from the last output layer (or more layers if there are branches present). The final block may comprise at least one fully connected layer.
The final output layer may comprise a classifier, such as a softmax, sigmoid or tanh classifier. Different classifiers may be suitable for different types of output: for example, a sigmoid classifier may be suitable where the output is a binary classifier. The neural network of the present disclosure may be configured to predict binding affinities between the target and test object. In which case, the output may be a prediction of the value for the equilibrium dissociation constant. The output of the neural network may provide an indication of a probability that the target and test object fit. It may provide as an output an indication of whether or not a more detailed analysis of the fit between the target and test object is warranted, such as in a binary form, wherein a first output indicates ‘yes’ and a second output indicates ‘no’. In which case, the network may act as a screen for pulling out a smaller group of compounds for which a more detailed examination is required.
To train the network, e.g. to learn values for the weightings, these weightings are assigned an initial value. These initial values may essentially be random; however, to improve training of the network, a suitable initialisation for the values may be applied such as a Xavier/Glorot initialisation. Such initialisations may inhibit situations from occurring in which initial random weightings are too great or too small, and the neural network can never properly be trained to overcome these initial prejudices. This type of initialisation may comprise assigning weightings using a distribution having a zero mean but a fixed variance.
Once the weightings have been assigned, training object data may be fed or input 710 into the neural network 700. This may comprise operating the neural network on known pairs of designed circuits (and/or circuit portions) and corresponding estimated/simulated and/or known parasitics to output 720 predicted parasitics for the input circuit portion/analogue circui. Based on this information, a backpropagation optimisation method, for example using gradient descent (e.g. stochastic gradient descent) and loss functions is performed on the network to compare 730 the predicted parasitics with expected or known parasitics for that circuit portion/analogue circuit. The expected or known parasitics may have been obtained, for example, using a virtual test bench. Algorithms such as mini-batch gradient descent, RMSprop, Adam, Adadelta and Nesterov may be used during this process. This may enable an identification of how much each different point (neuron) or path (between neurons in subsequent layers) in the network is contributing to determining an incorrect score, thus enabling a determination 740 of any weight adjustments that need to be made. The weightings may then be adjusted 750 according to the error calculated. For example, to minimise or remove the contribution from neurons which contribute, or contribute the most, to an incorrect determination.
After an iteration of training the network with different pairs of designed circuits (and/or circuit portions) and corresponding parasitics, the weightings may be updated 750, and this process may be repeated a large number of times. To inhibit the likelihood of overtraining the network, training variables such as learning rate and momentum may be varied and/or controlled to be at a selected value. Additionally, regularisation techniques such as L2 or dropout may be used which reduce the likelihood of different layers becoming over-trained to be too specific for the training data, without being as generally applicable to other, similar data. Likewise, batch normalisation may be used to aid training and improve accuracy. In general, the weightings are adjusted so that the network would, if operated on the same training image again, produce the expected outcome. Although, the extent to which this is true will be dependent on training variables such as learning rate.
It is to be appreciated that increasing the depth of neural networks may cause problems when training, e.g. due to vanishing gradient problems, and it may also provide slower networks. However, the present disclosure may enable the provision of a network having increased depth and accuracy without sacrificing the ability to adequately train the network.
The depth of the network used may be selected to provide a balance between accuracy and the time taken to provide an output. Increasing the depth of the network may provide increased accuracy although it may also increase the time taken to provide an output. Use of a branched structure (as opposed to in a convolutional neural network) may enable sufficient training of the network to occur as depth of the network increases, which in turn provides for an increased accuracy of the network.
It will be understood in the context of the present disclosure that a non-exhaustive list of example analogue parameters that may form basis of the criteria include: Noise tolerance; Power Supply Rejection Ratio (PSRR); Common Mode Range—Input (Input CMR); Common Mode Range—Output (Output CMR); Linearity; Maximum Offset; Bandwidth; Minimum Slew Rate; Intrinsic Delay; Minimum phase margin; Active Power consumption; Static power consumption; IP3 point; Filter centre-frequency; Filter band-pass range; Load Step response; Line step response; Output Accuracy; Noise figure; Calibration range; Noise floor; SNR; ENOB; SINAD; Output frequency range; Jitter—ptp; Jitter—RMS; Output ripple ptp; Total Harmonic Distortion; Start-up time; Channel isolation; Reference voltage; Gain error; Offset error; Gain drift.
It will also be understood that the design units (such as the primary, secondary and tertiary design units) may be implemented in software or hardware, for example as dedicated circuitry. For example, the design units may be implemented as part of a computer system. The computer system may include a bus or other communication mechanism for communicating information data, signals, and information between various components of the computer system. The components may include an input/output (I/O) component that processes a user (i.e., sender, recipient, service provider) action, such as selecting keys from a keypad/keyboard, selecting one or more buttons or links, etc., and sends a corresponding signal to the bus. The I/O component may also include an output component, such as a display and a cursor control (such as a keyboard, keypad, mouse, etc.). A transceiver or network interface may transmit and receives signals between the computer system and other devices, such as another user device, a merchant server, or a service provider server via a network. In one embodiment, the transmission is wireless, although other transmission mediums and methods may also be suitable. A processor, which can be a micro-controller, digital signal processor (DSP), or other processing component, processes these various signals, such as for display on the computer system or transmission to other devices via a communication link. The processor may also control transmission of information, such as cookies or IP addresses, to other devices.
The components of the computer system may also include a system memory component (e.g., RAM), a static storage component (e.g., ROM), and/or a disk drive (e.g., a solid-state drive, a hard drive). The computer system performs specific operations by the processor and other components by executing one or more sequences of instructions contained in the system memory component.
Logic may be encoded in a computer readable medium, which may refer to any medium that participates in providing instructions to a processor for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. In various implementations, non-volatile media includes optical or magnetic disks, volatile media includes dynamic memory, such as a system memory component, and transmission media includes coaxial cables, copper wire, and fiber optics. In one embodiment, the logic is encoded in non-transitory computer readable medium. In one example, transmission media may take the form of acoustic or light waves, such as those generated during radio wave, optical, and infrared data communications.
Some common forms of computer readable media includes, for example, floppy disk, flexible disk, hard disk, magnetic tape, any other magnetic medium, CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, any other memory chip or cartridge, or any other medium from which a computer is adapted to read.
In various embodiments of the present disclosure, execution of instruction sequences to practice the present disclosure may be performed by a computer system. In various other embodiments of the present disclosure, a plurality of computer systems 600 coupled by a communication link to a network (e.g., such as a LAN, WLAN, PTSN, and/or various other wired or wireless networks, including telecommunications, mobile, and cellular phone networks) may perform instruction sequences to practice the present disclosure in coordination with one another.
It will also be understood that aspects of the present disclosure may be implemented using hardware, software, or combinations of hardware and software. Also, where applicable, the various hardware components and/or software components set forth herein may be combined into composite components comprising software, hardware, and/or both without departing from the spirit of the present disclosure. Where applicable, the various hardware components and/or software components set forth herein may be separated into sub-components comprising software, hardware, or both without departing from the scope of the present disclosure. In addition, where applicable, it is contemplated that software components may be implemented as hardware components and vice-versa.
Software in accordance with the present disclosure, such as program code and/or data, may be stored on one or more computer readable mediums. It is also contemplated that software identified herein may be implemented using one or more general purpose or specific purpose computers and/or computer systems, networked and/or otherwise. Where applicable, the ordering of various steps described herein may be changed, combined into composite steps, and/or separated into sub-steps to provide features described herein.
The various features and steps described herein may be implemented as systems comprising one or more memories storing various information described herein and one or more processors coupled to the one or more memories and a network, wherein the one or more processors are operable to perform steps as described herein, as non-transitory machine-readable medium comprising a plurality of machine-readable instructions which, when executed by one or more processors, are adapted to cause the one or more processors to perform a method comprising steps described herein, and methods performed by one or more devices, such as a hardware processor, user device, server, and other devices described herein.
In the context of the present disclosure other examples and variations of the apparatus and methods described herein will be apparent to a person of skill in the art.
Number | Date | Country | Kind |
---|---|---|---|
2003543.2 | Mar 2020 | GB | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/GB2021/050437 | 2/22/2021 | WO |