Skip to content

Latest commit

 

History

History
497 lines (359 loc) · 38.2 KB

README_ja.md

File metadata and controls

497 lines (359 loc) · 38.2 KB

Nu:Tekt NTS-3 kaosspad kit SDK Source and Template Projects

English

概要

このディレクトリに Nu:Tekt NTS-3 kaoss pad kit で使用できるカスタム・オシレーターやエフェクトのビルドに必要なすべてのファイルが揃っています.

必要なソフトウェアバージョン

SDK version 2.0.0でビルドされたユーザーユニットを実行するために, 製品本体にバージョン1.0.0以降のファームウェアがインストールされている必要があります.

このディレクトリの構造:

  • common/ : 共通のヘッダーファイル.
  • ld/ : 共通のリンカーファイル.
  • dummy-genericfx/ : Generic FXプロジェクトのテンプレート.

製品の技術仕様

  • CPU: ARM Cortex-M7 (STM32H725)
  • ユニットのファイル形式: ELF 32-bit LSB shared object, ARM, EABI5 v1 (SYSV), dynamically linked
  • ツールチェイン: gcc-arm-none-eabi-10.3-2021.10

対応モジュール

モジュール スロット数 最大ユニットサイズ 最大RAM読み込みサイズ 利用できる外部メモリのサイズ
genericfx 50 ~ 32KB 32KB 3MB (per runtime)
Generic FXとは

NTS-3 kaoss pad kitのユニットフォーマットであるGeneric FXは, 他のlogue SDKプラットフォーム(例:modfx, derfx, revfxなど)のような特定の目的を持っていません. NTS-3 kaoss pad kitは任意のGeneric FXをロードできる4つののエフェクトランタイムをもっています. 同じエフェクト・ユニットを異なるランタイムを使用して複数回ロードすることができます (例: Generic FXとして作成したReverbを4つ重ねて使用する).

開発環境の環境構築

Dockerベースのビルド環境

Docker-based Build Environmentを参照してください.

Dockerを使わないビルド環境(prologue, minilogue XD, 初代NTS-1の環境と同じ手法)

  1. Gitでこのリポジトリをクローンし, サブモジュールの初期化/アップデートを実行します.
 $ git clone https://github.com/korginc/logue-sdk.git
 $ cd logue-sdk
 $ git submodule update --init
  1. ツールチェインをインストールします: GNU Arm Embedded Toolchain
  2. ビルドに必要なそのほかのユーティリティをインストールします:
    1. GNU Make

ユニットのビルド方法

Dockerベースの開発環境でのビルド

  1. docker/run_interactive.sh コマンドを実行します.
 $ docker/run_interactive.sh
 user@logue-sdk $ 

1.1. (オプション) ビルド可能なプロジェクトの一覧を表示します.

 user@logue-sdk $ build -l --nts-3
 - nts-3_kaoss/dummy-genericfx
  1. ビルドしたいプロジェクトのパスを指定しbuildコマンドを実行します (下記はnts-3_kaoss/dummy-genericfxをビルドする例).
 user@logue-sdk $ build nts-3_kaoss/dummy-genericfx
 >> Initializing NTS-3 kaoss development environment.
 Note: run 'env -r' to reset the environment
 >> Building /workspace/nts-3_kaoss/dummy-genericfx
 Compiler Options
 /usr/bin/arm-none-eabi-gcc -c -mcpu=cortex-m7 -mthumb -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -DTHUMB_PRESENT -g -Os -mlittle-endian -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant -fcheck-new -fPIC -std=c11 -fno-exceptions -W -Wall -Wextra -Wa,-alms=/workspace/nts-3_kaoss/dummy-genericfx//build/lst/ -DSTM32H725xE -DCORTEX_USE_FPU=TRUE -DARM_MATH_CM7 -D__FPU_PRESENT -I. -I/workspace/nts-3_kaoss/common -I/workspace/ext/CMSIS/CMSIS/Include
 
 Compiling header.c
 Compiling _unit_base.c
 Compiling unit.cc
 Linking /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.elf
 /usr/bin/arm-none-eabi-gcc /workspace/nts-3_kaoss/dummy-genericfx//build/obj/header.o /workspace/nts-3_kaoss/dummy-genericfx//build/obj/_unit_base.o /workspace/nts-3_kaoss/dummy-genericfx//build/obj/unit.o -mcpu=cortex-m7 -mthumb -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -DTHUMB_PRESENT -g -Os -mlittle-endian -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant -fcheck-new -nostartfiles -Wl,-z,max-page-size=128,-Map=/workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.map,--cref,--no-warn-mismatch,--library-path=/workspace/nts-3_kaoss/dummy-genericfx//../ld,--script=/workspace/nts-3_kaoss/dummy-genericfx//../ld/unit.ld -shared --entry=0 -specs=nano.specs -specs=nosys.specs -lc -lm -o /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.elf
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.hex
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.dmp
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.bin
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.list
 
    text	   data	    bss	    dec	    hex	filename
    2595	    168	     60	   2823	    b07	/workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.elf
 
 Done

 >> Installing /workspace/nts-3_kaoss/dummy-genericfx
 Making /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.nts3unit
 Deploying to /workspace/nts-3_kaoss/dummy-genericfx//dummy_genericfx.nts3unit
 Done
 
 >> Resetting environment
 >> Cleaning up NTS-3 kaoss development environment.
run_interactiveの代わりにrun_cmd.shを使う方法
  1. run_cmd.shのパスを指定し目的のプロジェクトをビルドします (下記はnts-3_kaoss/dummy-genericfxをビルドする例).
 $ ./run_cmd.sh build nts-3_kaoss/dummy-genericfx
 >> Initializing NTS-3 kaoss development environment.
 Note: run 'env -r' to reset the environment
 >> Building /workspace/nts-3_kaoss/dummy-genericfx
 Compiler Options
 /usr/bin/arm-none-eabi-gcc -c -mcpu=cortex-m7 -mthumb -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -DTHUMB_PRESENT -g -Os -mlittle-endian -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant -fcheck-new -fPIC -std=c11 -fno-exceptions -W -Wall -Wextra -Wa,-alms=/workspace/nts-3_kaoss/dummy-genericfx//build/lst/ -DSTM32H725xE -DCORTEX_USE_FPU=TRUE -DARM_MATH_CM7 -D__FPU_PRESENT -I. -I/workspace/nts-3_kaoss/common -I/workspace/ext/CMSIS/CMSIS/Include
 
 Compiling header.c
 Compiling _unit_base.c
 Compiling unit.cc
 Linking /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.elf
 /usr/bin/arm-none-eabi-gcc /workspace/nts-3_kaoss/dummy-genericfx//build/obj/header.o /workspace/nts-3_kaoss/dummy-genericfx//build/obj/_unit_base.o /workspace/nts-3_kaoss/dummy-genericfx//build/obj/unit.o -mcpu=cortex-m7 -mthumb -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -DTHUMB_PRESENT -g -Os -mlittle-endian -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant -fcheck-new -nostartfiles -Wl,-z,max-page-size=128,-Map=/workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.map,--cref,--no-warn-mismatch,--library-path=/workspace/nts-3_kaoss/dummy-genericfx//../ld,--script=/workspace/nts-3_kaoss/dummy-genericfx//../ld/unit.ld -shared --entry=0 -specs=nano.specs -specs=nosys.specs -lc -lm -o /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.elf
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.hex
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.dmp
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.bin
 Creating /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.list
 
    text	   data	    bss	    dec	    hex	filename
    2595	    168	     60	   2823	    b07	/workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.elf
 
 Done

 >> Installing /workspace/nts-3_kaoss/dummy-genericfx
 Making /workspace/nts-3_kaoss/dummy-genericfx//build/dummy_genericfx.nts3unit
 Deploying to /workspace/nts-3_kaoss/dummy-genericfx//dummy_genericfx.nts3unit
 Done
 
 >> Resetting environment
 >> Cleaning up NTS-3 kaoss development environment.
ビルドで生成されるファイル

ビルドによって最終的に .nts3unit ファイルがプロジェクトのディレクトリ (ビルドスクリプトで場所を指定しなかった場合)に生成されます.

Dockerを使わない(prologue, minilogue XD, 初代NTS-1の環境と同じ)開発環境でのビルド方法

  1. プロジェクトのディレクトリに移動します.
$ cd logue-sdk/platform/nts-3_kaoss/dummy-genericfx/
  1. makeコマンドを実行しプロジェクトをビルドします.
$ make
Compiler Options
../../../tools/gcc/gcc-arm-none-eabi-10.3-2021.10/bin/arm-none-eabi-gcc -c -mcpu=cortex-m7 -mthumb -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -DTHUMB_PRESENT -g -Os -mlittle-endian -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant -fcheck-new -fPIC -std=c11 -fno-exceptions -W -Wall -Wextra -Wa,-alms=build/lst/ -DSTM32H725xE -DCORTEX_USE_FPU=TRUE -DARM_MATH_CM7 -D__FPU_PRESENT -I. -I../common -I../../ext/CMSIS/CMSIS/Include

Compiling header.c
Compiling _unit_base.c
Compiling unit.cc
Linking build/dummy_genericfx.elf
../../../tools/gcc/gcc-arm-none-eabi-10.3-2021.10/bin/arm-none-eabi-gcc build/obj/header.o build/obj/_unit_base.o build/obj/unit.o -mcpu=cortex-m7 -mthumb -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -DTHUMB_PRESENT -g -Os -mlittle-endian -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant -fcheck-new -nostartfiles -Wl,-z,max-page-size=128,-Map=build/dummy_genericfx.map,--cref,--no-warn-mismatch,--library-path=../ld,--script=../ld/unit.ld -shared --entry=0 -specs=nano.specs -specs=nosys.specs -lc -lm -o build/dummy_genericfx.elf
Creating build/dummy_genericfx.hex
Creating build/dummy_genericfx.bin
Creating build/dummy_genericfx.dmp

   text	   data	    bss	    dec	    hex	filename
   2595	    168	     60	   2823	    b07	build/dummy_genericfx.elf

Creating build/dummy_genericfx.list
Done
  1. make installを実行し, 最終的なユニットファイルにします.
$ make install
Making build/dummy-genericfx.nts3unit
Deploying to ./dummy-genericfx.nts3unit
Done
  1. Deploying... で示された場所に, .nts3unit ファイルが生成されます. このファイルを製品に書き込んで使用します.

TIP: 環境変数INSTALLDIRを編集することで, インストールディレクトリを変更することができます.

ユニットのクリーン方法

Dockerベースの開発環境の場合

プロジェクトのクリーンを実行するとビルド成果物と一時ファイルを削除できます.

  1. docker/run_interactive.shを実行します.
 $ docker/run_interactive.sh
 user@logue-sdk $ 
  1. 目的のプロジェクトをクリーンします (nts-3_kaoss/dummy-genericfxの例) .
 user@logue-sdk:~$ build --clean nts-3_kaoss/dummy-genericfx 
 >> Initializing NTS-3 kaoss development environment.
 Note: run 'env -r' to reset the environment
 >> Cleaning /workspace/nts-3_kaoss/dummy-genericfx
 Cleaning
 rm -fR /workspace/nts-3_kaoss/dummy-genericfx//.dep /workspace/nts-3_kaoss/dummy-genericfx//build /workspace/nts-3_kaoss/dummy-genericfx//dummy_genericfx.nts3unit
 Done
 
 >> Resetting environment
 >> Cleaning up NTS-3 kaoss development environment.
run_interactiveの代わりにrun_cmd.shを使う方法
  1. 目的のプロジェクトをクリーンします (nts-3_kaoss/dummy-genericfxの例) .
 $ ./run_cmd.sh build --clean nts-3_kaoss/dummy-genericfx 
 >> Initializing NTS-3 kaoss development environment.
 Note: run 'env -r' to reset the environment
 >> Cleaning /workspace/nts-3_kaoss/dummy-genericfx
 Cleaning
 rm -fR /workspace/nts-3_kaoss/dummy-genericfx//.dep /workspace/nts-3_kaoss/dummy-genericfx//build /workspace/nts-3_kaoss/dummy-genericfx//dummy_genericfx.nts3unit
 Done
 
 >> Resetting environment
 >> Cleaning up NTS-3 kaoss development environment.

Dockerを使わない(prologue, minilogue XD, 初代NTS-1の環境と同じ)開発環境でのクリーン

  1. プロジェクトのディレクトリに移動します.
$ cd logue-sdk/platform/nts-3_kaoss/dummy-genericfx/
  1. make cleanを実行しプロジェクトをクリーンします.
$ make clean
Cleaning
rm -fR .dep build dummy-genericfx.nts3unit
Done

unit ファイルを実機に書き込む

ビルドした .nts3unit ファイルはKORG Kontrol Editor(準備中)または新しいloguecli(準備中) を使って Nu:Tekt NTS-3 kaoss pad kit にロードできます.

製品にロードされたユニットは, 各モジュール選択時にリストの最後にスロット番号順に表示されます.

TIP NTS-3 kaoss pad kitはdev/unit IDを使ってユニットを識別するため, これらを編集してスロットの順序を自由に移動することができます.

新規プロジェクトの作成

  1. テンプレート・プロジェクトのディレクトリdummy-genericfxをコピーし, platform/nts-3_kaoss/ において任意の名前を付けます.
  2. プロジェクトのビルドをカスタマイズしたい場合は config.mk を編集します. 詳細は config.mk セクションを参照してください.
  3. header.c テンプレートをプロジェクトに合わせて変更してください. 詳細はheader.c セクションを参照してください.
  4. unit.cc テンプレートで, 作成したコードとユニットAPIを統合します. 詳細は unit.cc セクションを参照してください.

プロジェクトの構造

config.mkファイル

config.mk ではMakefileを直接書き換えることなく, プロジェクトのソースファイルやinclude, ライブラリの宣言, 特定のビルドパラメーターのオーバライドをおこなうことができます.

デフォルトでは以下の変数が定義, もしくはすぐに使用できるよう設定されています.

  • PROJECT : プロジェクトの名前です. 最終的なビルド成果物のファイル名として使用されます. (Note: 製品にロードしたときに画面に表示される名前ではありません)
  • PROJECT_TYPE : ビルドするプロジェクトの種類を決定します. NTS-3 kaosspad kitではgenericfxに設定してください.
  • CSRC : プロジェクトで使用するC言語のソースファイルのリストです. 少なくともheader.cファイルが含まれている必要があります.
  • CXXSRC : プロジェクトで使用するC++のソースファイルのリストです. 少なくとも unit.cc ファイルが含まれている必要があります.
  • UINCDIR : 追加のインクルードのリストです.
  • ULIBDIR : 追加のライブラリのリストです.
  • ULIBS : 追加のライブラリフラグのリストです.
  • UDEFS : コンパイル時の追加定義のリストです. (記述例: -DENABLE\_MY\_FEATURE)

header.cファイル

header.c はprologue, minilogue XD, 初代のNTS-1の manifest.json と似た役割を担っており, ユニットとその公開パラメーターに関するいくつかのメタデータ情報を提供します. このファイルはユニットのコードと一緒にコンパイルされ, .unit_header という専用のELFセクションに置かれます.

フィールド:

  • .header_size : ヘッダー・ストラクチャーのサイズです. テンプレートの定義のままにしてください.
  • .target : ターゲット・プラットフォームとモジュールを定義します. テンプレートの定義のままで使用しますが, 定義されているモジュールが実際に作りたいモジュールのタイプと一致していることを確認してください. (osc: k_unit_module_osc, modfx: k_unit_module_modfx, delfx: k_unit_module_delfx, revfx: k_unit_module_revfx)
  • .api : ユニットがビルドされる際の Logue SDK APIのバージョンです. テンプレートのデフォルト値では, 現行のAPIが使用されます.
  • .dev_id : 開発者を識別するための固有のIDです. ローエンディアンの32ビット符号なし整数で表現されます. 詳細は開発者IDのセクションをご参照ください.
  • .unit_id : ユニットを識別するための固有のIDです. ローエンディアンの32ビット符号なし整数で表現されます. 同一のdev_idの範囲内では, ユニットごとに異なる固有のunit_idを設定してください.
  • .version : ユニットのバージョンをローエンディアンの32ビット符号なし整数で記述することができます. 上位16ビットにメジャー・バージョン番号を, 下位2バイトにそれぞれマイナー・バージョン番号とパッチ番号を設定できます (例: v1.2.3 -> 0x00010203U).
  • .name : ロード時にデバイスに表示されるユニットの名前を指定します. ASCIIのNULL終端配列で最大18文字です. 次の文字を使うことができます: " ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._".
  • .num_params : ユニットの公開パラメーターの数です. この値はモジュールごとに異なり, common headerの UNIT_XXX_MAX_PARAM_COUNT に正確な値があります(XXXがターゲットとなるモジュールを示します).
  • .params : パラメーター記述子の配列です. 詳細はパラメーター記述子のセクションをご参照ください.

デフォルト・パラメーター・マッピング

NTS-3 kaoss pad kitのGeneric FXは, (.default_mappings) 各エフェクト・パラメーターのUIコンポーネント (Touch Pad, FX DEPTH Slider)へのデフォルトのマッピング情報を持っています.

パラメーター・マッピングは下記のように定義されます:

  typedef struct genericfx_param_mapping {
    uint8_t assign;
    uint8_t curve:7;
    uint8_t curve_polarity:1;
    int16_t min;
    int16_t max;
    int16_t value;
  } genericfx_param_mapping_t;
  • .assign : パラメーターをアサインするUIコンポーネントを決定します. 次から選択できます: k_genericfx_param_assign_none, k_genericfx_param_assign_x, k_genericfx_param_assign_y, and k_genericfx_param_assign_depth.
  • .curve : UIコンポーネントの値の変化に適用される, カーブを定義します. 詳細はCurvesセクションを参照してください.
  • .curve_polarity : curveの極性をユニポーラー型かバイポーラー型か選択できます. 詳細はCurvesセクションを参照してください.
  • .min : UIコンポーネントの最小点 (Pad X: 左端, Pad Y: 下端, FX DEPTH, 下端) に対応するパラメーター値を定義します.
  • .max : UIコンポーネントの最大点 (Pad X: 右端, Pad Y: 上端, FX DEPTH, 上端) に対応するパラメーター値を定義します.
  • .value : assignで割り当てられたUIコンポーネントで制御される前の, パラメーターのデフォルト値を定義します.

.min.max.value は, パラメーター記述子で定義されたパラメーター値の最小/最大範囲内で設定する必要があります. (詳細は Parameter Descriptorsを参照してください)

TIP: .min.maxの値を入れ替えることで, UIコンポーネントの値の増減の方向が反転した効果を得ることができます.

Curves

カーブは下記から設定できます:

  • k_genericfx_curve_linear : パラメーターの値は.min.maxの間で線形 (一定) に処理されます.
  • k_genericfx_curve_exp : パラメーターの値は.min.maxの間で指数関数的に変化します.
  • k_genericfx_curve_log : パラメーターの値は.min.maxの間で対数カーブで変化します.
  • k_genericfx_curve_toggle : パラメーターの値は操作するUIコンポーネントの中点より下では.minの値に, 上では.maxの値にトグルされます.
  • k_genericfx_curve_minclip : パラメーターの値は操作するUIコンポーネントの中点より下では.minの値に固定され, 中点より上では.maxの値まで直線的に大きくなります.
  • k_genericfx_curve_maxclip : パラメーターの値は操作するUIコンポーネントの下端から中点までで.minから.maxに直線的に増加し, 中点より上では.maxに固定されます.

k_genericfx_curve_bipolarが設定されている場合, curveは操作するUIコンポーネントの中点で両側に反射/反転する形になります. (例: k_genericfx_curve_logの場合, curveはSの文字のような形になります)

unit.ccファイル

unit.cc はlogue SDK APIとのメインのインターフェイスです. API関数へのエントリー・ポイントを提供し, グローバルに定義されたステートメントやクラス・インスタンスを保持します.

開発者ID

開発者はユニットの適切な識別のために, 既に使用されているIDと被らないように, ユニークな開発者ID(32ビット符号なし整数)を設定する必要があります. 既に設定されているIDのリストはこちらにあります.

Note 次の開発者IDは予約済みであり, 使用できません: 0x00000000, 0x4B4F5247 (KORG)と0x6B6F7267 (korg)とこれらの大文字/小文字の組み合わせ

パラメーター記述子

パラメーター記述子は header 構造体の一部として定義されます. パラメーターの名前, パラメーターの値の範囲, パラメーターの値の解釈や表示方法の制御といった項目を設定できます.

typedef struct unit_param {
 int16_t min;
 int16_t max;
 int16_t center;
 int16_t init;
 uint8_t type;
 uint8_t frac : 4;       // fractional bits / decimals according to frac_mode
 uint8_t frac_mode : 1;  // 0: 固定小数点, 1: 10進数
 uint8_t reserved : 3;
 char name[UNIT_PARAM_NAME_LEN + 1];
} unit_param_t;
  • minmax はパラメーターの最小値/最大値を決定します.
  • centerはパラメーターがバイポーラー(両極性, プラス値とマイナス値, ステレオ・パンのLとRなど)であることを示すために使うことができます. ユニポーラーの場合はシンプルにminの値に設定してください.
  • initはパラメーターの初期値です. ユニット・パラメーターは初期化段階のあとにinitの値に設定されることが期待されます.
  • typeを設定することで, パラメーターを製品のディスプレイに表示するときのフォーマットをコントロールすることができます. 詳細はパラメーターの型のセクションを参照してください.
  • fracでパラメーターの小数部分を設定できます. この値はfrac_modeの値に応じて小数ビット数または小数として解釈されます.
  • frac_modeで記述される小数値のタイプを決定します. 0に設定すると値は固定小数点となり, fracで指定されたビットが小数部を表します. 1に設定すると値はfracの10倍を乗じたの小数部分を含むとみなされ,基数10の小数の増減が可能になります.
  • reserved は常に0に設定してください.
  • nameには21文字の名前を付けることができます. 値はNULL終端で7ビットのASCIIフォーマットである必要があり, 次の文字をサポートしています " ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._".

Note min, max, center ,initの値はfracfrac_modeの値を考慮して設定する必要があります.

使いたいパラメーター数が利用できる最大パラメーター数より少ない場合でも, 各パラメーターでパラメーター記述子を設定する必要があります. 使用しないパラメーター・インデックスには以下のパラメーター記述子を記入して埋めてください.

{0, 0, 0, 0, k_unit_param_type_none, 0, 0, 0, {""}}

パラメーターの型

下記のパラメーター・タイプ(型)を利用し, パラメーターを製品のディスプレイに表示するときのフォーマットをコントロールすることができます.

Note: NTS-3 kaoss pad kitの7セグメント・ディスプレイの制限により多くのパラメーターでは表示形式に大きな変化はありませんが, 将来的に利用できるようにパラメーターに対し適切なタイプを選択することを推奨します.

  • k_unit_param_type_none : 型を持たない値の記述に用います. 値がそのまま表示されます(端数が考慮されます).
  • k_unit_param_type_percent : パーセント値の記述に用います.
  • k_unit_param_type_db : デシベル値の記述に用います.
  • k_unit_param_type_cents : ピッチのセント値の記述に用います.
  • k_unit_param_type_semi : ピッチのセミトーンの記述に用います.
  • k_unit_param_type_oct : ピッチのオクターブ値の記述に用います.
  • k_unit_param_type_hertz : ヘルツ値の記述に用います.
  • k_unit_param_type_khertz : キロヘルツ値の記述に用います.
  • k_unit_param_type_bpm : BPM(Beat Per Minute)の記述に用います.
  • k_unit_param_type_msec : ミリ単位の値の記述に用います.
  • k_unit_param_type_sec : 秒単位の値の記述に用います.
  • k_unit_param_type_enum : 数値列挙値を記述に用います. パラメーター記述子でminを0に設定している場合, 表示の際に1増加した値が表示されます.
  • k_unit_param_type_strings : ユーザー・カスタムの文字列表現による値の記述に用います. unit_get_param_str_value(..)を呼び出して数値を渡すことで, 文字列を取得します. 詳細は文字列 セクションを参照してください.
  • k_unit_param_type_drywet : ドライ・ウェットの値の記述に用います. マイナスの値の前にはドライを示すDが, プラスの値の前にはウェットを示すWの文字が追加され, 値が0になった場合はバランス・ミックスを表すBALNの文字に置き換わります.
  • k_unit_param_type_pan : ステレオ・パンの値の記述に用います. マイナスの値の前には左を示すL, プラスの値には右を示すRの文字が追加され, 値が0になった場合はパンニングが中央(センター)であることを示すCNTRの文字に置き換わります.
  • k_unit_param_type_spread : ステレオの広がりの値の記述に用います. マイナスの値の前には左を示すL, プラスの値には右を示すRの文字が追加され, 値が0になった場合はステレオの広がりがないことを表すCNTRの文字に置き換わります.
  • k_unit_param_type_onoff: オン・オフのトグルの記述に用います. 0offに, 1onとして文字で表示されるようになります.
  • k_unit_param_type_midi_note : MIDIノートの値の記述に用います. ノート値を示す数値が, 音名として表示されます(例: C0, A3).

ユニットAPIの概要

ここではGeneric FXユニットの概要を説明します.

Essential Functions

全てのユニットで, 以下の関数の実装が必要です. ただし, 各関数でデフォルトでフォール・バック実装が存在するため, 目的に合った関数のみの実装で十分です.

  • __unit_callback int8_t unit_init(const unit_runtime_desc_t * desc) : ユニットがロードされた後に自動的に呼ばれる関数です. ランタイム環境の基本的なチェック, ユニットの初期化, 外部メモリの確保(必要な場合)を実行します. descは現在のランタイム環境の記述子を提供します (詳細はランタイム記述子のセクションを参照してください).
  • __unit_callback void unit_teardown() : ユニットがアンロードされる前に呼ばれます. クリーン・アップやメモリの解放が必要な場合に使用してください.
  • __unit_callback void unit_reset() : ユニットをニュートラルな状態にリセットしなければならないケースで呼ばれる関数です. 必要に応じて, アクティブなノートの非アクティブ化, エンヴェロープ・ジェネレーターをニュートラル状態にリセット, オシレーターの位相のリセット, ディレイ・ラインのクリア (一度に全てクリアするのは重い可能性があります) などの処理を実装してください. ただしパラメーターのデフォルト値へのリセットはここでは実施しないでください.
  • __unit_callback void unit_resume() : 処理が中断されていたユニットが処理を再開する直前に呼び出される関数です.
  • __unit_callback void unit_suspend() : ユニットを切り替えたときなど, ユニットの処理が中断されるときに呼ばれる関数です.通常, そのあとにunit_reset()が呼ばれます.
  • __unit_callback void unit_render(const float * in, float * out, uint32_t frames) : オーディオ・レンダリングのコールバック関数です. インプット/アウトプット・バッファーの情報はunit_init(..)関数の引数unit_runtime_desc_tで提供されます.
  • __unit_callback int32_t unit_get_param_value(uint8_t index) : 引数で指定されたインデックスのパラメーターの現在の値を取得するために呼び出されます.
  • __unit_callback const char * unit_get_param_str_value(uint8_t index, int32_t value) : k_unit_param_type_strings型のパラメーターのカスタム文字列を取得するために呼ばれる関数です. 戻り値はNULL終端の7ビットASCII文字列を指すポインターにしてください. このポインターは unit_get_param_str_value(..)が再び呼び出されるまでキャッシュ/再利用されることはありません.
  • __unit_callback void unit_set_param_value(uint8_t index, int32_t value) : 引数で指定されたインデックスのパラメーターの現在の値を設定するために呼ばれる関数です. NTS-3 kaoss pad kitでは値は16ビット整数として保存されますが, 将来的なAPIの互換性を担保するため32ビット整数として値が渡されていることに注意してください. 安全性を高めるため, ヘッダーで宣言したmin/maxの値に従って, 値のチェックと丸め込みを実施してください.
  • __unit_callback void unit_set_tempo(uint32_t tempo) : テンポが変更された時に呼び出される関数です. テンポは固定小数点でフォーマットされ, 上位16ビットが整数部分, 下位16ビット(ローエンディアン)が小数部分になります. この関数は外部デバイスとテンポ同期しているときに頻繁に呼び出される可能性があるため, テンポ変更を処理する際にはCPU負荷を可能な限り低く保つように注意してください.
  • __unit_callback void unit_tempo_4ppqn_tick_func(uint32_t counter) : 初期化後, 4PPQNインターバル(16分音符)のクロック・イベントをユニットに通知するためにいつでも呼び出すことができる関数です.

NTS-3 Specific Touch Event Handler

NTS-3 kaoss pad kitでは下記APIの実装が必要です.

  • __unit_callback void unit_touch_event(uint8_t id, uint8_t phase, uint32_t x, uint32_t y) : このコールバックではタッチ・イベントをユニットに渡すことができます. 初期化後にいつでも実行可能です.

  • id : タッチイ・ベントのIDで, シングル・タッチのプラットフォームでは常に0です. (NTS-3 kaoss pad kitはシングル・タッチです)

  • phase : 現在のタッチの状態(フェイズ)です. 詳細は後述します.

  • x : タッチのX座標です. (X軸の解像度の範囲内の値になります. 詳細はランタイム記述子のセクションを参照してください)

  • y : タッチのY座標です. (Y軸の解像度の範囲内の値になります. 詳細はランタイム記述子のセクションを参照してください)

Touch Phases
  • k_unit_touch_phase_began : タッチの開始が検出された状態です.
  • k_unit_touch_phase_moved : 別の座標へ移動している状態です.
  • k_unit_touch_phase_ended : タッチが終了している状態です.
  • k_unit_touch_phase_stationary : 現在の座標を強制的に更新するために使用されます.
  • k_unit_touch_phase_cancelled : タッチがシステム要因で強制的に終了した状態です.

ランタイム記述子

ランタイム記述子への参照は初期化段階でユニットに渡されます. この記述子は, 現在のデバイス, API, オーディオ・レート, バッファに関する情報と, 呼び出し可能なAPI巻子へのポインタを提供します.

typedef struct unit_runtime_desc {
 uint16_t target;
 uint32_t api;
 uint32_t samplerate;
 uint16_t frames_per_buffer;
 uint8_t input_channels;
 uint8_t output_channels;
 unit_runtime_hooks_t hooks;
} unit_runtime_desc_t;
  • target : 現在のプラットフォームとモジュールを記述します. k_unit_target_nts3_kaoss_genericfxに設定してください. マクロUNIT_TARGET_PLATFORM_IS_COMPAT(target)を使うと現在のユニットと実行環境の互換性をチェックできます.
  • api : 現在使用されているAPIのバージョンを記述します. バージョンは上位16ビットにメジャー番号, 下位2バイトにそれぞれマイナー番号とパッチ番号が格納されます (例: v1.2.3 -> 0x00010203U). マクロUNIT_API_IS_COMPAT(api)を使うと現在のユニットとランタイム環境APIの互換性をチェックできます.
  • samplerate : オーディオ処理に適用するサンプルレートを指定します. NTS-3 kaoss pad kitでは常に48000であるべきですが, 将来的な互換性のためユニットによってチェックすることを推奨します. ユニットはunit_init(..)関数から k_unit_err_samplerate*を返すことで, 不都合なサンプルレートを拒否することができます.
  • frames_per_buffer : unit_render(..)関数での, オーディオ処理バッファの最大フレーム数を記述します. 一般的には関数のframes引数と等しくなければいけませんが, それより小さい値のサポートも検討してください.
  • input_channels : unit_render(..)関数の入力バッファにある, 1フレーム当たりのオーディオのチャンネル数(サンプル数)を記述します.
  • output_channels : unit_render(..)関数の出力バッファにある, 1フレーム当たりのオーディオのチャンネル数(サンプル数)を記述します.
  • hooks はランタイム環境が提供する追加のコンテキストと呼び出し可能なAPIへのアクセスを提供します. 詳細はランタイム・コンテキスト呼び出し可能なAPI関数のセクションを参照してください.

ランタイム・コンテキスト

NTS-3 kaoss pad kitのGeneric Fxのランタイムは, 追加の情報をユニットに提供します.

  • .touch_area_width : XY pad領域の幅です. X軸のタッチ時の座標は, この値で丸め込まれます. (通常は1024段階, X軸の座標は0-1023になります)
  • .touch_area_height : XY pad領域の高さです. Y軸のタッチ時の座標は, この値で丸め込まれます. (通常は1024段階, Y軸の座標は0-1023になります)

呼び出し可能なAPI関数

  • sdram_alloc (uint8_t *sdram_alloc(size_t size)) この関数は外部メモリのバッファを確保します. この割り当ては初期化段階で行ってください. バッファのサイズは4バイト・アラインメントを推奨します.
  • sdram_free (void sdram_free(const uint8_t *mem)) この関数はsdram_allocによって割り当てられた外部メモリのバッファを解放します.
  • sdram_avail (size_t sdram_avail()) この関数は現在利用可能な外部メモリのサイズを返します.

さらにgenericfxランタイムは下記のNTS-3 kaosspad kit固有のAPIを提供します.

  • get_raw_input (const float *get_raw_input()) : エフェクトのON/OFFの状態に影響されない, 生のオーディオ入力バッファへの参照を取得することができます.

このAPIはルーパーやグラニュラー・エフェクトといった, タッチ・イベントによって有効にされる前に入力音声のバッファリングを始める必要があるエフェクトに有用です.

Note: このバッファへの参照は, unit_renderの呼び出しで再利用しないでください.

文字列

unit_get_param_str_value(..)関数で扱う文字列は, NULL終端の7ビットASCII文字である必要があり, 次の文字がサポートされています: " ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._".