Main Content

このページの内容は最新ではありません。最新版の英語を参照するには、ここをクリックします。

coder.mapping.api.CodeMapping

C コード生成用のモデル データおよび関数インターフェイスの構成

R2020b 以降

    説明

    コード マッピング オブジェクトおよび関連する関数を使用すると、Simulink® モデルのデータの C コード生成を構成できます。モデル データ要素について、コード マッピングは、データ要素をストレージ クラスとストレージ クラス プロパティから成る構成に関連付けます。モデル全体のデータ要素のカテゴリに対して既定の構成を指定することにより、C コード生成用にモデルを準備する作業を軽減します。データ要素を個別に構成することにより、既定の構成をオーバーライドします。小規模なモデルでは、各データ要素を個別に構成することを選択できます。

    作成

    Simulink エディターの [アプリ] タブから [Simulink Coder] アプリや [Embedded Coder] アプリなどのコード生成アプリを選択すると、コード マッピングがまだ存在しない場合は coder.mapping.api.CodeMapping オブジェクトが作成されます。コード マッピングは、モデルのアクティブなコンフィギュレーション セット オブジェクトに格納されているコードのカスタマイズ設定に基づいて作成されます。コンフィギュレーション セット オブジェクトでは、データと関数に対してメモリ セクションを指定できます。

    coder.mapping.api.CodeMapping オブジェクトをプログラムで作成するには、関数 coder.mapping.utils.create を呼び出します。

    オブジェクト関数

    addSignalブロックの出力信号をモデル コード マッピングに追加する
    coder.mapping.api.getモデルのコード マッピングの取得
    coder.mapping.utils.createC および C++ コード生成用にデータおよび関数インターフェイスを構成するためのコード マッピング オブジェクトを作成する
    findモデル コード マッピングのカテゴリに対するモデル要素の取得
    getDataDefaultモデルのデータ カテゴリに対する既定のストレージ クラスまたはストレージ クラス プロパティ設定の取得
    getDataStoreローカルまたは共有のローカル データ ストアに対するコード マッピングからのコードおよびキャリブレーションの構成の取得
    getInportルートレベルの Inport に対するコード マッピングからのコードおよびキャリブレーション構成の取得
    getModelParameterモデル パラメーターに対するコード マッピングからのコードおよびキャリブレーション構成の取得
    getOutportルートレベルの Outport に対するコード マッピングからのコードおよびキャリブレーション構成の取得
    getSignalブロックの出力信号に対するコード マッピングからのコードおよびキャリブレーション構成の取得
    getStateブロックの状態に対するコード マッピングからのコードおよびキャリブレーション構成の取得
    removeSignalブロックの出力信号をモデル コード マッピングから削除する
    setDataDefaultモデル データ カテゴリの既定のストレージ クラスとストレージ クラス プロパティの値を設定する
    setDataStoreコード生成とキャリブレーション ファイル (a2l) 生成用のローカル データ ストアまたは共有ローカル データ ストアを設定する
    setInportコードとキャリブレーション ファイル (a2l) の生成用のルートレベルの Inport の構成
    setModelParameterコード生成とキャリブレーション ファイル (a2l) 生成用のモデル パラメーターを設定する
    setOutportコード生成とキャリブレーション ファイル (a2l) 生成用にルートレベルの Outport を設定する
    setSignalコード生成とキャリブレーション ファイル (a2l) 生成用のブロック信号データを設定する
    setStateコードとキャリブレーション ファイル (a2l) の生成用のブロック状態の設定

    すべて折りたたむ

    プログラム インターフェイスを使用して、Simulink モデルのコード マッピング オブジェクトを作成および使用します。

    モデル NoCoderMapping を読み込みます。

    simulinkModel = "NoCoderMapping";
    load_system(simulinkModel);

    try-catch ブロックを使用して、モデル用にコード マッピング オブジェクトが存在するかどうかを判別します。try ブロック内で、関数 coder.mapping.api.get を使用して既存のオブジェクトの取得を試みます。catch ブロック内で、関数 coder.mapping.utils.create を使用して新しいコード マッピング オブジェクトを作成します。コード マッピング オブジェクトを変数 codeMapObj に保存します。

    モデルに既存のコード マッピング オブジェクトがあったかどうかを示す出力メッセージを追加します。

    try
      codeMapObj = coder.mapping.api.get(simulinkModel);
              fprintf("" + ...
                " ========================================================\n" + ...
                " The model already had code mappings.\n" + ...
                " ========================================================\n");
    catch
              fprintf("" + ...
                " ==========================================\n" + ...
                " The model does not have code mappings.\n" + ...
                " Creating new code mappings for the model.\n" + ...
                " ==========================================\n");
      codeMapObj = coder.mapping.utils.create(simulinkModel);
    end
     ==========================================
     The model does not have code mappings.
     Creating new code mappings for the model.
     ==========================================
    

    モデルの入力端子 inport_1 のストレージ クラスを取得します。

    getInport(codeMapObj,"inport_1","StorageClass")
    ans = 
    'Auto'
    

    入力端子 inport_1 のストレージ クラスを ExportedGlobal に設定します。

    setInport(codeMapObj,"inport_1",StorageClass="ExportedGlobal")

    同じ try-catch ブロックを使用して、関数 coder.mapping.api.get でモデルの既存のコード マッピングをどのように取得できるようになったかを確認します。

    try
      codeMapObj = coder.mapping.api.get(simulinkModel);
              fprintf("" + ...
                " ========================================================\n" + ...
                " The model already had code mappings.\n" + ...
                " ========================================================\n");
    catch
              fprintf("" + ...
                " ==========================================\n" + ...
                " The model does not have code mappings.\n" + ... 
                " Creating new code mappings for the model.\n" + ...
                " ==========================================\n");
      codeMapObj = coder.mapping.utils.create(simulinkModel);
    end
     ========================================================
     The model already had code mappings.
     ========================================================
    

    モデルの入力端子 inport_1 のストレージ クラスを取得します。これは、以前に設定したストレージ クラスであることに注意してください。

    getInport(codeMapObj,"inport_1","StorageClass")
    ans = 
    'ExportedGlobal'
    

    モデルを保存せずに閉じます。

    close_system(simulinkModel,false)

    バージョン履歴

    R2020b で導入

    すべて展開する