hdlcoder.OptimizationConfig Class
Namespace: hdlcoder
hdlcoder.optimizeDesign
configuration object
Description
Use the hdlcoder.OptimizationConfig
object to set options for the
hdlcoder.optimizeDesign
function.
Maximum Clock Frequency Configuration
To configure hdlcoder.optimizeDesign
to maximize the clock
frequency of your design:
Set
ExplorationMode
tohdlcoder.OptimizationConfig.ExplorationMode.BestFrequency
.Set
ResumptionPoint
to the default,''
.
You can optionally set IterationLimit
and
TimingStrategy
to nondefault values. HDL Coder™ ignores the TargetFrequency
setting.
Target Clock Frequency Configuration
To configure hdlcoder.optimizeDesign
to meet a target clock frequency:
Set
ExplorationMode
tohdlcoder.OptimizationConfig.ExplorationMode.TargetFrequency
.Set
TargetFrequency
to your target clock frequency.Set
ResumptionPoint
to the default,''
.
You can optionally set IterationLimit
and
TimingStrategy
to nondefault values.
Resume From Interruption Configuration
To configure hdlcoder.optimizeDesign
to resume after an
interruption, specify ResumptionPoint
.
When you set ResumptionPoint
to a nondefault value, the other
properties are ignored.
Creation
creates an optimcfg
=
hdlcoder.OptimizationConfighdlcoder.OptimizationConfig
object for automatic iterative HDL
design optimization.
Properties
ExplorationMode
— Optimization target mode
hdlcoder.OptimizationConfig.ExplorationMode.BestFrequency
(default) | hdlcoder.OptimizationConfig.ExplorationMode.TargetFrequency
Optimization target mode, specified as one of these values:
hdlcoder.OptimizationConfig.ExplorationMode.BestFrequency | Optimizes the design to try to achieve the maximum clock frequency |
hdlcoder.OptimizationConfig.ExplorationMode.BestFrequency
is the default. | |
hdlcoder.OptimizationConfig.ExplorationMode.TargetFrequency | Optimizes the design to try to achieve the specified target clock frequency |
IterationLimit
— Maximum number of iterations
1 (default) | positive integer
Maximum number of optimization iterations before exiting, specified as a positive integer.
If ExplorationMode
is
hdlcoder.OptimizationConfig.ExplorationMode.BestFrequency
,
HDL Coder runs this number of iterations.
If ExplorationMode
is
hdlcoder.OptimizationConfig.ExplorationMode.TargetFrequency
,
HDL Coder runs the number of iterations
needed to meet the target frequency.
Otherwise, the coder runs the maximum number of iterations.
ResumptionPoint
— Folder containing optimization data from earlier iteration
''
(default) | character vector
Name of folder that contains previously-generated optimization iteration
data, specified as a character vector. The folder is a subfolder of
hdlexpl
, and the folder name begins with the
character vector, Iter
.
When you set ResumptionPoint
to a nondefault value,
hdlcoder.optimizeDesign
ignores the other
configuration object properties.
Example: 'Iter1-26-Sep-2013-10-19-13'
TargetFrequency
— Target clock frequency
Inf
(default) | double
Target clock frequency, specified as a double in MHz. Specify when
ExplorationMode
is
hdlcoder.OptimizationConfig.ExplorationMode.TargetFrequency
.
TimingStrategy
— Timing strategy used to calculate the critical path
'Synthesis'
(default) | 'CriticalPathEstimation'
Timing strategy used to calculate the estimated or actual critical path of
your design during automatic iterative HDL design optimization. The timing
strategy can be set to either Synthesis
or
CriticalPathEstimation
.
Synthesis | Uses synthesis as the timing strategy to determine
the actual critical path of your design. Using
Synthesis as your timing strategy
can cause a long run time for
hdlcoder.OptimizeDesign .
|
CriticalPathEstimation | Use critical path estimation as the timing strategy
to determine the estimated critical path of your design.
Critical path estimation does not run synthesis nor does
it generate HDL code, which significantly shortens the
runtime of hdlcoder.OptimizeDesign ,
while still maintaining optimization accuracy for
calculating the critical path. |
Examples
Configure hdlcoder.optimizeDesign for Maximum Clock Frequency
Open the model and specify the DUT subsystem.
model = 'sfir_fixed'; dutSubsys = 'symmetric_fir'; open_system(model); hdlset_param(model,'HDLSubsystem',[model,'/',dutSubsys]);
Set your synthesis tool and target device options.
hdlset_param(model,'SynthesisTool','Xilinx Vivado', ... 'SynthesisToolChipFamily','Zynq', ... 'SynthesisToolDeviceName','xc7z030', ... 'SynthesisToolPackageName','fbg484', ... 'SynthesisToolSpeedValue','-3')
Enable HDL test bench generation.
hdlset_param(model,'GenerateHDLTestBench','on');
Save your model.
You must save your model if you want to regenerate code later
without rerunning the iterative optimizations, or resume your run
if it is interrupted. When you use hdlcoder.optimizeDesign
to
regenerate code or resume an interrupted run, HDL Coder checks
the model checksum and generates an error if the model has changed.
Create an optimization configuration object, oc
.
oc = hdlcoder.OptimizationConfig;
Set the iteration limit to 10.
oc.IterationLimit = 10;
Optimize the model.
hdlcoder.optimizeDesign(model,oc)
hdlset_param('sfir_fixed', 'HDLSubsystem', 'sfir_fixed/symmetric_fir'); hdlset_param('sfir_fixed', 'SynthesisTool', 'Xilinx Vivado'); hdlset_param('sfir_fixed', 'SynthesisToolChipFamily', 'Zynq'); hdlset_param('sfir_fixed', 'SynthesisToolDeviceName', 'xc7z030'); hdlset_param('sfir_fixed', 'SynthesisToolPackageName', 'fbg484'); hdlset_param('sfir_fixed', 'SynthesisToolSpeedValue', '-3'); Iteration 0 Generate and synthesize HDL code ... (CP ns) 16.26 (Constraint ns) 5.85 (Elapsed s) 143.66 Iteration 1 Generate and synthesize HDL code ... (CP ns) 16.26 (Constraint ns) 5.85 (Elapsed s) 278.72 Iteration 2 Generate and synthesize HDL code ... (CP ns) 10.25 (Constraint ns) 12.73 (Elapsed s) 427.22 Iteration 3 Generate and synthesize HDL code ... (CP ns) 9.55 (Constraint ns) 9.73 (Elapsed s) 584.37 Iteration 4 Generate and synthesize HDL code ... (CP ns) 9.55 (Constraint ns) 9.38 (Elapsed s) 741.04 Iteration 5 Generate and synthesize HDL code ... Exiting because critical path cannot be further improved. Summary report: summary.html Achieved Critical Path (CP) Latency : 9.55 ns Elapsed : 741.04 s Iteration 0: (CP ns) 16.26 (Constraint ns) 5.85 (Elapsed s) 143.66 Iteration 1: (CP ns) 16.26 (Constraint ns) 5.85 (Elapsed s) 278.72 Iteration 2: (CP ns) 10.25 (Constraint ns) 12.73 (Elapsed s) 427.22 Iteration 3: (CP ns) 9.55 (Constraint ns) 9.73 (Elapsed s) 584.37 Iteration 4: (CP ns) 9.55 (Constraint ns) 9.38 (Elapsed s) 741.04 Final results are saved in /tmp/hdlsrc/sfir_fixed/hdlexpl/Final-07-Jan-2014-17-04-41 Validation model: gm_sfir_fixed_vnl
Then HDL Coder stops after five iterations because the fourth and fifth iterations had the same critical path, which indicates that the coder has found the minimum critical path. The design’s maximum clock frequency after optimization is 1 / 9.55 ns, or 104.71 MHz.
Configure hdlcoder.optimizeDesign for Target Clock Frequency
Open the model and specify the DUT subsystem.
model = 'sfir_fixed'; dutSubsys = 'symmetric_fir'; open_system(model); hdlset_param(model,'HDLSubsystem',[model,'/',dutSubsys]);
Set your synthesis tool and target device options.
hdlset_param(model,'SynthesisTool','Xilinx Vivado', ... 'SynthesisToolChipFamily','Zynq', ... 'SynthesisToolDeviceName','xc7z030', ... 'SynthesisToolPackageName','fbg484', ... 'SynthesisToolSpeedValue','-3')
Disable HDL test bench generation.
hdlset_param(model,'GenerateHDLTestBench','off');
Save your model.
You must save your model if you want to regenerate code later
without rerunning the iterative optimizations, or resume your run
if it is interrupted. When you use hdlcoder.optimizeDesign
to
regenerate code or resume an interrupted run, HDL Coder checks
the model checksum and generates an error if the model has changed.
Create an optimization configuration object, oc
.
oc = hdlcoder.OptimizationConfig;
Configure the automatic iterative optimization to stop after it reaches a clock frequency of 50MHz, or 10 iterations, whichever comes first.
oc.ExplorationMode = ...
hdlcoder.OptimizationConfig.ExplorationMode.TargetFrequency;
oc.TargetFrequency = 50;
oc.IterationLimit = 10;
Optimize the model.
hdlcoder.optimizeDesign(model,oc)
hdlset_param('sfir_fixed','GenerateHDLTestBench','off'); hdlset_param('sfir_fixed','HDLSubsystem','sfir_fixed/symmetric_fir'); hdlset_param('sfir_fixed','SynthesisTool','Xilinx Vivado'); hdlset_param('sfir_fixed','SynthesisToolChipFamily','Zynq'); hdlset_param('sfir_fixed','SynthesisToolDeviceName','xc7z030'); hdlset_param('sfir_fixed','SynthesisToolPackageName','fbg484'); hdlset_param('sfir_fixed','SynthesisToolSpeedValue','-3'); Iteration 0 Generate and synthesize HDL code ... (CP ns) 16.26 (Constraint ns) 20.00 (Elapsed s) 134.02 Iteration 1 Generate and synthesize HDL code ... Exiting because constraint (20.00 ns) has been met (16.26 ns). Summary report: summary.html Achieved Critical Path (CP) Latency : 16.26 ns Elapsed : 134.02 s Iteration 0: (CP ns) 16.26 (Constraint ns) 20.00 (Elapsed s) 134.02 Final results are saved in /tmp/hdlsrc/sfir_fixed/hdlexpl/Final-07-Jan-2014-17-07-14 Validation model: gm_sfir_fixed_vnl
Then HDL Coder stops after one iteration because it has achieved the target clock frequency. The critical path is 16.26 ns, a clock frequency of 61.50 GHz.
Configure hdlcoder.optimizeDesign to Resume from Interruption
Open the model and specify the DUT subsystem.
model = 'sfir_fixed'; dutSubsys = 'symmetric_fir'; open_system(model); hdlset_param(model,'HDLSubsystem',[model,'/',dutSubsys]);
Set your synthesis tool and target device options to the same values as in the interrupted run.
hdlset_param(model,'SynthesisTool','Xilinx Vivado', ... 'SynthesisToolChipFamily','Zynq', ... 'SynthesisToolDeviceName','xc7z030', ... 'SynthesisToolPackageName','fbg484', ... 'SynthesisToolSpeedValue','-3')
Enable HDL test bench generation.
hdlset_param(model,'GenerateHDLTestBench','on');
Create an optimization configuration object, oc
.
oc = hdlcoder.OptimizationConfig;
Configure the automatic iterative optimization to run using data from the first iteration of a previous run.
oc.ResumptionPoint = 'Iter5-07-Jan-2014-17-04-29';
Optimize the model.
hdlcoder.optimizeDesign(model,oc)
hdlset_param('sfir_fixed','HDLSubsystem','sfir_fixed/symmetric_fir'); hdlset_param('sfir_fixed','SynthesisTool','Xilinx Vivado'); hdlset_param('sfir_fixed','SynthesisToolChipFamily','Zynq'); hdlset_param('sfir_fixed','SynthesisToolDeviceName','xc7z030'); hdlset_param('sfir_fixed','SynthesisToolPackageName','fbg484'); hdlset_param('sfir_fixed','SynthesisToolSpeedValue','-3'); Try to resume from resumption point: Iter5-07-Jan-2014-17-04-29 Iteration 5 Generate and synthesize HDL code ... Exiting because critical path cannot be further improved. Summary report: summary.html Achieved Critical Path (CP) Latency : 9.55 ns Elapsed : 741.04 s Iteration 0: (CP ns) 16.26 (Constraint ns) 5.85 (Elapsed s) 143.66 Iteration 1: (CP ns) 16.26 (Constraint ns) 5.85 (Elapsed s) 278.72 Iteration 2: (CP ns) 10.25 (Constraint ns) 12.73 (Elapsed s) 427.22 Iteration 3: (CP ns) 9.55 (Constraint ns) 9.73 (Elapsed s) 584.37 Iteration 4: (CP ns) 9.55 (Constraint ns) 9.38 (Elapsed s) 741.04 Final results are saved in /tmp/hdlsrc/sfir_fixed/hdlexpl/Final-07-Jan-2014-17-07-30 Validation model: gm_sfir_fixed_vnl
Then coder stops after one additional iteration because it has achieved the target clock frequency. The critical path is 9.55 ns, or a clock frequency of 104.71 MHz.
Configure hdlcoder.optimizeDesign for Critical Path Estimation
Use CriticalPathEstimation
as the
TimingStrategy
for the optimization configuration object
to shorten the run time for hdlcoder.optimizeDesign
.
Open the model and specify the DUT subsystem.
model = 'sfir_fixed'; dutSubsys = 'symmetric_fir'; open_system(model); hdlset_param(model,'HDLSubsystem',[model,'/',dutSubsys]);
Set your synthesis tool and target device options.
hdlset_param(model,'SynthesisTool','Xilinx Vivado', ... 'SynthesisToolChipFamily','Zynq', ... 'SynthesisToolDeviceName','xc7z030', ... 'SynthesisToolPackageName','fbg484', ... 'SynthesisToolSpeedValue','-1')
Create an optimization configuration object oc
.
oc = hdlcoder.OptimizationConfig;
Set the iteration limit to 10.
oc.IterationLimit = 10;
Set the timing strategy to CriticalPathEstimation
.
oc.TimingStrategy = 'CriticalPathEstimation';
Optimize the model by using critical path estimation as the timing strategy.
hdlcoder.optimizeDesign(model,oc)
%% Set Model 'sfir_fixed' HDL parameters hdlset_param('sfir_fixed', 'HDLSubsystem', 'sfir_fixed/symmetric_fir'); hdlset_param('sfir_fixed', 'SynthesisTool', 'Xilinx Vivado'); hdlset_param('sfir_fixed', 'SynthesisToolChipFamily', 'Zynq'); hdlset_param('sfir_fixed', 'SynthesisToolDeviceName', 'xc7z030'); hdlset_param('sfir_fixed', 'SynthesisToolPackageName', 'fbg484'); hdlset_param('sfir_fixed', 'SynthesisToolSpeedValue', '-1'); Iteration 0 Generate and synthesize HDL code ... ... (CP ns) 9.94 (Constraint ns) 5.46 (Elapsed s) 4.80 Iteration 9 Generate and synthesize HDL code ... Exiting because critical path cannot be further improved. Summary report: summary.html Achieved Critical Path (CP) Latency : 6.21 ns Elapsed : 31.33 s Iteration 0: (CP ns) 9.94 (Constraint ns) 5.46 (Elapsed s) 4.80 Iteration 1: (CP ns) 8.81 (Constraint ns) 5.46 (Elapsed s) 7.90 Iteration 2: (CP ns) 8.77 (Constraint ns) 7.14 (Elapsed s) 11.14 Iteration 3: (CP ns) 7.34 (Constraint ns) 7.14 (Elapsed s) 14.74 Iteration 4: (CP ns) 7.34 (Constraint ns) 7.14 (Elapsed s) 17.99 Iteration 5: (CP ns) 7.34 (Constraint ns) 7.14 (Elapsed s) 21.25 Iteration 6: (CP ns) 7.34 (Constraint ns) 7.14 (Elapsed s) 24.75 Iteration 7: (CP ns) 6.21 (Constraint ns) 7.14 (Elapsed s) 27.95 Iteration 8: (CP ns) 6.21 (Constraint ns) 5.96 (Elapsed s) 31.33
For comparison to the previous results, set the timing strategy to
Synthesis
(its default) and optimize the model by using
hdlcoder.optimizeDesign
.
oc.TimingStrategy = 'Synthesis';
hdlcoder.optimizeDesign(model,oc)
%% Set Model 'sfir_fixed' HDL parameters hdlset_param('sfir_fixed', 'HDLSubsystem', 'sfir_fixed/symmetric_fir'); hdlset_param('sfir_fixed', 'SynthesisTool', 'Xilinx Vivado'); hdlset_param('sfir_fixed', 'SynthesisToolChipFamily', 'Zynq'); hdlset_param('sfir_fixed', 'SynthesisToolDeviceName', 'xc7z030'); hdlset_param('sfir_fixed', 'SynthesisToolPackageName', 'fbg484'); hdlset_param('sfir_fixed', 'SynthesisToolSpeedValue', '-1'); Iteration 0 Generate and synthesize HDL code ... (CP ns) 9.74 (Constraint ns) 5.21 (Elapsed s) 252.66 Iteration 3 Generate and synthesize HDL code ... Exiting because critical path cannot be further improved. Summary report: summary.html Achieved Critical Path (CP) Latency : 5.49 ns Elapsed : 704.51 s Iteration 0: (CP ns) 9.74 (Constraint ns) 5.21 (Elapsed s) 252.66 Iteration 1: (CP ns) 9.74 (Constraint ns) 5.21 (Elapsed s) 479.88 Iteration 2: (CP ns) 5.49 (Constraint ns) 7.95 (Elapsed s) 704.51
Synthesis Timing Strategy | Critical Path Estimation Timing Strategy | |
---|---|---|
Total elapsed time, in seconds | 704.51 | 31.33 |
When you use CriticalPathEstimation
as the
TimingStrategy
, the time to run
hdlcoder.optimizeDesign
is shorter.
The critical path calculated by using CriticalPathEstimation
as the
TimingStrategy
is the estimated critical path delay of the
optimized model. The critical path calculated by using Synthesis
as
the TimingStrategy
is the actual critical path delay of the optimized
model.
Version History
Introduced in R2014a
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)