このページの翻訳は最新ではありません。ここをクリックして、英語の最新版を参照してください。
クローン検出と置換によるリソース共有の改善
この例では、クローン検出器アプリを使用して、繰り返しパターンを自動的に特定して置き換える方法を示します。結果として、リソース共有を使用してモデルを最適化する機会も向上します。クローン検出器アプリは、設計内のクローンを特定し、そのクローンをライブラリ内のサブシステム ブロックへのリンクに置き換えてモデルをリファクタリングします。この例では、リソース共有が最適になるようにクローン検出器アプリを使用して変更済みのモデルを使用します。これらの変更の詳細については、「設計の変更によるリソース共有の改善」を参照してください。
クローン検出
クローン検出は、カスタム ライブラリ ファイルを使用して入力として指定したいくつかのサンプル パターンを基準に、それに似た設計内のモデリング パターンを特定するために使用できるツールです。クローン検出器アプリは、それらのパターンを特定すると、パターンを Atomic サブシステムに置き換えます。これにより、コードの再利用によって最適なコードを生成できるようになり、Atomic サブシステムでのリソースの共有によってリソースの利用が改善されます。クローン検出の詳細については、クローン検出を使用したコンポーネント再利用の有効化 (Simulink Check)を参照してください。
リソース共有用のモデルの設定
この編集後のモデルは hdlcoderParkTransformShare.slx という名前で保存されています。次のコマンドを使用して、このバージョンのモデルを一時ディレクトリにコピーします。
design_name = 'hdlcoderParkTransformShare'; design_new_name = 'hdlcoderParkTransformShareCopy'; copyfile(fullfile([design_name,'.slx']), fullfile([design_new_name,'.slx']), 'f'); % Open the model. open_system(design_new_name);
対象のサブシステムで SharingFactor を 6 に設定し、モデルから対応するレポートと共に HDL を生成します。
subsystem = [design_new_name '/DUT']; hdlset_param(subsystem, 'SharingFactor', 6); makehdl(subsystem);
### Generating HDL for 'hdlcoderParkTransformShareCopy/DUT'. ### Using the config set for model <a href="matlab:configset.showParameterGroup('hdlcoderParkTransformShareCopy', { 'HDL Code Generation' } )">hdlcoderParkTransformShareCopy</a> for HDL code generation parameters. ### Running HDL checks on the model 'hdlcoderParkTransformShareCopy'. ### Begin compilation of the model 'hdlcoderParkTransformShareCopy'... ### Applying HDL optimizations on the model 'hdlcoderParkTransformShareCopy'... ### <a href="matlab:configset.internal.open('hdlcoderParkTransformShareCopy','LUTMapToRAM')">'LUTMapToRAM'</a> is set to 'On' for the model. This option is used to map lookup tables to a block RAM in hardware. To disable pipeline insertion for mapping lookup tables to RAM, please set the option to 'Off'. ### The DUT requires an initial pipeline setup latency. Each output port experiences these additional delays. ### Output port 1: 39 cycles. ### Output port 2: 39 cycles. ### Working on... <a href="matlab:configset.internal.open('hdlcoderParkTransformShareCopy', 'GenerateModel')">GenerateModel</a> ### Begin model generation. ### Model generation complete. ### Generating new validation model: <a href="matlab:open_system('hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/gm_hdlcoderParkTransformShareCopy_vnl')">gm_hdlcoderParkTransformShareCopy_vnl</a>. ### Validation model generation complete. ### Begin VHDL Code Generation for 'hdlcoderParkTransformShareCopy'. ### MESSAGE: The design requires 6 times faster clock with respect to the base rate = 6. ### Begin VHDL Code Generation for 'DUT_tc'. ### Working on DUT_tc as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT_tc.vhd. ### Code Generation for 'DUT_tc' completed. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_sincos_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_sincos_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_sub_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_sub_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_mul_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_mul_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_add_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_add_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_mul_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_mul_single_block.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_uminus_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_uminus_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT.vhd. ### Generating package file hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT_pkg.vhd. ### Code Generation for 'hdlcoderParkTransformShareCopy' completed. ### Generating HTML files for code generation report at <a href="matlab:web('/tmp/Bdoc22b_2039835_1060685/tp5e8b7d68/hdlcoder-ex46534583/hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/html/hdlcoderParkTransformShareCopy_codegen_rpt.html')">hdlcoderParkTransformShareCopy_codegen_rpt.html</a> ### Creating HDL Code Generation Check Report file:///tmp/Bdoc22b_2039835_1060685/tp5e8b7d68/hdlcoder-ex46534583/hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT_report.html ### HDL check for 'hdlcoderParkTransformShareCopy' complete with 0 errors, 1 warnings, and 2 messages. ### HDL code generation complete.
高水準リソース レポートには、設計のリソース利用の推定結果が次のように表示されます。
Resource Usage _________________________ ________ Multipliers 13 Adders/Subtractors 178 Registers 1012 Total 1-Bit Registers 16888 RAMs 0 Multiplexers 610 I/O Bits 196 Static Shift operators 8 Dynamic Shift operators 8
モデルで合成ワークフローを実行することもできます。このモデルの合成結果は次のようになります。
Resource Usage _________________________ ________ Slice LUTs 8792 Slice Registers 8419 DSPs 13 Block Ram Tile 0 URAM 0
合成ワークフローの詳細については、Simulink モデルからの HDL コード生成と FPGA 合成を参照してください。
クローン検出を使用したリソース共有用のモデルの最適化
クローン検出器アプリを使用する前に、モデル内の各繰り返しパターンを Atomic サブシステムとして格納するカスタム ライブラリを作成します。この例では、hdlcoderParkTransformShareLib.slx という名前のカスタム ライブラリが用意されています。
% Copy the library into the temporary directory lib_name = 'hdlcoderParkTransformShareLib'; lib_new_name = 'hdlcoderParkTransformShareLibCopy'; copyfile(([lib_name,'.slx']), fullfile([lib_new_name,'.slx']), 'f'); % Open the custom library open_system('hdlcoderParkTransformShareLibCopy');
モデルのパターンを Atomic サブシステムを含むライブラリに置き換えます。クローン検出器アプリの設定方法とクローンの置き換え方法については、クローン検出を使用したコンポーネント再利用の有効化 (Simulink Check)を参照してください。具体的には、「クローン検出のためのパラメーターの設定」の節の手順に従って、クローン検出用のライブラリをリンクし、[異なるパラメーターの最大数] の値を 0
に設定します。
その後、「クローンの置換」の節に従って、このライブラリを厳密クローンの置換用のモデルに適用します。
以下に示すように、元のモデル内のすべてのパターンがライブラリの Atomic サブシステムに置き換えられます。
このシステムに対する変更を保存します。Simulink エディターの [シミュレーション] タブで、[保存] をクリックします。
最適化されたモデルの結果の比較
このモデルには Atomic サブシステムの内部に Sin、Cos、および Product のブロックが含まれているため、それらを共有してリソース利用を改善できます。
subsystem = [design_new_name '/DUT']; hdlset_param(subsystem, 'SharingFactor', 3); % Generate HDL code and the corresponding reports for the optimized model makehdl(subsystem);
### Generating HDL for 'hdlcoderParkTransformShareCopy/DUT'. ### Using the config set for model <a href="matlab:configset.showParameterGroup('hdlcoderParkTransformShareCopy', { 'HDL Code Generation' } )">hdlcoderParkTransformShareCopy</a> for HDL code generation parameters. ### Running HDL checks on the model 'hdlcoderParkTransformShareCopy'. ### Begin compilation of the model 'hdlcoderParkTransformShareCopy'... ### Applying HDL optimizations on the model 'hdlcoderParkTransformShareCopy'... ### <a href="matlab:configset.internal.open('hdlcoderParkTransformShareCopy','LUTMapToRAM')">'LUTMapToRAM'</a> is set to 'On' for the model. This option is used to map lookup tables to a block RAM in hardware. To disable pipeline insertion for mapping lookup tables to RAM, please set the option to 'Off'. ### The DUT requires an initial pipeline setup latency. Each output port experiences these additional delays. ### Output port 1: 33 cycles. ### Output port 2: 33 cycles. ### Working on... <a href="matlab:configset.internal.open('hdlcoderParkTransformShareCopy', 'GenerateModel')">GenerateModel</a> ### Begin model generation. ### Model generation complete. ### Generating new validation model: <a href="matlab:open_system('hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/gm_hdlcoderParkTransformShareCopy_vnl')">gm_hdlcoderParkTransformShareCopy_vnl</a>. ### Validation model generation complete. ### Begin VHDL Code Generation for 'hdlcoderParkTransformShareCopy'. ### MESSAGE: The design requires 3 times faster clock with respect to the base rate = 6. ### Begin VHDL Code Generation for 'DUT_tc'. ### Working on DUT_tc as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT_tc.vhd. ### Code Generation for 'DUT_tc' completed. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_sincos_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_sincos_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_sub_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_sub_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_mul_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_mul_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_add_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_add_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT/nfp_uminus_single as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/nfp_uminus_single.vhd. ### Working on hdlcoderParkTransformShareCopy/DUT as hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT.vhd. ### Generating package file hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT_pkg.vhd. ### Code Generation for 'hdlcoderParkTransformShareCopy' completed. ### Generating HTML files for code generation report at <a href="matlab:web('/tmp/Bdoc22b_2039835_1060685/tp5e8b7d68/hdlcoder-ex46534583/hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/html/hdlcoderParkTransformShareCopy_codegen_rpt.html')">hdlcoderParkTransformShareCopy_codegen_rpt.html</a> ### Creating HDL Code Generation Check Report file:///tmp/Bdoc22b_2039835_1060685/tp5e8b7d68/hdlcoder-ex46534583/hdl_prj/hdlsrc/hdlcoderParkTransformShareCopy/DUT_report.html ### HDL check for 'hdlcoderParkTransformShareCopy' complete with 0 errors, 1 warnings, and 2 messages. ### HDL code generation complete.
共有後の高水準リソース レポートには、設計のリソース利用の推定結果が次のように表示されます。
Resource Usage _________________________ ________ Multipliers 13 Adders/Subtractors 177 Registers 1004 Total 1-Bit Registers 16657 RAMs 0 Multiplexers 610 I/O Bits 196 Static Shift operators 8 Dynamic Shift operators 8
Atomic サブシステムの共有後に [加算器/減算器]、[レジスタ]、および [1 ビット レジスタの合計] の数が少なくなったことがわかります。
モデルで合成ワークフローを実行することもできます。このモデルの合成結果は次のようになります。
Resource Usage _________________________ ________ Slice LUTs 8848 Slice Registers 8308 DSPs 13 Block Ram Tile 0 URAM 0
共有後に [Slice Registers] の数が少なくなったことがわかります。