Export Verilog-A Model
Represent Circuit Object with Model Object
Before you can write a Verilog-A model of an RF circuit object, you need to create
an rfmodel.rational object to represent the component.
There are two ways to create an RF model object:
You can fit a rational function model to the component data using the
rationalfitfunction.You can use the
rfmodel.rationalconstructor to specify the pole-residue representation of the component directly.
This section discusses using a rational function model. For more information on
using the constructor, see the rfmodel.rational reference page.
When you use the rationalfit function to create an rfmodel.rational object that represents an RF component, the arguments
you specify affect how quickly the resulting Verilog-A model runs in a circuit
simulator.
You can use the rationalfit function with only the two
required arguments. The syntax is:
model_obj = rationalfit(freq,data)
where
model_objis a handle to the rational function model object.freqis a vector of frequency values that correspond to the data values.datais a vector that contains the data to fit.
For faster simulation, create a model object with the smallest number of poles required to accurately represent the component. To control the number of poles, use the syntax:
model_obj = rationalfit(freq,data,tol,weight,delayfactor)
where
tol— the relative error-fitting tolerance, in decibels. Specify the largest acceptable tolerance for your application. Using tighter tolerance values may force therationalfitfunction to add more poles to the model to achieve a better fit.weight— a vector that specifies the weighting of the fit at each frequency.delayfactor— a value that controls the amount of delay used to fit the data. Delay introduces a phase shift in the frequency domain that may require a large number of poles to fit using a rational function model. When you specify the delay factor, therationalfitfunction represents the delay as an exponential phase shift. This phase shift allows the function to fit the data using fewer poles.
For more information, see rationalfit.
Note
You can also specify the number of poles directly using the
npoles argument. The model accuracy is not guaranteed
with approach, so you should not specify npoles when accuracy
is critical. For more information on the npoles argument, see
the rationalfit reference page.
If you plan to integrate the Verilog-A module into a large design for simulation using detailed models, such as transistor-level circuit models, the simulation time consumed by a Verilog-A module may have a trivial impact on the overall simulation time. In this case, there is no reason to take the time to optimize the rational function model of the component.
For more information on the rationalfit function arguments,
see the rationalfit reference page.
Write Verilog-A Module
You use the writeva method to create a Verilog-A
module that describes the RF model object. This method writes the module to a
specified file. Use the syntax:
status = writeva(model_obj,'obj1',{'inp','inn'},{'outp','outn'})to write a Verilog-A module for the model object
model_obj to the file obj1.va. The
module has differential input nets, inp and
inn, and differential output nets,
outp and outn. The method
returns status, a logical value of true if the
operation is successful and false otherwise.
The write reference page describes the
method arguments in detail.
An example of exporting a Verilog-A module appears in the RF Toolbox™ example, Export Verilog-A module from Rational Function.