JPS6042954B2 - electronic musical instruments - Google Patents

electronic musical instruments

Info

Publication number
JPS6042954B2
JPS6042954B2 JP51158948A JP15894876A JPS6042954B2 JP S6042954 B2 JPS6042954 B2 JP S6042954B2 JP 51158948 A JP51158948 A JP 51158948A JP 15894876 A JP15894876 A JP 15894876A JP S6042954 B2 JPS6042954 B2 JP S6042954B2
Authority
JP
Japan
Prior art keywords
data
signal
output
memory
channel
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired
Application number
JP51158948A
Other languages
Japanese (ja)
Other versions
JPS5383610A (en
Inventor
昭紀 遠藤
博万 加藤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nippon Gakki Co Ltd
Original Assignee
Nippon Gakki Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nippon Gakki Co Ltd filed Critical Nippon Gakki Co Ltd
Priority to JP51158948A priority Critical patent/JPS6042954B2/en
Publication of JPS5383610A publication Critical patent/JPS5383610A/en
Publication of JPS6042954B2 publication Critical patent/JPS6042954B2/en
Expired legal-status Critical Current

Links

Landscapes

  • Electrophonic Musical Instruments (AREA)

Description

【発明の詳細な説明】[Detailed description of the invention]

〔産業上の利用分野〕 この発明は、発音割当て方式の電子楽器の改良に関する
。 〔従来の技術〕 発音割当て方式の電子楽器は、複数の楽音発生チャンネ
ルを有するウエイブジエネレータと、このウエイブジエ
ネレータの各チャンネルに、押下された鍵盤キーの発音
を割当てるアサイナとを有して構成される。 〔発明が解決しようとする問題点〕 ところで、従来のこの種の電子楽器にあつては、アサイ
ナとウエイブジエネレータとが直結されているので、ウ
エイブジエネレータの構成を簡単に変更できず、また、
両者を同期動作させる必要があるので、設計上の制約が
ある。 また、アサイナとウエイブジエネレータとは通常別個の
151チップによつて構成されるが、上述した従来の電
子楽器は両チップ間の配線数が増える欠点があ’る。〔
問題点を解決するための手段〕 この発明は、上記の欠点を解消するためになされたもの
で、アサイナを、各チヤンネルヘの音の割当てに対応し
て、割当てた音に関する周波数デ・ 一タおよびエンベ
ロープデータを各チャンネル毎にバスに順次出力するよ
うに構成し、また、ウエイブジエネレータを、上記バス
に送出された上記周波数データおよびエンベロープデー
タを上記各チャンネルごとにそれぞれ記憶する記憶手段
と、上記記憶手段に記憶された周波数データを各チャン
ネルごとにそれぞれ演算して各チャンネルの位相データ
を形成して時分割出力する第1の演算手段と、上記記憶
手段に記憶されたエンベロープデータを各チャンネルご
とにそれぞれ演算して各チャンネルのエンベロープ波形
データを形成して時分割出力する第2の演算手段と、上
記第1および第2の演算手段から出力されると位相デー
タおよびエンベロープ波形データに基づき各チャンネル
ごとに時分割で楽音波形を形成する楽音波形形成手段と
から構成したことを特徴としている。 〔実施例〕以下、この発明の一実施例を図面を参照して
詳細に説明する。 最初に、この実施例において用いられる楽音波形形成の
基本原理について説明する。 まず、この実施例においては、y=ASIN(ωなる周
波数変調演算の式に基づいて、ディジタル方式によつて
楽音波形が形成される。 この(1)式において、Aは楽音波形の振幅を決定する
要素であり、ωoは周波数変調における搬送波の周波数
を決定する要素であり、また、ω1,ω2および11,
11は周波数変調における変調波の周波数および振幅を
決定する要素てある。第1図、上記(1)式に基づいて
楽音波形を形成する場合の基本的回路構成の一例を示す
図であり、この図においてACCl〜ACC3はいずれ
も累算器である。 これらの累算器ACCl〜ACC3は各々、各入力端に
供給される位相の増分値Δω1,Δω2,Δωoを一定
周期のクロックパルスに従つて累算し、その累算結果を
順次出力する。サインテーブルSINl,SIN2は共
にサイン波形の各瞬時値を記憶しているメモリであり、
累算器−ACCl,ACC2の出力が各々アドレス信号
として供給されると、同じアドレス信号に対応する番地
内に記憶されている瞬時値が読出され乗算回路Ml,M
2へ各々供給される。以上の構成において、例えば累算
器ACClが−ROョから累算を開始し、そして、オー
バフローするまでの期間で、サインテーブルSINlか
ら丁度1周期分のサイン波の各瞬時値が順次読出される
。 この場合、累算器ACClの累算速度は、クロックパル
スの周波が一定であることから一定であり、したがつて
、位相の増分値Δω1が一定の場合、サインテーブルS
INlから出力されるサイン波の周期は一定となる。言
い換えれば、位相の増分値Δω1の値を変化させるこに
より、サインテーブルSINlから出力されるサイン波
の周期(周波数)を変化させることができる。例えば、
位相の増分値Δω1を大とすれば、サイン波の周期は小
となり、また、増分値Δω1を小とすれば”サイン波の
周期が大となる。また、累算器ACCl〜ACC3にお
いて各々行われる累算を式によつて示すと、となる。 なお、これらの式においてω11N,,ω21NT9ω
0INTは各々位相の初期値であるO再び第1図に戻る
と、乗算器M1はサインテーブルSINlの出力と、前
記第(1)式における11の値を発生する数値発生回路
11の出力とを乗算するもので、その出力は加算回路A
Uへ供給される。同様に、乗算器M2はサインテーブル
SIN2の出力と、第(1)式における12の値を発生
する数値発生回路12の出力とを乗算し、乗算結果を加
算回路AUへ出力する。加算回路AUは乗算器Ml,M
2、累算器ACC3の各出力を加算し、加算結果をサイ
ンテーブルSIN3へアドレス信号として供給する。サ
インテーブルSIN3は前述したサインテーブルSIN
l,2と同一構成てあり、その出力は乗算回路M3へ供
給される。乗算器M3はサインテーブルSIN3の出力
と、第(1)式におけるAの値を発生する数値発生回路
Aの出力とを乗算し、その乗算結果を出力する。しかし
て、以上の説明から明らかなように、第1図に示す各ブ
ロックの出力は各々、第(1)式における次の各要素に
対応している。 すなわち、乗算器M3の出力として第(1)式に示す波
形が得られる。 なお、乗算器M3の出力は当然のことながらディジタル
データである。したがつて、楽音波形を得るには、この
データをD/A(ディジタル/アナログ)変換器によつ
てアナログ波形とする必要がある。以上、楽音波形形成
回路の基本的構成について述べたが、次に、この実施例
における楽音波形形成の過程を更に詳しく述べる。 この実施例は、前記第(1)式のA,ω0,11,12
,ω1,ω2の各々を楽音の発生から停止までの間に適
宣変化させ、これにより、形成される楽音がより自然楽
器の楽音に近づくように構成されている。 すなわち、この実施例においては、楽音波形の振幅エン
ベロープを例えば第2図に示すものとすれば、このエン
ベロープにおける楽音発生時点t1から楽音停止時点T
2までの間を8個のセグメント0〜7に分割し、各セグ
メント毎に上記,A,ω。,11・・・・・・として別
個の値(同じ値の場合もある)を設定し、この設定され
た値に基づいて第(1)式の楽音波形を形成する。また
この場合、各セグメント内においても上記A,ll,l
2の各値が各々変化し、これにより、形成される楽音波
形が;各セグメント0〜7内においても順次変化するよ
うになつている。そして、各セグメント0〜7内におけ
るA,ll,l2の各値の変化は以下の式に基づいて行
なわれる。 なお、これらの式においてΔA,Δ11,Δ12は各々
第(1)式におけるA,ll,l2の増分値、A!NT
,ll!Nτ912!NTは各々A9ll9l2の初期
値であるOまた、セグメント0〜7の各々の時間幅は、
後述するセグメンデータ、すなわち、レイトカウントデ
ータRCDO−RCD7およびエンベロカウントデータ
ECDO上CD7によつて決定されるようになつている
。 しかして、以上述べたことから明らかなように、この実
施例においては1つの楽音波形(1個のキー操作によつ
て発生する楽音波形)を発生するために、次の各データ
(合計70W0RD:1W0RD=16ビット)を必要
とする。 (4)第1表および第2表に示す増分値(48W0RD
)(B)初期値(6W0RD) A!NT9ll!NT9l2工NT ωO !NT9ω1 !NT9ω21NT(C)セグメ
ントデータ(16W0RD)レイトカウントデータRC
DO−RCD7エンベロープカウントデータECDO上
CD7したがつて、この実施例においては、発生すべき
楽音の音色および音高に対応して上述した(4)〜(C
)の各データが予めメモリ内に設定されており、このメ
モリ内の各データを読出して楽音の形成が行われる。 例えば、音色の種類が1喝類、キーの数が44個の電子
オルガンの場合は、上述した各データが44国且メモリ
内に設定される。以上が、この実施例において用いられ
る楽音形成の基本原理である。次に、この実施例にによ
る電子オルガンにつにて詳細に説明する。 第3図は上記電子オルガンの構成を示すブロック図であ
り、この図において符号101は音色を設定するための
音色レバー、102は鍵盤に設けられたキー群である。 音色レバー101は、この実施例においては1C@のレ
バーから構成され、また、各レバーに対応してw個の音
色スイッチが設けられている。そして、各音色スイッチ
の出力が各々キーアサイナ103へ供給される。キー群
102は、この実施例においては44個のキーと各キー
に対応する44個のキースイッチから構成され、各キー
スイッチの出力が各々キーアサイナ103へ供給される
。キーアサイナ103は、上述した音色スイッチの各出
力に基づいて、現在設定されている音色を検出すると共
に、上述したキースイッチの出力に基づいて、新たに押
下されたキー、離鍵されたキーを検出する。そして、新
たに押下されたキーを検出した場合は、同キーの楽音発
生をこの発明によるウエイブジエネレータ104のいず
れかのチャンネル(後述する)に割当て、また、離鍵さ
れたキーを検出した場合は、同キーの発音が割当てられ
ている上記チャンネルに発音停止を指示する。このキー
アサイナ103には=RArVl(ランダムアクセスメ
モリ)105およびROM(リードオンメモリ)106
が各々接続されている。そして、RAMlO5には、チ
ャンネル割当ての際使用される各種データテーブル、デ
ータファイル等が記憶されており、また、ROM,lO
6には、音色スイッチの検出、キーの押鍵・離鍵の検出
、チャンネル割当て等の際に使用されるプログラムおよ
びウエイブジエネレータ104における楽音波形の際必
要な各種のデータ、すなわち前述した(4)〜(C)の
各データ等が記憶されてい.る。ウエイブジエネレータ
104は前述した基本原理に基づいて楽音波形を形成す
るもので、データボート107および楽音波形形成部1
08から構成されている。 なお、データボート107の詳細.を第4図に、楽音波
形形成部108の詳細を第5図〜第7図に示す。このウ
エイブジエネレータ104は、この実施例では16チャ
ンネル(第0チャンネルCHO〜第15チャンネルCH
l5)の楽音波形演算糸を有し、16の楽音波形を同時
に形成できるようになつている。ただし、楽音波形を前
記(1)式に基づいて演算する演算部および前述したサ
インテーブルは各々1回路であり、これらの演算部およ
びサインテーブルを時分割によつて使用する二うになつ
ている。次に、第4図〜第7図に示すウエイブジエネレ
タ104を詳細に説明する。 )概略動作 第3図に示すキー群102のいずれかのキーが押下され
ると、キーアサイナ103がこれを検知し、押下された
キーの発音を第0〜第b発音チャンネルCHO〜CHl
5の内の空いているチャンネルに割当てる。 次にキーアサイナ103は、押下されたキーに対応し、
かつ音色レバー101の設定状態に対応する楽音形成用
データ(70W0RD)をROMlO6から読出し、第
4図に示す増分値データメモl川1、初期値データメモ
リ13、セグメントデータメモリ15へ転送する。この
転送が終了すると、次に、発音を割当てたチャンネルの
発音開始を指示するスタートコマンドを出力する。この
スタートコマンドは、第5図に示すスタートコマンドレ
ジスタ30に読込まれる。スタートコマンドレジスタ3
0にスタートコマンドが読込まれると、次のクロックパ
ルスINITCLK(第8図参照)の立上り時点から2
56μSec(INITCLKの1周期)の間に、第4
図のメモリ11,13,15内のデータが第6図に示す
エンベロープ演算メモリ54、位相演算メモリ55、エ
ンベロープ増分値メモリ66、位相増分値メモリ67、
セグメントカウントメモリ76へ転送される。そして、
この転送が終了した時点以降楽音波形演算が行われる。
この楽音波形演算においては、次の3系統の演算が並列
的に行われる。 (1)セグメント演算 この演算は第6図のセグメントカウントメモリ76、そ
の下部の回路および第5図のセグメントメモリ22等に
よつて行われるもので、セグメントカウントメモリ76
内のセグメントデータに基づいて第2図に示すセグメン
ト0〜7の各時間を順次計測し、この計測結果に応じて
、第5図のセグメントメモリ22から現在実行中のセグ
メント番号を逐次出力する。 このメモリ22から出力されるセグメント番号に応じて
前述した第1表および第2表に示す各増分値データが選
択される。(Ii)エンベロープおよび位相演算 この演算は、前述した第(5)〜第(7)式および第
(2)〜第(4)式の演算であり、第6図に示すエンベ
ロープ演算メモリ5牡位相演算メモリ55、これらのメ
モリ54,55の下部に示される回路およびエンベロー
プ増分値メモリ66位相増分値メモリ67によつて行わ
れる。 そして、第(5)〜第(7)式の各演算結果が第6図下
部に示すENVDATAl5〜0として第7図の楽音演
算回路へ逐次供給され、また第(2)〜第(4)式の各
演算結果が第6図下部に示すFREQDATAl5〜0
として第7図の楽音演算回路へ逐次供給される。(Ii
O楽音波形演算 この演算は、前述した第(1)式の演算であり、第7
図に示す楽音演算回路によつて行われる。 この楽音演算回路は、マイクロプログラムメモリ47内
のマイクロ命令に従い、上述したENVDATAl5〜
0およびFREQDATAl5〜0を用いて楽音波形演
算を行なう。 次に、楽音の終了は次の様にして行われる。 キー群102の押下されていたキーが離鍵されると、キ
ーアサイナ103が、離鍵されたキーの発音割当てが行
われているチャンネルの発音終了を指示するデイケイコ
マンドまたはダンプ5コマンドを出力する。デイケイコ
マンドは第5図のデイケイコマンドレジスタ38に読込
まれ、またダンプコマンドはダンプコマンドレジスタ4
2に読込まれる。デイケイコマンドがキーアサイナ10
3から出力されると、その時の,楽音波形演算がセグメ
ント0〜4のどのセグメントにある場合でも、強制的に
セグメント5へ移行され、以降セグメント5〜7の楽音
波形演算が行われる。また、その時の楽音波形演算がセ
グメント5〜7のいずれかにある場合は、そのまま各セ
グメントの波形演算が順次実行される。一方、ダンプコ
マンドがキーアサイナ103から出力された場合は、そ
の時の波形演算がどのセグメントにある場合でも、楽音
が一定のスピードで急速に減衰する。次に、上述した各
動作および各動作に係る構成について説明する。 (2)メモリ11,13,15の書込み 第4図において、マスタクロック発生器1は回路各部で
使用される4種類のクロックパルスMCLKl,MCL
K2,MCLK3,INITCLKを発生する回路であ
る。 第8図に、これらのクロックパルスMCLKl〜INI
TCLKの波形および相互関係を示す。マスタカウンタ
2はマスタクロックMCLKlに従つてカウント動作を
行う10ビットのバイナリイカウンタであり、そのカウ
ント出力はアドレス信号1A5〜0、ISA9〜6とし
て出力される。ここで、アドレス信号IA5〜0はカウ
ント出力の第5ビット〜第0ビット(下位6ビット)、
アドレス信号1SA9〜6はカウント出力の第9ビット
〜第6ビット(上位4ビット)である。バイブラインレ
ジスタ3はクロックパルスMCLKlによつてトリガさ
れる、言い換えればクロックパルスMCLKlのタイミ
ングで入力データを読込む10ビットのレジスタである
。 すなわち、このバイブラインレジスタ3はマスタカウン
タ2の出力をクロックパルスMCLKlの1周期(25
0r1sec:以下この時間をベースクロックタイムと
称する)遅延させて出力する。 このバイブラインレジスタ3の出力は、アドレス信号P
ISA5〜0(下位6ビット)、PIA9〜6(上位4
ビット)として出力される。アドレスデコーダバッファ
10は、キーアサイナ103(第3図)から出力されて
アドレスバス17を介して供給されるアドレス信号が一
時記憶される10ビットのレジスタである。増分値デー
タメモリ11は、キーアサイナ103から出力されてデ
ータバス18を介して供給される増分値データ(前記第
1表および第2表参照)が書込まれるメモリであり、第
9図に示すように、チャンネルCHO〜チャンネルCH
l5の各々に対応する記憶エリアを有している。そして
、例えばチャンネルCHOに発音が割当てられた場合は
、第1表および第2表に示す48W0RDの増分値デー
タがキーアサイナ103から出力され、第9図のチャン
ネルCHOに対応するエリア内に書込まれる。初期値デ
ータメモリ13は、キーアサイナ103から出力される
初期値A4T,lllNT9l2!NT9ω01NT9
ω11NT9ω2!NTが書込まれるメモリであり、第
10図に示すようにチャンネルCHO〜CHl5の各々
に対応するエリアを有している。セグメントデータメモ
リ15は、キーアサイナ103から出力されるセグメン
トデータ、すなわちレイトカウントデータRCDO−R
CD7およびエンベロープカウントデータECDO上C
D7が書込まれるメモリであり、第11図に示すように
、チャンネルCHO〜CHl5の各々に対応するエリア
を有ている。データセレクタ4,6,8は各々、入力端
子AまたはBのデータの一方を選択的に出力する回路て
あり、キーアサイナ103から出力されるメモリ選択信
号MSに応じて上記選択を行う。メモリ選択信号MSは
3ビットの信号であり、その第0ビットがデータセレク
タ4および図示は省略しているがメモリ11へ供給され
、第1ビットがデータセレクタ6およびメモリ13へ、
また第2ビットがデータセレクタ8およびメモリ15を
供給される。そして、上記信号MSの第0ビットが゜゜
1゛になると、データセレクタ4が入力端子Bのデータ
(アドレス信号)を選択して出力し、また、メモリ11
がデータ書込み可能状態となる。信号MSの第1ビット
、第2ビットが各々“1゛になつた場合は、データセレ
クタ6,8、メモリ13,15が同様に動作する。アド
レスバッファ5,7,9はバッファ増幅器であり、また
、バッファレジスタ12,14,16は各々、入力され
るデータをベースクロックタイム(250r1sec)
遅延させて出力するレジスタである。いま、第3図に示
すキー群102のいずれかのキーが押下され、このキー
操作に応じて、キーアサイナ103が押下キーの発音を
例えばチャンネルCHOに割当てたとする。 この場合、キーアサイナ103は、該押下キーに関する
第1表、第2表の各増分値データを、第9図のチャンネ
ルCHOのエリアの各アドレスを示すアドレス信号と共
に順次出力し、またこの時同時にメモリ選択信号MS“
00F゛(第0ビットが゛゜1゛)を出力する。キーア
サイナ103から出力されたアドレス信号はアドレスバ
ス17を介してアドレスデコーダバッファ10内に順次
書込まれ、この書込まれたアドレス信号がデータセレク
タ4およびアドレスバッファ5を介してメモリ11へ順
次供給される。これにより、データバス18を介してメ
モリ11へ供給される増分値データが第9図に示すチヤ
ンネノ顎HOに対応するエリア内に順次、図に示す状態
で書込まれる。次に、キーアサイナ103は、同様にし
て初期値データおよびセグメントデータをアドレス信号
およびメモリ選択信号MSと共に順次出力する。これに
より、第10図に示すメモリ13、第11図に示すメモ
リ15のチャンネルCHOに対応する各エリア内に各デ
ータが順次図に示す状態で書込まれる。()メモリ11
,13,15内のデータをメモリ54,55,66,6
7,76(第6図)へ転送第12図イ、口は各々クロッ
クパルス MCLKl,INITCLKの波形を示す図、ハ、二は
第4図のマスタカウンタ2から出力されるアドレス信号
1A5〜0およびISA9〜6を示す図、ホ、へは各々
第4図のバイブラインレジスタ3から出力されるアドレ
ス信号PIA5〜0およびPISA9〜6を示す図であ
る。 この図に示すように、アドレス信号1A5〜0およびI
SA9〜6は共に、クロックパルスINITCLKの立
上りにおいてROJとなる。また、アドレス信号PIA
5〜0およびPISA9〜6は各々、アドレス信号1A
5〜0およびISA9〜6を1ベースクロックタイム(
250nsec)遅延された信号となる。第12図卜は
チャンネルアドレス信号ClIA3〜0を示す図である
。 このチャンネルアドレス信号CHA3〜0は第7図に示
すマイクロプログラムメモリ47から出力される信号で
あり、第12図卜に示すように、アドレス信号1A5〜
0がRO〜3ョの時ROョ、R4〜7.Jの時RL..
r8〜11Jの時R2J・・R6O〜63Jの時Rl5
Jとなる4ビットの信号である。このチャンネルアドレ
ス信隼]ハ3〜0の各値はチャンネルCHO〜CHl5
に対応しており、例えばチャンネルアドレス信号CHA
3〜0がROJの時は、チャンネルCHOの処理が行わ
れ、またRl5Jの時はチャンネルCHl5の処理が行
われる。そして、メモリ11,13,15内のデータを
メモリ54〜76へ転送する場合は上記の各アドレス信
号が用いられる。次に、メモリ11,13,15内の各
データの読出しについて説明する。 これらのメモリ11,13,15内の各データは、前述
したデー夕書込の場合を除き常時並列に読出されている
。すなわち、前述したデータ書込みの場合以外は、メモ
リ選択信号MSが゜“0,0,0゛となり、したがつて
データセレクタ4,6,8が各々入力端子Aのデータを
出力する。この結果、マスタカウンタ2から出力される
アドレス信号1A5〜0およびISA9〜6がデータセ
レクタ4,6,8、アドレスバッファ5,7,9を介し
てメモリ11,13,15の各アドレス端子ADへ供給
され、これにより、メモリ11,13,15内の各デー
タが逐次読出される。ただし、メモリ11へ供給される
アドレス信号はIA5〜0,ISA9〜6であるが、メ
モリ13へ供給されるアドレス信号はIA5〜0および
ISA6(マスタカウンク2の出力の第6ビットの信−
号)であり、またメモリ15へ供給されるアドレス信号
はIA5〜1 (マスタカウンタ2の出力の第1〜第5
ビットの信号)およびISA8〜6(同第6〜第8ビッ
トの信号)である。次に、各メモリ11,13,15内
のデータ,の読出し過程を詳述する。 (1) メモリ11 まず、アドレス信号1A5〜0として 10.J,ISA9〜6としてROョが供給されると、
第9図に示すデータΔ110(イ)〕が読出され(第1
2図チ参照)、次いてIA5〜0としてRljIsA9
〜6としてROョが供給されると、第9図のデータΔ1
20〔1〕が読出され、 IA5〜0として163J.
.ISA9〜6としてROJが供給されると、データΔ
氏〔63〕が読出される。 すなわち、ISA9〜6が70Jの楊合は各チャンネル
CHO〜CHl5のセグメント0のエンベロープ増分値
データ(Δ110,Δ120,ΔAO)が読出される。
次に、ISA9〜6がr1ョになると、IA5〜0がR
O〜Bョにわたつて変化する間に、各チャンネルCHO
〜CHl5のセグメント1のエンベロープ増分値データ
Δ111〔〔〕,Δ121〔1a〕・・・ΔA1〔63
a〕が読出され(第12図チ参照)、以下同様にして各
エンベロープ増分値データが順次読出される。次に、I
SA9〜6が18ョ(6“1000゛)になると、IA
5〜0がRO〜63.jにわたつて変化する間に各チャ
ンネルCHO〜CHl5のセグメント0の位相増分値デ
ータ(Δω10,Δω9,Δω00)が読出され、以下
同様に、各位相増分値データが順次読出される。 以上の過程から明らかなように、アドレス信号1SA8
〜6の各値の各々はセグメント0〜7に対応し、また、
アドレス信号1SA9の6′0″,′6r3は各々第9
図に示すエリアEO,Elに対応している。 そして、上記過程により読出された各データはバツハレ
ジスタ12(第4図)により1ベースクロックタイム遅
延されて出力される(第12図り参照)。l) メモリ
13 アドレス信号1SA6が“゜0゛の楊合は、アドレス信
号1A5〜0がRO〜63ョにわたつて変化する間に第
10図に示すデータ111NT
[Field of Industrial Application] The present invention relates to an improvement of an electronic musical instrument using a sound assignment method. [Prior Art] An electronic musical instrument using the sound assignment method includes a wave generator having a plurality of musical tone generation channels, and an assigner that assigns the sound of a pressed keyboard key to each channel of the wave generator. be done. [Problems to be Solved by the Invention] By the way, in conventional electronic musical instruments of this type, the assigner and the wave generator are directly connected, so the configuration of the wave generator cannot be easily changed. ,
Since both need to operate synchronously, there are design constraints. Furthermore, although the assigner and the wave generator are usually constructed of 151 separate chips, the above-mentioned conventional electronic musical instrument has the disadvantage that the number of wires between the two chips increases. [
Means for Solving the Problems] The present invention has been made to solve the above-mentioned drawbacks, and in accordance with the assignment of sounds to each channel, the assigner is configured to collect frequency data and information regarding the assigned sounds. The wave generator is configured to sequentially output the envelope data to the bus for each channel, and the wave generator is configured to store the frequency data and the envelope data sent to the bus for each channel, respectively; a first calculating means for calculating the frequency data stored in the storage means for each channel to form phase data for each channel and outputting the same in a time-division manner; a second calculation means that calculates envelope waveform data for each channel and outputs it in a time-division manner; It is characterized by comprising a tone waveform forming means for forming a tone waveform in a time-division manner. [Embodiment] Hereinafter, an embodiment of the present invention will be described in detail with reference to the drawings. First, the basic principle of tone waveform formation used in this embodiment will be explained. First, in this embodiment, a musical sound waveform is formed digitally based on the frequency modulation calculation formula y=ASIN(ω. In equation (1), A determines the amplitude of the musical sound waveform. ωo is an element that determines the carrier wave frequency in frequency modulation, and ω1, ω2 and 11,
11 is an element that determines the frequency and amplitude of a modulated wave in frequency modulation. FIG. 1 is a diagram showing an example of a basic circuit configuration when forming a tone waveform based on the above equation (1), and in this figure, ACCl to ACC3 are all accumulators. These accumulators ACCl to ACC3 each accumulate phase increment values Δω1, Δω2, and Δωo supplied to each input terminal in accordance with a clock pulse of a constant period, and sequentially output the accumulated results. Both sine tables SINl and SIN2 are memories that store each instantaneous value of the sine waveform,
When the outputs of the accumulators ACCl and ACC2 are respectively supplied as address signals, the instantaneous values stored in the addresses corresponding to the same address signals are read out and sent to the multipliers Ml and M.
2, respectively. In the above configuration, for example, each instantaneous value of the sine wave for exactly one period is sequentially read from the sine table SINl during the period from when the accumulator ACCl starts accumulation from -RO to overflow. . In this case, the accumulation speed of the accumulator ACCl is constant because the frequency of the clock pulse is constant, and therefore, if the phase increment value Δω1 is constant, the sine table S
The period of the sine wave output from INl is constant. In other words, by changing the value of the phase increment value Δω1, the period (frequency) of the sine wave output from the sine table SINl can be changed. for example,
If the phase increment value Δω1 is made large, the period of the sine wave becomes small, and if the increment value Δω1 is made small, the period of the sine wave becomes large. Expressing the cumulative sum of
0INT is the initial value of each phase O Returning to FIG. It multiplies, and its output is sent to adder circuit A.
Supplied to U. Similarly, the multiplier M2 multiplies the output of the sine table SIN2 by the output of the numerical value generation circuit 12 that generates the 12th value in equation (1), and outputs the multiplication result to the addition circuit AU. Adder circuit AU includes multipliers Ml, M
2. Add each output of the accumulator ACC3, and supply the addition result to the sine table SIN3 as an address signal. Sign table SIN3 is the above-mentioned sign table SIN.
It has the same configuration as 1 and 2, and its output is supplied to the multiplier circuit M3. Multiplier M3 multiplies the output of sine table SIN3 by the output of numerical value generation circuit A that generates the value of A in equation (1), and outputs the multiplication result. As is clear from the above description, the output of each block shown in FIG. 1 corresponds to each of the following elements in equation (1). That is, the waveform shown in equation (1) is obtained as the output of the multiplier M3. Note that the output of the multiplier M3 is, of course, digital data. Therefore, in order to obtain a musical tone waveform, it is necessary to convert this data into an analog waveform using a D/A (digital/analog) converter. The basic configuration of the tone waveform forming circuit has been described above. Next, the process of forming tone waveforms in this embodiment will be described in more detail. In this embodiment, A, ω0, 11, 12 of the above equation (1)
, ω1, and ω2 are changed appropriately between the generation of the musical tone and the stop of the musical tone, thereby making the musical tone formed closer to the musical tone of a natural musical instrument. That is, in this embodiment, if the amplitude envelope of the musical sound waveform is shown in FIG.
2 is divided into eight segments 0 to 7, and each segment has the above, A, and ω. , 11, . . . are set as separate values (which may be the same value in some cases), and the tone waveform of equation (1) is formed based on the set values. In addition, in this case, within each segment, the above A, ll, l
Each value of 2 changes, and as a result, the musical tone waveform formed also changes sequentially within each segment 0 to 7. Changes in the values of A, 11, and 12 within each segment 0 to 7 are performed based on the following equations. Note that in these equations, ΔA, Δ11, and Δ12 are the increment values of A, ll, and l2 in equation (1), respectively, and A! N.T.
,ll! Nτ912! NT is the initial value of A9ll9l2.O Also, the time width of each segment 0 to 7 is
It is determined by segment data to be described later, that is, late count data RCDO-RCD7 and envelope count data ECDO-CD7. As is clear from the above, in this embodiment, in order to generate one tone waveform (tone waveform generated by one key operation), the following data (total 70W0RD: 1W0RD=16 bits). (4) Incremental value shown in Tables 1 and 2 (48W0RD
) (B) Initial value (6W0RD) A! NT9ll! NT9l2engineeringNTωO! NT9ω1! NT9ω21NT(C) Segment data (16W0RD) Late count data RC
DO-RCD7 Envelope Count Data ECDO Upper CD7 Therefore, in this embodiment, the above-mentioned (4) to (C
) are set in advance in the memory, and musical tones are formed by reading each data in the memory. For example, in the case of an electronic organ with one type of tone and 44 keys, each of the above-mentioned data is set in the memory for 44 countries. The above is the basic principle of musical tone formation used in this embodiment. Next, the electronic organ according to this embodiment will be explained in detail. FIG. 3 is a block diagram showing the configuration of the electronic organ. In this figure, reference numeral 101 is a tone lever for setting the tone, and 102 is a group of keys provided on the keyboard. In this embodiment, the tone lever 101 is composed of 1C@ levers, and w tone switches are provided corresponding to each lever. The output of each tone switch is then supplied to the key assigner 103, respectively. In this embodiment, the key group 102 is composed of 44 keys and 44 key switches corresponding to each key, and the output of each key switch is supplied to a key assigner 103. The key assigner 103 detects the currently set tone based on each output of the tone switch described above, and detects a newly pressed key or a released key based on the output of the key switch described above. do. When a newly pressed key is detected, the musical tone generation of the key is assigned to one of the channels (described later) of the wave generator 104 according to the present invention, and when a released key is detected. commands the channel to which the same key is assigned to stop sound generation. This key assigner 103 includes =RArVl (random access memory) 105 and ROM (read-on memory) 106.
are connected to each other. The RAMIO5 stores various data tables, data files, etc. used in channel assignment, and also stores the ROM,
6 includes programs used for detecting tone switches, detecting key presses and key releases, channel assignment, etc., and various data necessary for creating musical sound waves in the wave generator 104, that is, the above-mentioned (4) ) to (C) are stored. Ru. The wave generator 104 forms a musical sound waveform based on the basic principle described above, and is connected to the data boat 107 and the musical sound waveform forming section 1.
It consists of 08. In addition, the details of the data boat 107. is shown in FIG. 4, and details of the tone waveform forming section 108 are shown in FIGS. 5 to 7. This wave generator 104 has 16 channels (0th channel CHO to 15th channel CH) in this embodiment.
It has a tone waveform calculation string 15), and is designed to be able to simultaneously form 16 tone waveforms. However, the arithmetic section for calculating the tone waveform based on the equation (1) and the sine table described above each have one circuit, and these arithmetic sections and the sine table are used in two ways in a time-sharing manner. Next, the wave generator 104 shown in FIGS. 4 to 7 will be explained in detail. ) Outline of operation When any key in the key group 102 shown in FIG.
Allocate to an empty channel among 5. Next, the key assigner 103 corresponds to the pressed key,
The tone forming data (70W0RD) corresponding to the setting state of the tone lever 101 is read out from the ROM 106 and transferred to the incremental value data memory 1, initial value data memory 13, and segment data memory 15 shown in FIG. When this transfer is completed, a start command is output that instructs the channel to which sound generation is assigned to start sound generation. This start command is read into the start command register 30 shown in FIG. Start command register 3
When the start command is read at 0, 2 starts from the rising edge of the next clock pulse INITCLK (see Figure 8).
During 56 μSec (one period of INITCLK), the fourth
The data in the memories 11, 13, and 15 shown in the figure includes the envelope calculation memory 54, phase calculation memory 55, envelope increment value memory 66, phase increment value memory 67,
Transferred to segment count memory 76. and,
Tone waveform calculation is performed after this transfer is completed.
In this musical sound waveform calculation, the following three systems of calculations are performed in parallel. (1) Segment operation This operation is performed by the segment count memory 76 shown in FIG. 6, the circuit below it, the segment memory 22 shown in FIG.
The time of each of segments 0 to 7 shown in FIG. 2 is sequentially measured based on the segment data in FIG. 2, and the segment number currently being executed is sequentially output from the segment memory 22 shown in FIG. According to the segment number output from the memory 22, each of the incremental value data shown in the first and second tables described above is selected. (Ii) Envelope and phase calculation This calculation is the calculation of the above-mentioned equations (5) to (7) and equations (2) to (4), and the envelope calculation memory 5 phase calculation shown in FIG. This is done by an arithmetic memory 55, a circuit shown below these memories 54, 55, an envelope increment value memory 66 and a phase increment value memory 67. Then, the calculation results of equations (5) to (7) are sequentially supplied to the musical tone calculation circuit of FIG. 7 as ENVDATA15 to 0 shown in the lower part of FIG. The results of each calculation are shown in the lower part of Figure 6 as FREQDATA15~0.
The signal is sequentially supplied to the musical tone calculation circuit shown in FIG. (Ii
O musical sound waveform calculation This calculation is the calculation of the above-mentioned formula (1), and the seventh
This is performed by the musical tone calculation circuit shown in the figure. This musical tone arithmetic circuit operates according to the micro instructions in the micro program memory 47.
0 and FREQDATA15 to 0 are used to perform musical waveform calculations. Next, the musical tone ends as follows. When a pressed key in the key group 102 is released, the key assigner 103 outputs a Decay command or a Dump 5 command that instructs the end of the sound generation of the channel to which the released key is assigned. . The Decay command is read into the Decay command register 38 in FIG. 5, and the dump command is read into the Dump command register 4.
2. DAYK command is key assigner 10
When the tone waveform calculation is outputted from segment 3, no matter which of segments 0 to 4 the musical tone waveform calculation is in, it is forcibly transferred to segment 5, and thereafter the tone waveform calculations of segments 5 to 7 are performed. Further, if the musical waveform calculation at that time is in one of segments 5 to 7, the waveform calculation for each segment is executed sequentially. On the other hand, when a dump command is output from the key assigner 103, the musical tone rapidly decays at a constant speed, regardless of which segment the waveform calculation is performed at that time. Next, each of the above-mentioned operations and the configuration related to each operation will be explained. (2) Writing to memories 11, 13, 15 In FIG. 4, the master clock generator 1 generates four types of clock pulses MCLKl, MCL used in each part of the circuit.
This is a circuit that generates K2, MCLK3, and INITCLK. In FIG. 8, these clock pulses MCLKl~INI
TCLK waveforms and interrelationships are shown. Master counter 2 is a 10-bit binary counter that performs a counting operation according to master clock MCLKl, and its count output is output as address signals 1A5-0 and ISA9-6. Here, address signals IA5-0 are the 5th bit to 0th bit (lower 6 bits) of the count output,
Address signals 1SA9-1SA6 are the 9th bit to 6th bit (upper 4 bits) of the count output. The vibe line register 3 is a 10-bit register that is triggered by the clock pulse MCLKl, in other words, it reads input data at the timing of the clock pulse MCLKl. That is, this vibe line register 3 converts the output of the master counter 2 into one period (25
0r1 sec: This time is hereinafter referred to as base clock time) and is output with a delay. The output of this vibe line register 3 is the address signal P
ISA5~0 (lower 6 bits), PIA9~6 (higher 4 bits)
bits). Address decoder buffer 10 is a 10-bit register in which an address signal output from key assigner 103 (FIG. 3) and supplied via address bus 17 is temporarily stored. The incremental value data memory 11 is a memory in which the incremental value data (see Tables 1 and 2) output from the key assigner 103 and supplied via the data bus 18 is written, as shown in FIG. Channel CHO ~ Channel CH
It has a storage area corresponding to each of 15. For example, if the sound is assigned to channel CHO, the increment value data of 48W0RD shown in Tables 1 and 2 is output from the key assigner 103 and written in the area corresponding to channel CHO in FIG. . The initial value data memory 13 stores the initial values A4T, lllNT9l2! output from the key assigner 103. NT9ω01NT9
ω11NT9ω2! This is a memory in which NT is written, and as shown in FIG. 10, it has areas corresponding to each of channels CHO to CH15. The segment data memory 15 stores segment data output from the key assigner 103, that is, late count data RCDO-R.
CD7 and envelope count data ECDO top C
D7 is a memory to which data is written, and as shown in FIG. 11, it has areas corresponding to each of channels CHO to CH15. Each of the data selectors 4, 6, and 8 is a circuit that selectively outputs one of the data at the input terminal A or B, and performs the above selection in response to the memory selection signal MS output from the key assigner 103. The memory selection signal MS is a 3-bit signal, the 0th bit of which is supplied to the data selector 4 and the memory 11 (not shown), the 1st bit is supplied to the data selector 6 and the memory 13,
The second bit is also supplied to the data selector 8 and memory 15. Then, when the 0th bit of the signal MS becomes ゜゜1゛, the data selector 4 selects and outputs the data (address signal) of the input terminal B, and the memory 11
becomes ready for data writing. When the first and second bits of the signal MS each become "1", the data selectors 6 and 8 and the memories 13 and 15 operate in the same way.The address buffers 5, 7 and 9 are buffer amplifiers, In addition, each of the buffer registers 12, 14, and 16 receives input data within a base clock time (250r1sec).
This is a register that outputs with a delay. Now, assume that any key in the key group 102 shown in FIG. 3 is pressed, and in response to this key operation, the key assigner 103 assigns the sound of the pressed key to, for example, channel CHO. In this case, the key assigner 103 sequentially outputs each incremental value data of Tables 1 and 2 regarding the pressed key together with an address signal indicating each address of the area of channel CHO in FIG. Selection signal MS“
Outputs 00F゛ (0th bit is ゛゜1゛). The address signals output from the key assigner 103 are sequentially written into the address decoder buffer 10 via the address bus 17, and the written address signals are sequentially supplied to the memory 11 via the data selector 4 and address buffer 5. Ru. As a result, the incremental value data supplied to the memory 11 via the data bus 18 is sequentially written in the area corresponding to the chin HO shown in FIG. 9 in the state shown in the figure. Next, the key assigner 103 similarly sequentially outputs the initial value data and segment data together with the address signal and memory selection signal MS. As a result, each data is sequentially written in each area corresponding to the channel CHO of the memory 13 shown in FIG. 10 and the memory 15 shown in FIG. 11 in the state shown in the figure. ()Memory 11
, 13, 15 to memories 54, 55, 66, 6
Transferred to 7, 76 (Fig. 6) Fig. 12 A. Figure 12 shows the waveforms of clock pulses MCLKl and INITCLK, respectively. Figures ISA9-6, E, and F are diagrams showing address signals PIA5-0 and PISA9-6 respectively output from the vibe line register 3 of FIG. 4. As shown in this figure, address signals 1A5-0 and I
Both SA9-6 become ROJ at the rising edge of clock pulse INITCLK. In addition, the address signal PIA
5-0 and PISA9-6 are each address signal 1A
5-0 and ISA9-6 with 1 base clock time (
The signal is delayed (250 nsec). FIG. 12 is a diagram showing channel address signals ClIA3-0. These channel address signals CHA3-0 are signals output from the microprogram memory 47 shown in FIG. 7, and as shown in FIG.
When 0 is RO~3, RO is R4~7. When J.RL. ..
R2J when r8~11J... Rl5 when R6O~63J
This is a 4-bit signal representing J. Each value of this channel address
For example, the channel address signal CHA
When 3-0 is ROJ, channel CHO processing is performed, and when R15J, channel CH15 processing is performed. When transferring data in the memories 11, 13, and 15 to the memories 54 to 76, each of the above address signals is used. Next, reading of each data in the memories 11, 13, and 15 will be explained. Each data in these memories 11, 13, and 15 is always read out in parallel except in the case of data writing described above. That is, except in the case of data writing described above, the memory selection signal MS becomes "0, 0, 0", and therefore the data selectors 4, 6, and 8 each output the data of the input terminal A. As a result, Address signals 1A5-0 and ISA9-6 output from the master counter 2 are supplied to each address terminal AD of the memories 11, 13, 15 via data selectors 4, 6, 8 and address buffers 5, 7, 9, As a result, each data in the memories 11, 13, and 15 is read out sequentially.However, the address signals supplied to the memory 11 are IA5-0 and ISA9-6, but the address signals supplied to the memory 13 are IA5-0 and ISA6 (6th bit signal of master count 2 output)
The address signals supplied to the memory 15 are IA5-1 (1st to 5th outputs of the master counter 2).
bit signals) and ISA8 to ISA6 (sixth to eighth bit signals). Next, the process of reading data in each memory 11, 13, 15 will be described in detail. (1) Memory 11 First, address signals 1A5-0 are set to 10. When RO is supplied as J, ISA9~6,
The data Δ110 (a) shown in FIG.
2), then RljIsA9 as IA5~0
When RO is supplied as ~6, the data Δ1 in FIG.
20[1] is read and 163J. is read as IA5-0.
.. When ROJ is supplied as ISA9-6, data Δ
Mr. [63] is read out. That is, when ISA9-6 is 70J, the envelope increment value data (Δ110, Δ120, ΔAO) of segment 0 of each channel CHO-CH15 is read.
Next, when ISA9-6 becomes r1yo, IA5-0 becomes R
While changing from O to B, each channel CHO
Envelope increment value data of segment 1 of ~CHl5 Δ111[[], Δ121[1a]...ΔA1[63]
a] is read out (see FIG. 12, H), and in the same manner, each envelope increment value data is sequentially read out. Next, I
When SA9~6 becomes 18jo (6"1000゛), IA
5-0 is RO-63. During the change over j, phase increment value data (Δω10, Δω9, Δω00) of segment 0 of each channel CHO to CHl5 are read out, and in the same manner, each phase increment value data is sequentially read out. As is clear from the above process, address signal 1SA8
Each of the values of ~6 corresponds to segments 0-7, and
6'0'' and '6r3 of the address signal 1SA9 are the 9th
This corresponds to areas EO and El shown in the figure. Each data read out through the above process is delayed by one base clock time and output by the batch register 12 (FIG. 4) (see FIG. 12). l) When the address signal 1SA6 of the memory 13 is "0", the data 111NT shown in FIG.

〔0〕〜AINT〔63
〕(エンベロープ初期値データ)が読出され、アドレス
信号1SA6が″r′の場合は、アドレス信号1A5〜
0がRO〜63Jにわたつて変化する間に、第10図の
データω10NTC01〕〜ω01NT〔6311〕(
位相初期値データ)が読出される(第12図チ参照)。 そして、読出された各データはバッファレジスタ14に
よつて1ベースクロックタイム遅延されて出力される(
第12図リ参照)。110メモリ15 アドレス信号1SA8〜6がROョの場合は、アドレス
信号1A5〜1がRO〜31Jにわたつて変化する間に
第11図に示すデータRCDOCO〕〜ECDO〔31
)が読出され、アドレス信号1SA8〜6がr1ョの場
合は、アドレス信号1A5〜1がRO〜3Lにわたつて
変化する間に第11図のデータRCDl〔〔〕〜ECD
l〔31a〕が読出され、以下、同様にして各セグメン
トデータが順次読出される(第12図ヌ参照)。 すなわち、メモリ15の読出しは2ベースクロックタイ
ム毎に行われ、また、アドレス信号1SA8〜6の各値
は各々セグメント0〜7に対応している。そして、メモ
リ15から読出された各データはバッファレジスタ16
によつて1ベースクロックタイム遅延されて出力される
(第12図ル参照)。次にメモリ11,13,15内の
データがメモリ54,55,66,67,76へ転送さ
れる過程を説明する。 いま、キーアサイナ103が押下キーの発音をチャンネ
ルCHOに割当てたとする。この場合、前述したように
、キーアサイナ103が発音すべき楽音の音高および音
色に対応する各種データを出力してメモリ11,13,
15のチャンネルCHOに対応するエリアに書込み、次
いでスタートコマンド“400・・・01″(16ビッ
ト)を出力する。このスタートコマンドにおける第0ビ
ットの゜゜1゛がチャンネルCHOのスタートを指示し
ている。このスタートコマンドが出力されると、以後、
第9図に示すメモI川1のエリアEOの内のチャンネル
CHOに対応する各エンベロープ増分値データが各々第
6図のエンベロープ増分値メモリ66へ転送され、また
、エリアE1内のチャンネルCHOに対応する各位相増
分値データが各々第6図の位相増分値メモリ67へ転送
され、また、第10図に示すメモリ13内のチャンネル
CHOに対応する各エンベロープ初期値データ5(11
0N,,12,N,,A,N,)がエンベロープ演算メ
モリ54へ、各位相初期値データ(ω11NT,ω21
NT9ω0INT)が位相演算メモリ55へ各々転送さ
れ、また、第11図に示すメモリ15のチャンネルCH
Oに対応する各セグメントデータがセグメントカウント
メモリ76へ転送される。以下、上記動作について詳述
する。前述したスタートコマンド“゜00・・・01゛
がキーアサイナ103から出力されると、このスタート
コマンドがデータバス18を介して第5図の.”スター
トコマンドレジスタ30(16ビット)に読込まれる。
次に、クロックパルスINITCLKが立上ると、この
立上り時点においてスタートコマンドレジスタ30の出
力データがイニツトレジスタ31内に読込まれ、この読
込まれたデ!ータがイニツトマルチプレクタ34へ供給
される。イニツトマルチプレクタ34は、チャンネルア
ドレス信号CHA3〜0(第12図卜)がROョの時人
力データの第0ビットの信号を出力し、以下、CHA3
〜0がRlJ−Rl5Jの・時各々入力データの第1ビ
ット〜第15ビットの信号を出力する(並直変換を行う
)。すなわち、イニツトレジスタ31に読込まれたデー
タ(スタートコマンド)が6400・・・0r2の場合
、イニツトマルチプレクサ34の出力信号1NIT−1
は第12図オの波形となる。この信号1NIT−1のパ
ルス幅1μSecであり、また、第13図口に示すよう
に、クロックパルスINITCLK(第7313図イ)
の1周期(256μSec)間に托回発生する。そして
この信号1NIT−1が16回発生する際にメモリ54
〜76のデータ書込みが行われる。この信号1NIT−
1はフリップフロップ37(第5図)のセット入力端子
Sへ供給される。フリップフロップ37はクロックパル
スMCLKlによつてトリガされるもので、信号1NI
T−1を1ベースクロックタイム遅延させ、信号1NI
T(第12図ワ)として出力する。そして、上記信号1
NIT−1およびINITに基づいて、以下の過程でメ
モリ54〜76のデータ書込みが行われる。(1)メモ
リ66,67(第6図) これらのメモリ66,67は各々、第9図のエリアEO
,Elと同一容量のメモリであり、アドレス信号PIA
5〜0(第4図、第12図ホ参照)が下位アドレスとし
て供給され、また、アドレス信号PSA8〜6が上位ア
ドレスとして供給されている。 ここで、アドレス信号PSA8〜6について説明する。 第5図に示すセレクタレジスタ21は、信号1NIT−
1が゜゛0゛の時人力端子Aへ供給されているメモリ2
2の出力データをクロックパルスMCLKlのタイミン
グで読込み、また、信号1NIT−1が“゜1゛の時は
入力端子Bへ供給されているアドレス信号ISA9〜6
(第12図ニ)をROョクロツクパルスMCLKlのタ
イミングで読込む。そして、読込んだ信号をアドレス信
号PSA9〜6として出力する。すなわち、信号1NI
T−1が“1゛となると、アドレス信号1SA9〜6が
セレクタレジスタ21において1ベースクロックタイム
遅延され(したがつてアドレス信号PISA9〜6と同
一の信号となり)、アドレス信号PSA9〜6として出
力される。メモリ66,67へ上位アドレスとして供給
されるアドレス信号PSA8〜6は上述したアドレス信
号PSA9〜6の下位3ビットである。次に、メモリ6
6,67の各リード/ライト端子R/Wには各々アンド
ゲート68,69の出力が供給されている。 また、アンドゲート68,69の各第1入力端へは信号
INITが供給され、アンドゲート68の第2入力端へ
はアドレス信号PSA9がインバータ70を介して供給
され、アンドゲート69の第2入力端へはアドレス信号
PSA9が直接供給されている。 ここで、アドレス信号PSA9は、アドレス信号1SA
9がセレクタレジスタ21(第5図)によつて1ベース
クロックタイム遅延された信号であり(但し、信号1■
NIT−1が゜“1゛の場合)、したがつて、アドレス
信号PSA9が′60合の時は第4図のバッファレジス
タ12から第9図のエリアEO内のデータが出力され、
また、アドレス信号PSA9が66r′の時は、第4図
のバツフアレ1ジスタ12から第9図のエリアF1内の
データが出力される。 さて、クロックパルスINITCLKが6′F9信号に
立上り、次いて第12図ワに符号P1にて示す信号1N
ITが出力されると、その時冫点で信号PSA9が“0
゛であるところから同信号1NITがアンドゲート68
を介してメモリ66のリード/ライト端子R/Wへ供給
される。 この時、第12図りに示すように、第4図のバッファレ
ジスタ12からはチヤンネ,ルCHOの、かつセグメン
ト0のエンベロープ増分値データ(Δ110,Δ120
,ΔAO:第9図)が順次出力され、メモリ66(第6
図)のデータ入力端へ供給されている。したがつて、符
号P1て示す信号1NITが出力されると、上記のエン
ベロープ増分値データがメモニJ66内に書込まれる。
次に、第12図ワに符号P2にて示す信号1NITが出
力されると、チャンネルCHOの、かつセグメント1の
エンベロープ増分値データ(Δ111,Δ121,ΔA
1)がメモリ66に順次書込まれ、以下、信号1NIT
が゜゜1゛信号になる毎に、チャンネルCHOのセグメ
ント2,3・・・7の各エンベロープ増分値データが順
次メモリ66内に書込される。次に第9図のエリアE1
内のデータがバッファレジスタ12(第4図)から順次
出力される時は、前述したようにアドレス信号PSA9
゛が゜゜1゛となり、したがつて、アンドゲート69が
開状態となり、信号INITがメモリ67のリード/ラ
イト端子R/Wへ供給される。この結果、以後信号IN
ITが出力される毎に、チヤンネノL/CHOのセグメ
ント0〜7の各位相増分値データ(Δω109Δω20
9Δω00ゞΔω179Δω219Δω07:第9図)
が順次メモリ67内に書込まれる。 1) メモリ54,55 第4図のバッファレジスタ14から出力された初期値デ
ータは第6図に示すセレクタレジスタ51,52の各入
力端子Aへ供給される。 セレクタレジスタ51,52は各々、アンドゲート51
a,52aの出力が“゜1゛の時人力端子Aのデータを
クロックパルスMCLK3(第8図参照)のタイミング
で読込み、アンドゲート51a,52aの出力が“0゛
の時は、入力端子BのデータをクロックパルスMCLK
3のタイミングで読込む。 アンドゲート51a,52aの各第1入力端へは信号1
NITが供給され、またアンドゲート51aの第2入力
端へはアドレス信号PISA6がインバータ50を介し
て供給され、アンドゲート52aの第2入力端へはアド
レス信号PISA6が直接供給されている。 ここで、アドレス信号PISA6が“゜0゛の時は、第
10図に示すエンベロープ初期値データ(11!NT9
l2lNT9A!NT9)が第4図のバッファレジスタ
14から出力され、アドレス信号PISA6が゜“1゛
の時は第10図の位相初期値データ(ω1!NT9ω2
!NT9ωO!NT)がバッファレジスタ14から出力
される。メモリ54,55は、第14図に示すようにチ
ャンネルCHO〜CHl5の各々に対応するエリアを有
し、また、各エリアが各々4記憶スロット(1スロツト
ニ20ビット)から構成されている。この場合、各エリ
ア内の4つのスロットがアドレス信号PIAl,Oによ
つてアドレスされ、また各エリアがアドレス信号PIA
5〜2によつてアドレスされる。 そして、これらのメモリ54,55はセレクタレジスタ
51,52の出力をクロックパルスMCLKlの立上り
のタイミングで読込む。 しかして、第12図ワに符号P1にて示す信号1NIT
が出力されると、この信号1NITのタイミングにおい
てアドレス信号PISA6が゜゜0゛であることから、
信号1NITがアンドゲート51aを介してセレクタレ
ジスタ51へ供給される。 この結果、上述した信号1NITのタイミングにおいて
バッファレジスタ14(第4図)から出力されるチャン
ネルCHOのエンベロープ初期値データ(111NT,
121NT,A0N,)(第12図り参照)が順次セレ
クタレジスタ51に読込まれ、次いで読込まれた各初期
値データがメモリ54のチャンネルCHOに対応するエ
リア内に順次読込まれる。次に、第12図りに符号P2
にて示す信号INITが出力されると、この時アドレス
信号PISA6が゜゛1゛であることから、同信号IN
ITがアンドゲート51aを介してセレクタレジスタ5
2へ供給される。 この結果、上述した信号1NITタイミングにおいてバ
ッファレジスタ14から出力されるチャンネルCHOの
位相初期値データ(ω1,NT,ω2,NT,ωoぃT
)が順次セレクタレジスタ52に−読込まれ、次いで読
込まれた各初期値データがメモリ55のチャンネルCH
Oに対応するエリア内に順次読込まれる。 以下、信号INlTが出力される毎に上記と全く同じ動
作が繰返される。 (Ii) メモリ76 第4図のバッファレジスタ16から出力されたセグメン
トデータは第6図のセレクタレジスタ75の入力端子A
へ供給される。 セレクタレジスタ75は、上述したセレクタレジースタ
51,52と同一構成であり、信号囚汀4“1゛1の時
クロックパルスMCLK3のタイミングで入力端子Aの
データを読込み、信号1NITが゛0゛の時は入力端子
Bのデータを読込む、セグメントカウントメモリ765
は、第11図に示すメモリ15と同一構成のメモリであ
り、アドレス信号PIA5〜1が下位アドレスとして供
給され、アドレス信号PSM8〜6が上位アドレスとし
て供給され、クロックパルスMCLKlの立上りの夕4
イミングで入力データを読込む。 しかして、第12図ワの符号P1で示す信号1MTが出
力されると、この時点でバッファレジスタ16(第4図
)から出力されるチヤンネノL/CHOの、かつセグメ
ント0のセグメントデータ(レイトカウントデータRC
DOおよびエンベロープカウントデータECDO)セレ
クタレジスタ75に順次読込まれ、次いで、読込まれた
データがセグメントカウンタメモリ76内に順次読込ま
れる。 以下、信号INITが出力される毎にチャンネルCHO
のセグメント1〜7の各セグメントデータが順次メモリ
76内に読込まれる。(4) セグメント演算 上述したメモリ54〜76へのデータ転送は、第12図
に示すクロックパルスINITCLKの1周期間(25
6μSec)において行われる。 そして、次にクロックパルスINITCLKが4“1″
に立上ると、第5図に示すイニツトレジスタ31内のデ
ータ゜゛00・・・01゛がランレジスタ32内に読込
まれる。このランレジスタ32の16の各ビット出力は
各々インバーク36によつて反転され、イニツトレジス
タ31、スタートコマンドレジスタ30の各ビットリセ
ット端子へ各々供給される。これにより、ランレジスタ
32の“1゛のビットに対応するレジスタ30,31の
ビットがリセットされる。また、インバータ36の出力
(16ビット)の内の“゜0゛信号は、スタートコマン
ドレジスタ30の対応するビットの入力を禁止する。ま
た、ランレジスタ32の出力はランマルチプレクサ35
へ供給される。 ランマルチプレクサ35はチャンネルアドレス信号CI
(A3〜0力げ0Jの時ランレジスタ32の第0ビット
信号を出力し、CHA3〜0がr1ョの時ランレジスタ
32の第1ビットの信号を出力し、CHA3〜0力げ1
5Jの時ランレジスタ32の第15ビットの信号を出力
する(並直変換を行う)。 このランマルチプレクサ35の出力は、信号RUN−1
としてフリップフロップ37のリセット端子Rへ供給さ
れる。フリップフロップ37は、信号RUN−1を1ベ
ースクロックタイム遅延させ、信号RUNとして出力す
る。なお第13図ハに信号RUN−1の波形を示す。こ
れらの信号RUN−1およびRUNが出力されると、当
該チャンネル(第13図の例の場合、チャンネルCHO
)のセグメント演算、エンベロープおよび位相演算、楽
音波形演算が行われ、これにより楽音が形成される。ま
たランレジスタ32の出力はバスドライバ33、データ
バス18を介してキーアサイナ103(第3図)へ供給
される。 このランレジスタ32の“゜1゛のビットは楽音形成が
終了した時リセットされ、したがつてランレジスタ32
の出力は現在楽音形成が行われているチャンネルを示し
ている。キーアサイナ103は、このランレジスタ32
の出力によつて、現在のチャンネルにおいて楽音形成が
行われているかを検1知する。次に、セグメント演算に
ついて説明する。 ます、第5図のセグメントメモリ22は、チャンネルC
HO〜CHl5に各々対応する第0〜第15記憶スロッ
ト(1スロツトニ4ビット)を有1L1チャンネルアド
レス信号CHA3〜0(第15図ハ参照)がアドレス端
子ADへ供給され、また、アドレス信号1A5〜0の第
1ビットの信号1A1がリード/ライト端子R/Wへ供
給されている。このセグメントメモリ22の2第0〜第
15記憶スロット内のデータは各々、チャンネルCHO
〜CHl5において現在実行中のセグメントの番号を示
している。例えば第0〜第3記憶スロット内のデータが
各々R3ョ,121r5ョであつた場合は、現在チヤン
ネルニCHO〜CH3の各々においてセグメント3,2
,5の楽音形成が行われていることを示ている。このセ
グメントメモリ22から読出されたデータはセレクタレ
ジスタ21によつて1ベースクロックタイム遅延され、
アドレス信号PSAj9〜6として出力される。そして
、このアドレス信号PSA9〜6の下位3ビットPSA
8〜6がセグメントカウントメモリ76(第6図)のア
ドレス端子AD2へ供給される。なお、このセクメント
メモリ22は初期リセットされる。いま、チャンネルC
HOに発音割当てが行われ、次いでセグメントカウンタ
メモリ76のチャンネルCHOに対応するエリアの書込
みが終了した時点においては、セグメントメモリ22の
チャンネルCHOに対応する第0記憶スロツ1・内のデ
ータがRO.uとなつている。したがつて、信号RUN
−1(第15図ニ)が“1゛に立上り、次いで信号RU
N(第15図ホ)が゜゜1゛となつた時点において、ア
ドレス信号PSA8〜6はROJであり、このデータR
Oョがセグメントカウントメモリ76のアドレス端子A
D2へ供給される。また、同メモリ76のアドレス端子
ADlへは、アドレス信号PlA5〜1(第15図へ)
が供給される。この結果、アドレス信号PIA5〜】が
ROョの時はセグメントカウントメモリ76からチャン
ネルCHOでかつセグメント0に対応するレートカウン
トデータRCDOが読み出され、また、アドレス信号P
IA5〜1がRlJの時はセグメントカウンタメモリ7
6からチャンネルCHOでかつセグメント0に対応する
エンベロープカウントデータECDOが読出され(第1
5図り参照)、分配回路77へ供給される。分配回路7
7は、入力データを信号PIAlに応じて出力端子Aま
たはBから出力する回路てある。セグメントカウンタメ
モリ76からデータRCDOが読出された時点において
、信号PIAl(第15図卜)は゛゜0゛にあり、この
結果、データRCDOは分配回路77の出力端子Bから
出力される。ここで、下記の説明を分かりやすくするた
めに、レートカウントデータCDおよびエンベロープカ
ウントデータECDのデータ内容およびこれらデータR
CD,ECDの処理の概要につき説明する。まず、エン
ベロープカウントデータECDは、例えば第3表に示す
ような16ビットの数値データである。 第3表に示すようなエンベロープカウントデータECD
の初期値から各セグメントにおいてそれぞれ所定の周期
でr1ョを繰返し減算し、その減算結果がROョになつ
たとき当該セグメントが終了して次のセグメントに移る
。 例えば、セグメント0に関するデータECDは、初期値
Rl68ョから所定周期でRl67.J,rl66.J
・r1ョと順次RlJずつ減少し、そしてデータECD
がRO.Jになると、セグメント0が終了する。また、
レイトカウントデータRCDは、例えば第4表に示すよ
うな16ビットのデータであるが、その下位7ビットは
上述したエンベロープカウントデータECDからRlJ
を繰返し減算する周期を示す数値データであり、また、
第7ビットはHOLD信号となつており、さらに、上位
8ビットは下位7ビットて表わされる数値からRlJを
順次減算した時の減算結果を示すデータとなつている。 この場合、HOLD信号とは楽音を同一状態て持続させ
るための制御信号であり、持続系の楽音(オルガン音等
)の場合、レートカウントデータRCD4(セグメント
4に対応するレートカウントデータ)のHOLD信号が
“1゛となる。なお、HOLD信号が“゜1゛となるは
この場合だけである。このレイトカウントデータRCD
の上位8ビットには、最初下位7ビットの数値データが
そのまま移され、その後この数値から一定タイミングで
r′1ョを順次減算した値を示すデータとなる。 例えば、セグメント0では、データRCDの下位7ビッ
トのデータR2lJであるから上位8ビットのデータは
R2lJ,r2Oョ,Rl9ョ・RlJを順次変化する
ことになる。 データRCDの上位8ビットのデータがROJになると
、このとき再び下位7ビットの数値データがそのまま上
位8ビットに移されるとともに、このタイミングでエン
ベロープカウントデータEcD(7)RlJ減算が実行
され、以後これを繰返すようになつてる。このように、
エンベロープカウントデータECDとレートカウントデ
ータRCDとによつて各セグメントの時間を決定するこ
とにより、全体として少ないビット数で各セグメントの
長さを細かく任意に設定でる。なお、以下の説明では、
上記各データECDおよびRCDを7コンプリメントの
データとしているので、RlJの減算はRlJの加算に
よつて行なわれる。さて、分配回路77の出力端子Bか
ら出力されたレートカウントデータRCDOの上位8ビ
ットはデータセレクタ80の入力端子Aへ印加され、下
位7ビットはデータセレクタ80の入力端子Bへ印加さ
れる。 また、同セレクタ80の入力端子Bの第7ビットには“
゜0゛が印加されている。データセレクタ80は、入力
端子Aへ供給されるデータの各ビットのノアをとるノア
回路83の出力が“1゛の時人力端子Bのデータを出力
し、“゜0゛の時人力端子Aのデータを出力する。この
場合、レートカウントデータRCDOの上位8ビットは
全で“0゛であることから、同データRCDOの下位7
ビットに“゜0゛を加えた8ビットのデータがデータセ
レクタ80から出力され、アダー81の入力端子Aへ供
給れる。アダー81はデータセレクタ80の出力とオア
ゲート84の出力(゜゛1゛または“゜0゛)とを加算
する。オアゲート84の第1入力端へはインバータ72
の出力が供給され、インバータ72の入力端へは分配回
路77の出力端子Bから出されるデータRCDの第7ビ
ット、すなわち、HOLD信号が供給されている。また
、オアゲート84の第2入力端へは後述するデイケイリ
クエスト信号DEQが供給れている。したがつて、HO
LD信号が゛゜0゛の時は、インバータ72の出力が゜
゜1゛となり、この゜“1゛がオアゲート84を介して
アダー81の入力端子Bへの供給される。この結果、デ
ータセレクタ80の出力データにアダー81によつてR
lJが加算され、この加算結果がデータセレクタ73の
入力端子Bの上位8ビットへ供給される。また、このデ
ータセレクタ73の入力端子Bの下位8ビットには分配
回路77から出力されたレートカウントデータRCDO
の下位8ビットが供給される。データセレクタ73はア
ドレス信号PIAl(第15図卜)が゜゜0゛の時人力
端子Bのデータを出力し、“1゛の場合入力端子Aのデ
ータを出力する。したがつて、この場合入力端子Bのデ
ータがデータセレクタ73から出力され、セレクタレジ
スタ75へ供給される。そして、このデータがクロック
パルスMCLK3のタイミングで同レジスタ75に読込
まれ、次いでクロックパルスMCLKlのタイミングで
セグメントカウントメモリ76に読込まれる。このよう
に、第15図りに示す時間T。 Oのタイミングにおいて、まずデータRCDOが読出さ
れ、読出されたデータRCDOにRlJが加算され(R
lJが減算され)、次いで、この加算後のデータを上位
8ビットとし、加算前のデータRCDOを下位8ビット
とするデータが再びメモー1J76内のデータRCDO
の位置に書込まれる。次に、第15図りに示す時間T。
lのタイミングにおいては、セグメントカウントメモリ
76からエンベロープカウントデータECDOが読出さ
れ、分配回路77へ供給される。この時、信号PIAl
は″F゛信号にあり、したがつて、データECDOは分
配回路77の出力端子Aから出力され、アダー78の入
力端子Aへ供給される。アダー78の入力端子Bへはオ
アゲート82の出力が供給されており、オアゲート82
の第1入力端へはタンプリクエスト信号DAQ(常時ぱ
゜0゛)が、第2入力端へは遅延回路(遅延時間=2ベ
ースクロックタイム)85の出力が供給されている。ま
た、遅延回路85の入力端へはアダー81のキヤリイア
ウト端子COの信号が供給されている。前述した時間T
。Oにおいて、アダー81のキヤリイアウト出力ばO”
であり、したがつて時間T。lにおいて、遅延回路85
の出力ぱ“0゛となり、この信号“゜0゛がオアゲート
82を介してアダー78の入力端子Bへ供給される。こ
の結果、アダー78の入力端子Aへ供給されたエンベロ
ープカウントデータECDOは、そのままアダー78か
ら出力され、データセレクタ73の入力端子Aへ供給さ
れる。この時、信号PIAlは“゜1゛であり、したが
つて、アダー78から出力されたエンベロープカウント
データECDOがセレクタ73から出力され、セレクタ
レジスタ75に読込まれ、次いでセグメントカウントメ
モリ76に読込まれる。このように、時間T。 lにおいては、セグメントカウントメモリ76からエン
ベロープカウントデータECDOが読出され、遅延回路
85の出力が“゜0゛の時は、読出されたデータECD
Oが再びメモリ76の同じ記憶位置に書込まれる。以下
、アドレス信号PIA5〜1 (第15図へ)がROJ
になる毎にレートカウントデータRCDOにRlJが加
算され、また、アドレル信号PIA5〜1がRlJにな
る毎にエンベロープカウントデータECDOがメモリ7
6から読出され、次いで同メモリ76に書込まれる。 そして、アダー81のキヤリイアウト端子COから゜“
1゛信号が出力されると(データRCDOの上位8ビッ
トがROョになると)、2ベースクロックタイム遅れて
遅延回路85から゜゜1”信号が出力され、オアゲート
82を介してアダー78の入力端子Bへ供給される。こ
れにより、エンベロープカウントデータECDOにrl
ョが加算される(11ョが減算される)。以下、同様の
過程が繰返され、そして、アダー78のキヤリイアウト
端子COから゜゜1゛信号が出力されると(データEC
DOがROJになると)、この“゜1゛信号が信号FC
Cとして第5図に示すアダー25のキヤリイイン端子C
Iへ供給される。以上が、チャンネルCHOの、かつセ
グメント0の時間計測の過程である。一方、第5図のセ
グメントメモリ22の第0記憶スロット内のチャンネル
CHOに対応するデータ(この場合ROつは、チャンネ
ルアドレス信号CHA3〜0が10Jになる毎に読出さ
れ、レジスタ24へ供給される。 レジスタ24は、供給されるデータを1ベースクロック
タイム遅延させてアダー25の入力端子Bへ出力する。
アダー25の入力端子Aへは、デイケイ・ダンプ制御回
路29からデータEDが供給されている。このデータE
Dは、常時はr′0Jであり、したがつて、レジスタ2
4の出力デー夕は、アダー25のキヤリイイン端子CI
へ信号ECCC゜l゛信号)が供給されていない時は、
アダー25からそのまま出力され、アンドゲート26へ
供給される。アンドゲート26は、信号RUN(第15
図ホ)が゜“1゛の時、開となり、アダー25の出力を
セグメントメモリ22の入力端へ供給する。しかして、
セグメントメモリ22のチャンネルCHOに対応する第
0記憶スロットの内容は、初期状態でROョてあり、信
号R[−1Nが“゜1゛に立上つた後もROJを続け、
そして、チャンネルCHOのタイミングで信号ECC(
゜゜1゛信号)がアダー25へ供給された時始めてRl
J(セグメント1を示す)となる。 セグメントメモリ22のチャンネルCHOに対応する第
0記憶スロットの内容がRlJになると、アドレス信号
PSA8〜6がr1ョとなり、このアドレス信号1しが
第6図のセグメントカウントメモリ76のアドレス端子
AD2へ供給される。 これにより、以後、チャンネルCHOに対応してアドレ
ス信号PIA5〜1がROョになる毎にレートカウント
データRCDl(セグメント1に対応)が、また、信号
PIA5〜1がRlJになる毎にエンベロープカウント
データECDlが各々セグメントカウントメモリ76か
ら読出され、前述した場合と同様にしてセグメント1の
時間計測が行われる。そして、アダー78のキヤリイア
ウト端子COから信号ECCが再び出力されると、セグ
メントメモリ22(第5図)のチャンネルCHOに対応
する第0記憶スロットの内容が12Jとなり、以後セグ
メント2の時間計測が行われ、このセグメント2の時間
計測が終了すると、次いでセグメント3〜7の時間計測
が順次行われる。以上が、セグメント演算の過程である
。 なお、上記の過程はチャンネルCHOのセグメント演算
の過程であるが、チャンネルCHl〜CHl5について
も発音割当てが行われた場合、同様にして行われる。 この場合、チャンネルCHlの時間計測は第15図りに
示す時間T1において行なわれ、・・、チャンネルCH
l5の時間計測は同図に示す時間Tl5において行われ
る。また、上記過程において、HOLD信号が“゜1゛
の場合は、インバータ72の出力が“゜0゛となり、し
たがつてオアゲート84の出力が“60゛となり、この
4“0゛信号がアダー81の入力端子Bへ供給される。 この結果、アダー81における1+しの加算が行われず
、セグメント演算は実質的にストップし、以後、セグメ
ントは4の状態−を続ける。なお、この場合における以
後のセグメント処理については後のキーオフ処理におい
て説明する。】)エンベロープ演算 第13図に示す楽音演算期間Tgに入つた時点において
、第6図のエンベロープ演算メモリ54(第14図参照
)のチャンネルCHOに対応するエリアには、エンベロ
ープ初期値110NT,I20NT,A0NTが各々記
憶されており、また、第6図のエンベロープ増分値メモ
リ66のチャンネルCHOに対応するエリアにはエンベ
ロープ増分値Δ110,Δ120,ΔAO,Δ111,
Δ121,ΔAl,・・・Δ117,Δ127,ΔA7
が各々記憶されている(第9図のエリアEO参照)。 この状態において、アドレス信号PIA5〜0がチャン
ネルCHOに対応してROJになると(第16A図イに
示す時間TaO参照)、エンベロープ演算メモリ54か
らチャンネルCHOに対応する初期値111NTが出力
され(第16A図口参照)、また、エンベロープ増分値
メモリ66からは、チャンネルCHOに対応する増分値
Δ110が出力される(第16A図ハ参照)。そして、
エンベロープ演算メモリ54の出力はアダー57の入力
端子Aへ供給され、また、エンベロープ増分値メモリ6
6の出力はデータセレクタ59の入力端子Aへ供給され
る。データセレクタ59は、インバータ72の出力が゜
0゛の時(HOLD信号が“1゛の時)、データROョ
を出力し、インバータ72の出力が“1゛の時は、ダン
プリクエスト信号DAQが“゜0゛の場合に入力端子A
のデータを出力し、同信号DAQが“1゛の場合に入力
端子Bのデータを出力する。 第16A図の時間匡%においてインバータ72の出力は
“1゛、ダンプリクエスト信号DAQぱ“0゛であり、
したがつて、エンベロープ増分値メモリ66の出力Δ1
10がデータセレクタ59を介してアダー57の入力端
子Bへ供給される。この結果、アダー57からデータ(
111NT+Δ11o)が出力され、アダー58の入力
端子Aへされる。このアダー58の入力端子Bへは、外
部コントロールデータが供給されている。この外部コン
トロールデータは、例えば演奏者が演奏中において発生
楽音の音量、音色等を直接制御したい場合あるいは音量
や音色に周期的変調を付与した場合等に供給されるデー
タであり、通常はROョとする。したがつて、通常はア
ダー58の入力端子Aへ供給されたデータがアダー58
からそのまま出力され、クロックパルスMCLK3のタ
イミングでセレクタレノジスタ51に読込まれる。そし
て、この読込まれたデータがENVDATAl5〜0と
して同レジスタ51から出力され(第16A図ニ)、第
7図の楽音演算回路へ供給されると共に、エンベロープ
演算メモリ54に再び書込まれる。このように、信号P
IA5〜0がROJにある期11!TTaO内において
、メモリ54からチャンネルCHOに対応するデータ1
11NTが読出され、次いでこのデータ111NTにデ
ータΔ110が加算され、この加算結果11、ェ+Δ1
10がチャンネルCH二0のデータ11に関するENV
DATAl5〜0として出力されると共に、メモリ54
内のデータ111NTが記憶されていた位置に書込まれ
る。次に、信号PIA5〜0力げしになると、上述した
楊合と同様にして、ENVDATAl5〜,0としてデ
ータ1218ェ+Δ120が出力され、また、このデー
タがメモリ54内に書込まれる。次いで信号PIA5〜
0がR3Jになると、ENVDATAl5〜0としてチ
ャンネルCHOのデータAINT+ΔAOが出力され、
またこのデータがメモリ54内に書込まれる。以上がチ
ャンネルCFIOに対する処理であり、以後信号PIA
5〜0が14〜7ョの時チャンネルCHlに対する処理
が行なわれ、 信号PIA5〜0が160〜63ョの
時チャンネルCHl5の処理が行われる。次に、再び信
号PIA5〜0がROJになると、メモリ54がデータ
111NT+Δ110が読出され、この読出されたデー
タにΔ110が加算され、この加算結果111NT+2
Δ110がENVDATAl5〜0として出力されると
共に、メモリ54内に再び書込まれ、以下同様の処理が
繰返される(第16B図参照)。 以上がエンベロープ演算の過程であり、このようにして
前記第(5)〜第(7)式の演算、すなわち、なる演算
が行われる。 なお、インバータ72の出力が“0゛の時(HOLD信
号が′6F′の時)はデータセレクタ59の出力がRO
Jとなり、したがつて、メモリ54から読出されたデー
タはそのまま(増分値が加算されずに)ENVDATA
l5〜0として出力され、また、メモリ54内に再書込
みされる。 この場合、勿論エンベロープデータA,ll,l2は変
化しない。なお、実際には、インバータ72の出力はタ
イミング合わせ用の回路を介してデータセレクタ59に
供給されるが、この点に関する説明は省略する。3)位
相演算 この位相演算の過程は上述したエンベロープ演算の過程
と略同じであり、したがつて詳細な説明は省略するが、
第16A図、第16B図のホ〜トに各々位相演算メモリ
55、位相増分値メモリ67の各出力およびFREQD
ATAl5〜0を示す。 このデータFREQDATAl5〜0が第7図の楽音演
算回路へ供給される。この位相演算が前述した第(2)
〜第(4)式の演算、すなわち、なる演算である。 なお、アダー61の入力端子Bへ供給される外部コント
ロールデータは、楽音に周波数変調(例えばビフラート
)をかける場合に供給されるデータであり、周波数変調
をかけない場合はROJである7)楽音波形演算 この楽音波形演算は楽音波形を形成するための演算であ
り、第7図に示す楽音演算回路によつて、上述したEN
VDATAl5〜0およびFREQDATAl5〜0を
用いて行われる。 第7図において、符号47はマイクロプログラムメモリ
(ROM)であり、このメモリ47には予め第17図に
示す64ステップ(1ステップ16ビット)のマイクロ
命令が記憶されている。この第17図において、O印は
“r゛信号を、空欄は“0゛信号を示している。例えば
、図の第1行目の命令TOは″00・・・0111r゛
なる命令である。また、図の最上部には各ビット信号の
名称が記載されている。各ビット信号の働きは次の通り
である。・チャンネルアドレス信号CHA3〜0(第1
5〜第12ビット)前述したように、チャンネルCHO
〜CHl5の各々についての処理タイミングを示す信号
である(第12図、第15図参照)。 ●ゲート信号GATEMULK(第7ビット)このゲー
ト信号GATEMULKが″R5になると、第7図のゲ
ート回路92が開状態となる。 ・セレクト信号FREQSEL(第6ビット)このセレ
タト信号FREQSELが6′0″になると、第7図の
セレクタレジスタR3の入力端子Aが選択され、“1゛
になると、入力端子Bが選択される。 ・ロード信号LDB(第5ビット) このロード信号LDBが゜゜1゛になると、第7図の出
力バッファ93にデータが読込まれる。 ・ロード信号LDR5(第4ビット) このロード信号LDR5が“1゛になると、レジスタR
5(第7図)にデータが読込まれる。 ・ロード信号LDR4(第3ビット) このロード信号LDR4が゜゜1゛になると、.レジス
タR4にデータが読込まれる。 ・ロード信号LDR3(第2ビット) このロード信号LDR3が゜゜F゛になると、レジスタ
R3に上述したセレクト信号FREQSELによつて選
択されたデータが読込まれる。 ・ロード信号LDR2(第1ビット)このロード信号L
DR2が゜゜1゛になると、レジスタR2にデータが読
込まれる。 ・ロード信号[J)R1(第0ビット) このロード信号LDRlが“4r゛になると、・ジスタ
R1にデータが読込まれる。 また、第17図においてO印の中に記入された数字は、
その信号によつて処理されるチャンネルCHO〜CHl
5の番号を示している。 上述したマイクロプログラムメモリ47内の各命令はア
ドレス信号1A5〜0によつて読出される。すなわち、
アドレス信号1A5〜0がROJの時間第17図の命令
TOが読出され、RlJの時命令T1が読出され、 、
R63Jの時命令T63が読出される。そして、読出さ
れた命令に含まれる各ビット信号の内、チャンネルアド
レス信号CH3〜0が第5図および第6図の回路各部へ
出力され、また、他のビット信号がインストラクション
レジスタ48によつて1ベースクロックタイム遅延され
た後、第7図へ出力される。次に、第7図に示す回路の
動作を第17図および第18図を参照して説明する。 まず、第18図はクロックパルスMCLKl、アドレス
信号1A5〜0、PIA5〜0、ENDATAl5〜0
、FREQDATAl5〜0および第7図各部の出力の
相互関係を示すタイミング図であり、この図において長
方形枠の右下隅の数字ROJ,rlョは各々チャンネル
番号を示している。また、第7図におけるマイクロプロ
グラムメモリ47内の各マイクロ命令TO〜T63は、
前述したようにアドレス信号1A5〜0(第18図口)
により、常時、繰返し読出される。そして、読出された
各マイクロ命令TO〜T63がインストラクションレジ
スタ48により1ベースクロックタイム遅延されて第7
図の各部へ出力される。他方、アドレス信号PIA5〜
0(第18図ハ)はアドレス信号1A5〜0を1ベース
クロックタイム遅延させた信号である。したがつて、第
18図ハおよびへに示すように、アドレス信号PIA5
〜0がROョの時インストラクションレジスタ48から
マイクロ命令TOが出力され、 アドレス信号PIA
5〜0がR63Jの時インストラクションレジスタ48
からマイクロ命令T63が出力される。また、前述した
データENVDATAl5〜0およびFREQDATA
l5〜0が第7図の回路へ供給されるタイミングは、第
16A図、第16B図二および卜に示される通りであり
、これらのデータが各々第18図二およびホに転記され
ている。 なお、第18図ホにおいてω1,ω2,ω。に代えてω
1t,ω2t,ω0t1と記載しているのは前述した(
1)式との対応をわかり易くするためである。以下、第
18図にしたがつて第7図の回路の動作を述べる。 まず、信号PIA5〜0がROJとなる時間TO(第1
8図最下部参照)においては、第7図のインストラクシ
ョンレジスタ48からマイクロ命令TOが出力される。
また、この時、レジスタR1の入力端へはチャンネルC
HOのENVDATAl5〜0rI1Jが供給され、セ
レクタレジスタR3の入力端子AへはチャンネルCHO
のFREQDATAl5〜0r0)1tJが供給されて
いる。インストラクションレジスタ48からマイクロ命
令TOが出力されると、ロード信号LDRl〜LDR4
(第17図参照)が各々レジスタR1〜R4へ供給され
る。ここで、ロード信号LDRl,LDR3はチャンネ
ルCHOの楽音信号を形成するための信号であるが、ロ
ード信号LDR2,LDR4はチャンネルCHl5の楽
音信号を形成するための信号である。以下、チャンネル
CHOの楽音信号を形成する場合についてのみ説明する
。ロード信一号LDRlおよびLDR3が各々レジスタ
R1およびR3へ供給されると、レジスタR1およびR
3に各々上記のデータ11およびω1tが読込まれる(
第18図卜,り参照)。なお、この時セレクト信号FR
EQSELば0゛であり、レジスタR3の入力端子Aが
選択されている。レジスタR3にデータω1が読込まれ
ると、このデータω1tがサインテーブル96へ供給さ
れ、これにより、サインテーブル96からSinω1t
が出力される(第18図オ参照)。次に、時間t1にな
ると、レジスタR1の入力端へENVDATAl5〜0
rI2Jが、またレジスタR3の入力端子A−.FRE
QDATAl5〜0「ω2tJが各々供給され、また、
インストラクションレジスタ48からマイクロ命令T1
(第17図参照)が出力される。 このマイクロ命令T1により、ロード信号1J)R1〜
LDR4が各々レジスタR1〜R4へ供給され、各レジ
スタR1〜R4に第18図に示す各データが読込まれる
。また、レジスタR3にデータω2tが読込まれ、サイ
ンテーブル96へ供給されると、サインテーブル96か
らデータSinω2tが出力される。また、レジスタR
4にデータSinω1tが読込れ、またレジスタR2に
データ11が読込まれ、これらのデータが各々乗算器9
0が供給されると、乗算器90からデータ11Sinω
1tが出力される(第18図ワ)。またこの時ゲート信
号GATEMUIKぱ“0゛であり、したがってゲート
回路92の出力は0である。(第18図力)。そして、
乗算器90から上述したデータ11sinω1tが出力
され、ゲート回92からデータ0が出力されると、アダ
ー91の出力が11Sinω1tとなる(第18図ヨ)
。次に、時間T2になると、インストラクションレジス
タ48からマイクロ命令T2が出力される。これにより
、ロード信号LDR2,LDR4,LDR5が各々レジ
スタR2,R4.R5へ供給され、各レジスタR2,R
4,R5に第18図に示す各データが読込まれる。なお
、レジスタRl,R3内のデータは時間t1におけるデ
ータと同じである。またこの時、サインテーブル96、
乗算器90、アダー91の各出力は各々図に示す通りと
なる。次に、時間T3になると、インストラクションレ
ジスタ48からマイクロ命令T3が出力される。 これにより、ロード信号LDRl,LDR3、セレクト
信号FREQSELlゲート信号GATEMULKが各
々レジスタRl,R3、ゲート回路92へ供給される。
ロード信号LDRlがレジスタR1へ供給されると、レ
ジスタR1にデータAが読込まれる。また、この時T3
においてレジスタR2,R4.R5内のデータは時間T
2におけるデータと同じである。したがつて、乗算器9
0の出力はデータI2sinω2tとなり、また、レジ
スタR5の出力はデータ11sinω1tとなる。 ここで、ゲート信号GAlEMULKによりゲート回路
92が開状態になると、アダー91の出力がデータ11
Sinω1t+I2Sinω2tとなり、このデータが
アダー95の入力端子Bへ供給される。この結果、アダ
ー95の出力がデータω。t+11Sinω1+I2S
inω2となり、このデータがレジスタR3の入力端子
Bへ供給される。ここで、レジスタR3へロード信号1
J)R3およびセレクト信号FREQSELが共に供給
されると、レジスタR3の入力端子Bのデータが同レジ
スタR3に読込まれ、サインテーブル96へ供給される
。これにより、時間T3においてサインテーブル96か
ら、Sin(ω0t+11Sinω1t+I2Sinω
2t)なるデータが出力される(第18図参照)。 次に、時間T4になると、インストラクションレジスタ
48からマイクロ命令T4が出力される。これにより、
ロード信号LDRl〜1J)R4が各々レジスタR1〜
R4へ供給され、図に示す各データがレジスタR1〜R
4に読込まれる。ここで、レジスタR2,R4に読込ま
れた各データはチャンネルCHOの楽音信号を形成する
ためのデータであるが、レジスタRl,R3に読込まれ
たデータは、チャンネルCHlの楽音信号を形成するた
めのデータである。すなわち、この時間T4からチャン
ネルCHlの楽音信号形成が開始される。レジスタR2
,R4にチャンネルCHOのデータAおよびデータSi
n(ω0t+11Sinω1t+I2Sinω2t)が
読込まれると、乗算器90から、Asin(ω0t+1
1Sinω1t+I2Sinω2t)なるデータ、すな
わち、チャンネルCHOについての前記第(1)式のデ
ータが出力され、このデータがアダー91から出力され
る。 次に、時間T5になると、インストラクションレジスタ
48からマイクロ命令T5が出力される。 これにより、ロード信号LDR5がレジスタR5へ供給
され、上記のデータがレジスタR5に読込まれる。次に
、時間T6になると、インストラクションレジスタ48
からマイクロ命令T6が出力される。 これにより、ロード信号LDBが出力バッファ93に供
給され、レジスタR内のチャンネルCHOに関するデー
タAsin(ω0t+11Sinω1t+I2Sinω
2t)が出力バッファ93に読込まれる。 そして、この出力バッファ93に読込まれたデータがD
−A変換器94によつてアナログ信号に変換され、スピ
ーカ(図示略)から楽音として発音される。以上がチヤ
ンネノL/CHOの楽音信号を形成する過程であり、上
述したように、チャンネルCHOの楽音信号はアドレス
信号PIA5〜0がRO〜6ョの間に形成される。 また、チャンネルCHl〜CHl5の各楽音信号も全く
同様の過程で形成される。この場合、チャンネルCHl
の楽音信号は信号PIA5〜0がR4〜10Jの時形成
され、チャンネルCH2の楽音信号は信号PIA5〜0
がR8〜14Jの時形成され、 チャンネルCHl5
の楽音信号は信号円A5〜0がR6O〜2Jの時形成さ
れる。しかして、上述した第7図の回路の動作は常時繰
返し行われている。 したがつて、例えばチヤンネノ顎HOに楽音割当てが行
われ、次いで第13図のデータ転送期間Ttにおいてチ
ャンネルCHOのについての各種データの転送が行われ
、次いで第13図の楽音演算期間Tgに入り、チャンネ
ルCHOのENVDATAl5〜0およびFREQDA
TAl5〜0が信号PIA5〜0r0〜3Jのタイミン
グにおいて第7図の回路へ逐次供給されると、チャンネ
ルCHOの楽音信号が上記の過程で形成される。一方、
チャンネルCHOの発音割当てが行われていない時は、
上述したチャンネルCHOのENVDATAl5〜0,
FREQDATA15〜0が共にROJとなり、楽音形
成は行われない。′,)キーオフ処理 キー群102(第3図)の押下されていたキーが離鍵さ
れると、前述したようにキーアサイナ103が、離鍵さ
れたキーの発音割当てが行われているチャンネル(CH
O〜CHl5)の発音終了を指示するデイケイコマンド
またはダンプコマンドを出力する。 以下、これらのコマンドに対応して行われる処理を説明
する。(1)デイケイコマンドに対する処理 例えばチャンネルCHOの発音終了を指令する場合、キ
ーアサイナ103は16ビットのデイケイコマンド66
00・・・01゛(第0ビットが“1゛で、他のビット
ぱ゜0゛)をアドレス信号と共に出力する。 このデイケイコマンドは第5図に示すデイケイコマンド
レジスタ38に読込まれる。次いで、クロックパルスI
NITCLKが立上ると、同レジスタ38内のデイケイ
コマンドがデイケイレジスタ39に読込まれ、デイケイ
マルチプレクサ40へ供給される。デイケイマルチプレ
クサ40は、前述したイーツトマルチプレクサ34、ラ
ンマルチプレクサ35と同一構成であり、チャンネルア
ドレス信号CHA3〜0がROョの時人力端のデータ(
16ビット)の第0ビット目の信号を出力し、 CH3
〜0がRl5Jの時人力端のデータの第15ビット目の
信号を出力する。このデイケイマルチプレクサ40の出
力は、レジスタ41によつて1ベースクロックタイム遅
延された後、信号DEOAYとしてデイケイダンプ制御
回路29へ出力される。デイケイダンプ制御回路29は
、同信号DECAYに基づいてチャンネルCHOにおい
てデイケイ指令が出力されたことを検知し、デイケイリ
クエスト信号DEQを、アドレス信号PIA5〜0がR
O〜3ョのタイミングにおいて出力すると共に、次の処
理を行う。すなわち、レジスタ24からセグメントメモ
リ22のチャンネルCHOに対応する第0記憶スロット
内のデータが出力された時、このデータをチェックし、
同データの値に応じて次の各データEDをアダー25の
入力端子Aへ出力する。 この処理により、その時点におけるチャンネルCHOの
楽音形成がセグメント0〜4のいずれりある場合におい
ても、楽音形成がセグメント5へ強制的に移行し、以後
セグメント5〜7の楽音形成が行われる。 また、チャンネルCHOの楽音形成がセグメント5〜7
のいずれかになる場合は、そのまま楽音形成が進行する
。以上がデイケイコマンドに対する処理である。(Ii
)ダンプコマンドに対する処理 例えばチャンネルCHOの発音を急速に終了させる場合
、キーアサイナ103は16ビットのダンプコマンド4
′00・・・0r′(第0ビットが“゜1゛)をアドレ
ス信号と共に出力する。 このダンプコマンドは第5図に示すダンプコマンドレジ
スタ42内に読込まれる。次いで、クロックパルスIN
ITCLKが立上ると、同レジスタ42内のダンプコマ
ンドがダンプレジスタ43内に読込まれ、ダンプマルチ
プレクサ44へ供給される。 ダンプマルチプレクサ44は、デイケイマルチプレクサ
40と同様に、チャンネルアドレス信号CHA3〜0に
基づいて入力端へ供給されるデータ(16ビット)を直
列データに変換し、レジスタ41へ出力する。レジスタ
41はダンプマルチプレクサ44の出力を1ベースクロ
ックタイム遅延させ、信号DAMPとしてデイケイ・ダ
ンプ制御回路29へ出力する。デイケイ・ダンプ制御回
路29は、この信号DAMPに基づいてチャンネルCH
Oに対するダンプ指令が出力されたことを検知し、以後
、アドレス信号PIA5〜0がRO〜3Jのタイミング
においてダンプリクエスト信号DAQC“1゛)を第6
図左下部に示すデータセレクタ59へ出力する。これに
より、以後、エンベロープ演算メモリ54から出力され
るチャンネルCHOのエンベロープ11,12,Aが各
々、減衰回路63によつて1−1164Jに減衰され、
データセレクタ59を介してアダー57へ供給される。
これにより、発生楽音が急速に減衰する。以上がダンプ
コマンドに対する処理である。なお、パーカツシブ系の
楽音の場合、キーオフ時点においてセグメント9〜7が
すでに終了している場合もある。 このような場合は、勿論デイケイ、ダンプコマンドがキ
ーアサイナ103から出力されることはない。 ))発音終了処理 発音終了は第5図のセグメントメモリ22内のデータが
R8J(“′1000′゛)になつた場合、またはEN
VDATAl5〜0(第6図参照)が負になつた場合に
検出される。 すなわち、第5図のレジスタ24の出力の第3ビットが
オアゲート27の第1入力端へ供給されている。また、
第6図下部に示す負データ検出回路64はENVDAT
Al5〜0が負になつた時信号RER(゛゜1゛信号)
を出力する回路であり、この信号RERは同オアゲート
27の第2入力端へ供給される。この結果、発音が終了
すると、オアゲート27から゜“1゛信号が出力され、
発音終了処理回路28へ供給される。発音終了処理回路
28はオアゲート27の出力およびチャンネルアドレス
信号CHA3〜0に基づいてどのチヤンネルCHO〜C
El5の発音が終了したかを検知し、終了したチャンネ
ルCHO〜CHl5を示す16ビットの信号SFCを出
力する。例えばチャンネルCHOが終了した場合、信号
GFCとして゜“11・・・10゛(第0ビットが゜゜
0゛)を出力する。この信号SFCはランレジスタ32
、デイケイレジスタ39、ダンプレジスタ43へ供給さ
れ、これにより、これらのレジスタ32,39,43の
各第0ビットがリセットされる。ランレジスタ32の第
0ビットがリセットされると、このランレジスタ32の
出力がキーアサイナ103へ供給されていることから、
キーアサイナ103がチャンネルCHOの発音終了を検
知し、その後のキーオンに対してチャンネルCHOに新
たな発音割当てを行う。なお、上記実施例の説明では、
この発明を電子オルガンに適用したが、電子オルガン以
外の同様な他の電子楽器にも勿論この発明を適用できる
。 また上記実施例ではエンベロープ波形を8個のセグメン
トに分割し、各セグメントにおいて独立した波形計算を
実行できるようにしたが、分割するセグメントの数は8
個に限定されない。更に楽音波形のアタック状態、サス
チイン状態、デイケイ状態を上記セグメントに対して割
当てる割当てかたも、上記実施例中の説明のものに限定
されない。〔発明の効果〕 以上詳述したことから明らかなように、この発明によれ
ば、アサイナとウエイブジエネレータとが各々独立に動
作し、したがつて両者を同期動作させる等の設計上の制
約が生じない利点がある。 また、この発明によれば、アサイナが周波数データ等を
各チャンネル毎にバスラインを介して順次ウエイブジエ
ネレータへ出力するので、アサイナとウエイブジエネレ
ータとの間の配線数を減少させ得る効果がある。
[0]~AINT[63
] (envelope initial value data) is read and if address signal 1SA6 is "r', address signals 1A5 to
While 0 changes from RO to 63J, the data ω10NTC01] to ω01NT[6311](
phase initial value data) is read out (see FIG. 12H). Then, each read data is delayed by one base clock time by the buffer register 14 and output (
(See Figure 12). 110 Memory 15 When the address signals 1SA8 to 1SA6 are RO, the data RCDOCO] to ECDO[31 shown in FIG.
) is read out, and if the address signals 1SA8-6 are r1, the data RCDl[[]-ECD in FIG.
1 [31a] is read out, and thereafter, each segment data is sequentially read out in the same way (see FIG. 12). That is, reading from the memory 15 is performed every two base clock times, and each value of address signals 1SA8-6 corresponds to segments 0-7, respectively. Each data read from the memory 15 is stored in a buffer register 16.
The signal is delayed by one base clock time and output (see FIG. 12). Next, a process in which data in the memories 11, 13, and 15 are transferred to the memories 54, 55, 66, 67, and 76 will be explained. Suppose now that the key assigner 103 assigns the sound of the pressed key to channel CHO. In this case, as described above, the key assigner 103 outputs various data corresponding to the pitch and timbre of the musical sound to be produced, and the memory 11, 13,
It writes to the area corresponding to channel CHO 15, and then outputs a start command "400...01" (16 bits). The 0th bit ゜゜1゛ in this start command instructs the start of channel CHO. After this start command is output,
Each envelope increment value data corresponding to channel CHO in area EO of memo I river 1 shown in FIG. 9 is transferred to envelope increment value memory 66 in FIG. 6, and also corresponds to channel CHO in area E1. Each phase increment value data is transferred to the phase increment value memory 67 shown in FIG. 6, and each envelope initial value data 5 (11) corresponding to the channel CHO in the memory 13 shown in FIG.
0N,,12,N,,A,N,) are transferred to the envelope calculation memory 54, and each phase initial value data (ω11NT, ω21
NT9ω0INT) are transferred to the phase calculation memory 55, and the channel CH of the memory 15 shown in FIG.
Each segment data corresponding to O is transferred to segment count memory 76. The above operation will be explained in detail below. When the aforementioned start command "00...01" is output from the key assigner 103, this start command is read into the start command register 30 (16 bits) shown in FIG. 5 via the data bus 18.
Next, when the clock pulse INITCLK rises, the output data of the start command register 30 is read into the init register 31 at this rising time, and the read data! data is provided to an init multiplexer 34. The input multiplexer 34 outputs the signal of the 0th bit of the manual data when the channel address signals CHA3 to CHA0 (FIG. 12) are RO.
When ~0 is R1J-R15J, signals of the 1st bit to 15th bit of the input data are output (parallel-to-serial conversion is performed). That is, when the data (start command) read into the init register 31 is 6400...0r2, the output signal of the init multiplexer 34 is 1NIT-1.
becomes the waveform shown in Fig. 12 (o). The pulse width of this signal 1NIT-1 is 1 μSec, and as shown in the opening of Figure 13, the clock pulse INITCLK (Figure 7313-A)
This occurs at least once during one period (256 μSec). When this signal 1NIT-1 occurs 16 times, the memory 54
~76 data writing is performed. This signal 1NIT-
1 is supplied to the set input terminal S of flip-flop 37 (FIG. 5). The flip-flop 37 is triggered by the clock pulse MCLKl and the signal 1NI
T-1 is delayed by 1 base clock time and the signal 1NI
Output as T (Figure 12 wa). And the above signal 1
Based on NIT-1 and INIT, data is written into the memories 54 to 76 in the following process. (1) Memories 66, 67 (Fig. 6) These memories 66, 67 are located in the area EO of Fig. 9, respectively.
, El, and has the same capacity as address signal PIA
5 to 0 (see FIGS. 4 and 12) are supplied as lower addresses, and address signals PSA8 to PSA 6 are supplied as upper addresses. Here, address signals PSA8 to PSA6 will be explained. The selector register 21 shown in FIG.
When 1 is ゜゛0゛, memory 2 is being supplied to human power terminal A.
2 is read at the timing of the clock pulse MCLKl, and when the signal 1NIT-1 is "゜1゛", the address signals ISA9 to ISA6 supplied to the input terminal B are read.
(FIG. 12D) is read at the timing of the RO clock pulse MCLKl. Then, the read signals are output as address signals PSA9 to PSA6. That is, the signal 1NI
When T-1 becomes "1", the address signals 1SA9-6 are delayed by one base clock time in the selector register 21 (therefore, they become the same signals as address signals PISA9-6), and are output as address signals PSA9-6. The address signals PSA8-6 supplied as upper addresses to the memories 66 and 67 are the lower three bits of the address signals PSA9-6 mentioned above.Next, the memory 6
The outputs of AND gates 68 and 69 are supplied to read/write terminals R/W 6 and 67, respectively. Further, a signal INIT is supplied to each first input terminal of AND gates 68 and 69, an address signal PSA9 is supplied to a second input terminal of AND gate 68 via an inverter 70, and a second input terminal of AND gate 69 is supplied with a signal INIT. An address signal PSA9 is directly supplied to the end. Here, the address signal PSA9 is the address signal 1SA
9 is a signal delayed by one base clock time by the selector register 21 (Fig. 5) (however, signal 1
Therefore, when the address signal PSA9 is '60', the data in the area EO in FIG. 9 is output from the buffer register 12 in FIG. 4,
When address signal PSA9 is 66r', data in area F1 in FIG. 9 is output from buffer array 1 register 12 in FIG. Now, the clock pulse INITCLK rises to the 6'F9 signal, and then the signal 1N indicated by the symbol P1 in FIG.
When IT is output, the signal PSA9 becomes “0” at that point.
゛The same signal 1NIT is connected to AND gate 68
The signal is supplied to the read/write terminal R/W of the memory 66 via. At this time, as shown in Figure 12, envelope increment value data (Δ110, Δ120
, ΔAO: Fig. 9) are sequentially outputted to the memory 66 (Fig.
(Fig.) is supplied to the data input terminal. Therefore, when the signal 1NIT indicated by the symbol P1 is output, the above-mentioned envelope increment value data is written into the memory J66.
Next, when the signal 1NIT indicated by P2 in FIG. 12 is output, the envelope increment value data (Δ111, Δ121, ΔA
1) are sequentially written into the memory 66, and hereinafter, the signal 1NIT
Each time the signal becomes a ゜゜1゛ signal, each envelope increment value data of segments 2, 3, . . . , 7 of channel CHO is sequentially written into the memory 66. Next, area E1 in Figure 9
When the data in the buffer register 12 (FIG. 4) is sequentially output, the address signal PSA9 is output as described above.
゛ becomes ゜゜1゛, therefore, the AND gate 69 becomes open and the signal INIT is supplied to the read/write terminal R/W of the memory 67. As a result, the signal IN
Every time IT is output, each phase increment value data (Δω109Δω20
9Δω00ゞΔω179Δω219Δω07: Figure 9)
are sequentially written into the memory 67. 1) Memories 54, 55 The initial value data output from the buffer register 14 in FIG. 4 is supplied to each input terminal A of the selector registers 51, 52 shown in FIG. The selector registers 51 and 52 each have an AND gate 51
When the outputs of the AND gates 51a and 52a are "1", the data of the input terminal A is read at the timing of the clock pulse MCLK3 (see Fig. 8), and when the outputs of the AND gates 51a and 52a are "0", the data of the input terminal B is read. The data of clock pulse MCLK
Load at timing 3. A signal 1 is input to each first input terminal of AND gates 51a and 52a.
NIT is supplied, address signal PISA6 is supplied to the second input terminal of AND gate 51a via inverter 50, and address signal PISA6 is directly supplied to the second input terminal of AND gate 52a. Here, when the address signal PISA6 is "0", the envelope initial value data (11!NT9) shown in FIG.
l2lNT9A! NT9) is output from the buffer register 14 in FIG. 4, and when the address signal PISA6 is "1", the phase initial value data (ω1!NT9ω2) in FIG.
! NT9ωO! NT) is output from the buffer register 14. As shown in FIG. 14, the memories 54 and 55 have areas corresponding to each of channels CHO to CH15, and each area is composed of 4 storage slots (20 bits per slot). In this case, four slots in each area are addressed by address signals PIAl,O, and each area is addressed by address signals PIAl,O.
Addressed by 5-2. These memories 54 and 55 read the outputs of the selector registers 51 and 52 at the timing of the rising edge of the clock pulse MCLKl. Therefore, the signal 1NIT indicated by the symbol P1 in FIG.
When is output, since the address signal PISA6 is ゜゜0゛ at the timing of this signal 1NIT,
Signal 1NIT is supplied to selector register 51 via AND gate 51a. As a result, the envelope initial value data (111NT, 111NT,
121NT, A0N, ) (see Figure 12) are sequentially read into the selector register 51, and then each read initial value data is sequentially read into the area corresponding to channel CHO of the memory 54. Next, the symbol P2 is shown in the 12th diagram.
When the signal INIT shown in is output, since the address signal PISA6 is ゜゛1゛ at this time, the signal INIT is output.
IT is connected to the selector register 5 via the AND gate 51a.
2. As a result, the channel CHO phase initial value data (ω1, NT, ω2, NT, ωoIT) output from the buffer register 14 at the signal 1NIT timing mentioned above
) are sequentially read into the selector register 52, and then each read initial value data is transferred to the channel CH of the memory 55.
They are sequentially read into the area corresponding to O. Thereafter, the exact same operation as described above is repeated every time the signal INIT is output. (Ii) Memory 76 The segment data output from the buffer register 16 in FIG. 4 is input to the input terminal A of the selector register 75 in FIG.
supplied to The selector register 75 has the same configuration as the selector registers 51 and 52 described above, and reads the data of the input terminal A at the timing of the clock pulse MCLK3 when the signal 4 is set to 1, and when the signal 1NIT is set to 0. Segment count memory 765 reads data from input terminal B at time.
is a memory having the same configuration as the memory 15 shown in FIG. 11, in which address signals PIA5-1 are supplied as lower addresses, address signals PSM8-6 are supplied as upper addresses, and clock pulse MCLKl rises on the evening of 4.
Read input data at the right time. When the signal 1MT indicated by the symbol P1 in FIG. 12 is output, the segment data (late count data rc
DO and envelope count data (ECDO) are sequentially read into selector register 75, and then the read data is sequentially read into segment counter memory 76. Hereafter, each time the signal INIT is output, the channel CHO
Each segment data of segments 1 to 7 is sequentially read into the memory 76. (4) Segment calculation Data transfer to the memories 54 to 76 described above is performed during one cycle of the clock pulse INITCLK (25
6 μSec). Then, the clock pulse INITCLK is 4"1"
When the voltage rises to 0, the data ゛00...01゛ in the init register 31 shown in FIG. 5 is read into the run register 32. Each of the 16 bits output from the run register 32 is inverted by an inverter 36 and supplied to each bit reset terminal of the init register 31 and start command register 30, respectively. As a result, the bits of the registers 30 and 31 corresponding to the "1" bit of the run register 32 are reset. Also, the "0" signal of the output (16 bits) of the inverter 36 is transmitted to the start command register 32. Input of the corresponding bit is prohibited. Also, the output of the run register 32 is sent to the run multiplexer 35.
supplied to The run multiplexer 35 uses the channel address signal CI
(When A3~0 is 0J, output the 0th bit signal of the run register 32, when CHA3~0 is r1, output the 1st bit signal of the run register 32,
At 5J, the signal of the 15th bit of the run register 32 is output (parallel-to-serial conversion is performed). The output of this run multiplexer 35 is the signal RUN-1
The signal is supplied to the reset terminal R of the flip-flop 37 as a signal. Flip-flop 37 delays signal RUN-1 by one base clock time and outputs it as signal RUN. Note that FIG. 13C shows the waveform of the signal RUN-1. When these signals RUN-1 and RUN are output, the corresponding channel (in the example of FIG. 13, channel CHO
) segment calculations, envelope and phase calculations, and tone waveform calculations are performed, thereby forming musical tones. The output of the run register 32 is also supplied to the key assigner 103 (FIG. 3) via the bus driver 33 and data bus 18. The “゜1” bit of this run register 32 is reset when musical tone formation is completed, and therefore the run register 32
The output indicates the channel where musical tone formation is currently being performed. The key assigner 103 uses this run register 32.
Based on the output of , it is detected whether musical tone formation is being performed in the current channel. Next, segment calculation will be explained. The segment memory 22 in FIG.
There are 0th to 15th memory slots (4 bits per slot) corresponding to HO to CHl5, respectively. 1L1 channel address signals CHA3 to 0 (see FIG. 15C) are supplied to the address terminal AD, and address signals 1A5 to A signal 1A1 of the first bit of 0 is supplied to the read/write terminal R/W. The data in the second 0th to 15th storage slots of this segment memory 22 are stored in channels CHO and CHO.
- Indicates the number of the segment currently being executed in CH15. For example, if the data in the 0th to 3rd storage slots are R3 and 121r5, respectively, then the current channels CHO to CH3 have segments 3 and 2, respectively.
, 5 shows that musical tone formation is occurring. The data read from this segment memory 22 is delayed by one base clock time by the selector register 21, and
It is output as address signals PSAj9 to PSAj6. Then, the lower 3 bits PSA of these address signals PSA9 to PSA
8 to 6 are supplied to address terminal AD2 of segment count memory 76 (FIG. 6). Note that this sector memory 22 is initially reset. Channel C now
When the sound generation is assigned to HO and then writing to the area corresponding to channel CHO of segment counter memory 76 is completed, the data in the 0th storage slot 1 corresponding to channel CHO of segment memory 22 is transferred to RO. It becomes u. Therefore, the signal RUN
-1 (Fig. 15 D) rises to "1", then the signal RU
At the time when N (FIG. 15) becomes ゜゜1゛, address signals PSA8 to PSA6 are ROJ, and this data R
O is the address terminal A of the segment count memory 76.
It is supplied to D2. In addition, address signals PlA5 to PlA1 (see FIG. 15) are sent to the address terminal ADl of the same memory 76.
is supplied. As a result, when the address signal PIA5~ is RO, the rate count data RCDO corresponding to channel CHO and segment 0 is read from the segment count memory 76, and the address signal PIA5~ is read out from the segment count memory 76.
When IA5-1 is RlJ, segment counter memory 7
Envelope count data ECDO corresponding to segment 0 and channel CHO is read from channel 6 (first
5) and is supplied to the distribution circuit 77. Distribution circuit 7
7 is a circuit that outputs input data from an output terminal A or B in accordance with a signal PIAl. At the time when the data RCDO is read from the segment counter memory 76, the signal PIAl (FIG. 15) is at '0', so that the data RCDO is output from the output terminal B of the distribution circuit 77. Here, in order to make the following explanation easier to understand, the data contents of the rate count data CD and envelope count data ECD and these data R
An overview of CD and ECD processing will be explained. First, the envelope count data ECD is, for example, 16-bit numerical data as shown in Table 3. Envelope count data ECD as shown in Table 3
In each segment, r1 is repeatedly subtracted from the initial value at a predetermined cycle, and when the subtraction result becomes RO, the segment ends and the next segment is started. For example, the data ECD regarding segment 0 is changed from the initial value Rl68 to Rl67 at a predetermined period. J, rl66. J
- r1yo and RlJ are sequentially decreased, and then the data ECD
is R.O. When reaching J, segment 0 ends. Also,
The late count data RCD is, for example, 16-bit data as shown in Table 4, but the lower 7 bits are RlJ from the envelope count data ECD mentioned above.
Numerical data that indicates the period of repeated subtraction, and
The 7th bit is a HOLD signal, and the upper 8 bits are data indicating the result of subtracting RlJ sequentially from the numerical value represented by the lower 7 bits. In this case, the HOLD signal is a control signal for sustaining musical tones in the same state, and in the case of sustained musical tones (organ sounds, etc.), the HOLD signal of rate count data RCD4 (rate count data corresponding to segment 4) becomes "1". Note that the HOLD signal becomes "1" only in this case. This late count data RCD
The numeric data of the lower 7 bits is initially transferred to the upper 8 bits of , and then becomes data indicating a value obtained by sequentially subtracting r'1 from this numeric value at a fixed timing. For example, in segment 0, since the lower 7 bits of data RCD are data R2lJ, the upper 8 bits of data will sequentially change R2lJ, r2O, Rl9, RlJ. When the data in the upper 8 bits of data RCD becomes ROJ, the numerical data in the lower 7 bits is again transferred to the upper 8 bits as is, and at this timing, the envelope count data EcD(7)RlJ is subtracted. I'm starting to repeat this. in this way,
By determining the time of each segment based on envelope count data ECD and rate count data RCD, the length of each segment can be finely and arbitrarily set using a small number of bits overall. In addition, in the following explanation,
Since each of the above data ECD and RCD is 7-complement data, subtraction of RlJ is performed by addition of RlJ. Now, the upper 8 bits of the rate count data RCDO output from the output terminal B of the distribution circuit 77 are applied to the input terminal A of the data selector 80, and the lower 7 bits are applied to the input terminal B of the data selector 80. In addition, the 7th bit of input terminal B of the selector 80 is “
゜0゛ is applied. The data selector 80 outputs the data of the human input terminal B when the output of the NOR circuit 83 which takes the NOR of each bit of the data supplied to the input terminal A is "1", and outputs the data of the human input terminal A when the output is "0". Output data. In this case, since the upper 8 bits of the rate count data RCDO are all “0”, the lower 7 bits of the rate count data RCDO
8-bit data obtained by adding "゜0゛" to the bits is output from the data selector 80 and supplied to the input terminal A of the adder 81. The adder 81 selects the output of the data selector 80 and the output of the OR gate 84 (゜゛1゛ or "゜0゛). The inverter 72 is connected to the first input terminal of the OR gate 84.
The input terminal of the inverter 72 is supplied with the seventh bit of the data RCD output from the output terminal B of the distribution circuit 77, that is, the HOLD signal. Further, a second input terminal of the OR gate 84 is supplied with a decay request signal DEQ, which will be described later. Therefore, H.O.
When the LD signal is ゛゜0゛, the output of the inverter 72 becomes ゜゜1゛, and this ゜"1゛ is supplied to the input terminal B of the adder 81 via the OR gate 84. As a result, the output of the inverter 72 becomes ゛゜1゛. Adder 81 adds R to the output data.
lJ is added, and the addition result is supplied to the upper 8 bits of input terminal B of data selector 73. Further, the lower 8 bits of the input terminal B of the data selector 73 contain the rate count data RCDO output from the distribution circuit 77.
The lower 8 bits are supplied. The data selector 73 outputs the data of the input terminal B when the address signal PIAl (FIG. 15) is ゜゛0゛, and when it is ``1'', it outputs the data of the input terminal A. Therefore, in this case, the input terminal Data B is output from the data selector 73 and supplied to the selector register 75.Then, this data is read into the register 75 at the timing of the clock pulse MCLK3, and then read into the segment count memory 76 at the timing of the clock pulse MCLK1. In this way, at the timing T.O shown in Figure 15, data RCDO is first read out, and RlJ is added to the read data RCDO (RlJ is added to the read data RCDO).
lJ is subtracted), then the data after this addition is used as the upper 8 bits, and the data RCDO before addition is used as the lower 8 bits is again the data RCDO in the memo 1J76.
is written to the location. Next, time T shown in the 15th diagram.
At timing 1, envelope count data ECDO is read from segment count memory 76 and supplied to distribution circuit 77. At this time, the signal PIAl
is in the "F" signal, therefore, the data ECDO is output from the output terminal A of the distribution circuit 77 and supplied to the input terminal A of the adder 78.The output of the OR gate 82 is supplied to the input terminal B of the adder 78. Supplied by Orgate 82
A stamp request signal DAQ (always at 0) is supplied to the first input terminal of , and the output of a delay circuit (delay time=2 base clock times) 85 is supplied to the second input terminal. Further, a signal from the carry-out terminal CO of the adder 81 is supplied to the input terminal of the delay circuit 85. The time T mentioned above
. At O, if the carry out output of adder 81 is O”
and therefore time T. In l, the delay circuit 85
The output signal becomes "0", and this signal "0" is supplied to the input terminal B of the adder 78 via the OR gate 82. As a result, the envelope count data ECDO supplied to the input terminal A of the adder 78 is output from the adder 78 as is, and is supplied to the input terminal A of the data selector 73. At this time, the signal PIAl is "゜1", so the envelope count data ECDO output from the adder 78 is output from the selector 73, read into the selector register 75, and then read into the segment count memory 76. .In this way, at time T.l, the envelope count data ECDO is read from the segment count memory 76, and when the output of the delay circuit 85 is "゜0゛", the read data ECD
O is again written to the same location in memory 76. Below, address signals PIA5 to 1 (to Figure 15) are ROJ
RlJ is added to the rate count data RCDO every time the address signal PIA5-1 becomes RlJ, and the envelope count data ECDO is added to the memory 7
6 and then written to the same memory 76. Then, from the carry out terminal CO of adder 81゜“
When the 1゛ signal is output (when the upper 8 bits of data RCDO become RO), the delay circuit 85 outputs the ゜゜1'' signal with a delay of 2 base clock times, and the signal is sent to the input terminal of the adder 78 via the OR gate 82. B. This causes the envelope count data ECDO to contain rl
1 is added (11 is subtracted). Thereafter, the same process is repeated, and when the ゜゜1゛ signal is output from the carry out terminal CO of the adder 78 (data EC
When DO becomes ROJ), this “゜1゛” signal becomes signal FC.
The carry-in terminal C of the adder 25 shown in FIG.
Supplied to I. The above is the process of time measurement for channel CHO and segment 0. On the other hand, data corresponding to the channel CHO in the 0th storage slot of the segment memory 22 in FIG. The register 24 delays the supplied data by one base clock time and outputs it to the input terminal B of the adder 25.
Data ED is supplied to the input terminal A of the adder 25 from the decay dump control circuit 29. This data E
D is always r'0J, so register 2
The output data of No. 4 is the carry-in terminal CI of the adder 25.
When the signal ECCC゜l゛signal) is not supplied to
The signal is output as is from the adder 25 and supplied to the AND gate 26. AND gate 26 receives signal RUN (15th
When E) in the figure is ゛1゛, it is open and the output of the adder 25 is supplied to the input end of the segment memory 22.
The contents of the 0th memory slot corresponding to the channel CHO of the segment memory 22 are set to RO in the initial state, and even after the signal R[-1N rises to "゜1゛", ROJ continues.
Then, at the timing of channel CHO, signal ECC (
Rl only when the ゜゜1゛ signal) is supplied to the adder 25.
J (indicating segment 1). When the content of the 0th storage slot corresponding to channel CHO of the segment memory 22 becomes RlJ, the address signals PSA8 to PSA6 become r1, and this address signal 1 is supplied to the address terminal AD2 of the segment count memory 76 in FIG. be done. As a result, from now on, the rate count data RCDl (corresponding to segment 1) is set every time the address signals PIA5-1 become RO corresponding to the channel CHO, and the envelope count data Each ECDl is read from the segment count memory 76, and time measurement for segment 1 is performed in the same manner as described above. Then, when the signal ECC is outputted again from the carry-out terminal CO of the adder 78, the contents of the 0th storage slot corresponding to channel CHO of the segment memory 22 (Fig. 5) become 12J, and from then on, the time measurement of segment 2 is performed. When the time measurement for segment 2 is completed, time measurement for segments 3 to 7 is then performed sequentially. The above is the process of segment calculation. Note that the above process is a segment calculation process for channel CHO, but when sound generation assignment is performed for channels CH1 to CH15, the same process is performed. In this case, the time measurement of channel CHl is performed at time T1 shown in Fig. 15, . . .
The time measurement of l5 is performed at time Tl5 shown in the figure. In addition, in the above process, when the HOLD signal is "°1", the output of the inverter 72 is "0", and therefore the output of the OR gate 84 is "60", and this 4"0" signal is the output of the adder 81. is supplied to input terminal B of. As a result, the addition of 1+ in the adder 81 is not performed, the segment calculation substantially stops, and the segment continues to be in the state of 4 -. Note that the subsequent segment processing in this case will be explained in the subsequent key-off processing. ]) Envelope calculation At the time when the musical tone calculation period Tg shown in FIG. 13 begins, the envelope initial values 110NT, I20NT, A0NT are stored respectively, and envelope increment values Δ110, Δ120, ΔAO, Δ111,
Δ121, ΔAl, ... Δ117, Δ127, ΔA7
are stored respectively (see area EO in FIG. 9). In this state, when the address signals PIA5-0 become ROJ corresponding to the channel CHO (see time TaO shown in FIG. 16A), the initial value 111NT corresponding to the channel CHO is output from the envelope calculation memory 54 (the Also, the envelope increment value memory 66 outputs an increment value Δ110 corresponding to the channel CHO (see FIG. 16A). and,
The output of the envelope calculation memory 54 is supplied to the input terminal A of the adder 57, and the envelope increment value memory 6
The output of 6 is supplied to input terminal A of data selector 59. The data selector 59 outputs data RO when the output of the inverter 72 is 0 (HOLD signal is 1), and when the output of the inverter 72 is 1, the dump request signal DAQ is output. Input terminal A when “゜0゛”
When the signal DAQ is "1", the data at the input terminal B is output. At % of the time in FIG. 16A, the output of the inverter 72 is "1", and the dump request signal DAQ is "0". and
Therefore, the output Δ1 of the envelope increment value memory 66
10 is supplied to the input terminal B of the adder 57 via the data selector 59. As a result, data (
111NT+Δ11o) is output and sent to the input terminal A of the adder 58. External control data is supplied to input terminal B of this adder 58. This external control data is data that is supplied when, for example, the performer wants to directly control the volume, timbre, etc. of the generated musical tones during a performance, or when the performer wants to apply periodic modulation to the volume or timbre. shall be. Therefore, normally the data supplied to the input terminal A of the adder 58 is
The signal is outputted as is from MCLK3 and read into the selector register 51 at the timing of clock pulse MCLK3. The read data is then outputted from the same register 51 as ENVDATA15-0 (FIG. 16A, d), supplied to the tone calculation circuit shown in FIG. 7, and written into the envelope calculation memory 54 again. In this way, the signal P
Period 11 with IA5~0 in ROJ! In TTaO, data 1 corresponding to channel CHO is retrieved from memory 54.
11NT is read out, and then data Δ110 is added to this data 111NT, and the addition result is 11, +Δ1.
10 is ENV regarding data 11 of channel CH20
It is output as DATA15 to 0 and is also stored in the memory 54.
The data 111NT within is written to the location where it was stored. Next, when the signal PIA5-0 is turned on, data 1218+Δ120 is output as ENVDATA15-,0, and this data is written into the memory 54 in the same manner as the above-mentioned input. Then signal PIA5~
When 0 becomes R3J, channel CHO data AINT+ΔAO is output as ENVDATA15 to 0,
This data is also written into memory 54. The above is the processing for channel CFIO, and from now on, signal PIA
When signal PIA5-0 is 14-7, processing for channel CH1 is performed, and when signal PIA5-0 is 160-63, processing for channel CH15 is performed. Next, when the signals PIA5 to 0 become ROJ again, data 111NT+Δ110 is read out from the memory 54, Δ110 is added to this read data, and the addition result is 111NT+2.
Δ110 is output as ENVDATA15-0 and is written again into the memory 54, and the same process is repeated (see FIG. 16B). The above is the process of envelope computation, and in this way, the computations of equations (5) to (7), that is, the following computations are performed. Note that when the output of the inverter 72 is "0" (when the HOLD signal is "6F"), the output of the data selector 59 is RO.
Therefore, the data read from the memory 54 is ENVDATA as it is (without the increment value added).
It is output as l5-0 and is also rewritten into memory 54. In this case, of course, the envelope data A, 11, and 12 do not change. Note that, in reality, the output of the inverter 72 is supplied to the data selector 59 via a timing adjustment circuit, but a description of this point will be omitted. 3) Phase calculation The process of this phase calculation is almost the same as the envelope calculation process described above, so a detailed explanation will be omitted.
The outputs of the phase calculation memory 55 and the phase increment value memory 67 and FREQD are shown in FIGS. 16A and 16B, respectively.
Shows ATAl5-0. This data FREQDATA15-0 is supplied to the musical tone calculation circuit shown in FIG. This phase calculation is the above-mentioned (2)
This is the calculation of formula (4), that is, the calculation. Note that the external control data supplied to the input terminal B of the adder 61 is data supplied when frequency modulation (for example, bifrato) is applied to the musical tone, and when no frequency modulation is applied, it is ROJ.7) Musical sound waveform Operation This musical sound waveform calculation is a calculation for forming a musical sound waveform, and is performed by the musical sound calculation circuit shown in FIG.
Performed using VDATA15-0 and FREQDATA15-0. In FIG. 7, reference numeral 47 is a microprogram memory (ROM), and this memory 47 stores in advance microinstructions of 64 steps (16 bits per step) shown in FIG. In FIG. 17, the O mark indicates the "r" signal, and the blank space indicates the "0" signal. For example, the instruction TO in the first line of the diagram is the instruction "00...0111r". Also, the name of each bit signal is written at the top of the diagram. The function of each bit signal is as follows. -Channel address signals CHA3-0 (first
5th to 12th bits) As mentioned above, channel CHO
This is a signal indicating the processing timing for each of CH15 to CH15 (see FIGS. 12 and 15). ●Gate signal GATEMULK (7th bit) When this gate signal GATEMULK becomes "R5", the gate circuit 92 in FIG. 7 becomes open. -Select signal FREQSEL (6th bit) This select signal FREQSEL becomes 6'0" When this happens, the input terminal A of the selector register R3 in FIG. 7 is selected, and when it becomes "1", the input terminal B is selected. - Load signal LDB (5th bit) Then, the data is read into the output buffer 93 in FIG. 7. Load signal LDR5 (4th bit) When this load signal LDR5 becomes "1", the register
5 (FIG. 7). - Load signal LDR4 (3rd bit) When this load signal LDR4 becomes ゜゜1゛. Data is read into register R4. - Load signal LDR3 (second bit) When this load signal LDR3 reaches ゜゛F゛, the data selected by the above-mentioned select signal FREQSEL is read into the register R3.・Load signal LDR2 (1st bit) This load signal L
When DR2 becomes ゜゜1゛, data is read into register R2.・Load signal [J) R1 (0th bit) When this load signal LDRl becomes “4r”, ・data is read into register R1. Also, the number written inside the O mark in FIG.
Channels CHO to CHl processed by that signal
It shows the number 5. Each instruction in the above-mentioned microprogram memory 47 is read out by address signals 1A5-0. That is,
When the address signal 1A5-0 is ROJ, the instruction TO in FIG. 17 is read out, and when the address signal 1A5-0 is RlJ, the instruction T1 is read out,
When R63J, instruction T63 is read. Of the bit signals included in the read instruction, the channel address signals CH3 to CH0 are output to each part of the circuit shown in FIGS. After being delayed by the base clock time, it is output to FIG. Next, the operation of the circuit shown in FIG. 7 will be explained with reference to FIGS. 17 and 18. First, FIG. 18 shows clock pulse MCLKl, address signals 1A5-0, PIA5-0, ENDATA15-0.
, FREQDATA15-0 and FIG. 7 is a timing diagram showing the interrelationship of outputs of each part. In this figure, the numbers ROJ and RLO in the lower right corner of the rectangular frame indicate channel numbers, respectively. Further, each microinstruction TO to T63 in the microprogram memory 47 in FIG.
As mentioned above, the address signal 1A5-0 (Figure 18)
Therefore, it is constantly read out repeatedly. Then, each of the read microinstructions TO to T63 is delayed by one base clock time by the instruction register 48 and
Output to each part of the diagram. On the other hand, address signals PIA5~
0 (FIG. 18C) is a signal obtained by delaying address signals 1A5-0 by one base clock time. Therefore, as shown in FIG. 18C and F, the address signal PIA5
When ~0 is RO, the microinstruction TO is output from the instruction register 48, and the address signal PIA
Instruction register 48 when 5 to 0 is R63J
A microinstruction T63 is output from the microinstruction T63. In addition, the aforementioned data ENVDATA15-0 and FREQDATA
The timing at which l5-0 is supplied to the circuit of FIG. 7 is as shown in FIGS. 16A and 16B, 2 and 5, and these data are transferred to FIGS. 18, 2 and 5, respectively. In addition, ω1, ω2, ω in FIG. 18E. instead of ω
1t, ω2t, ω0t1 as mentioned above (
This is to make the correspondence with formula 1) easier to understand. The operation of the circuit shown in FIG. 7 will be described below with reference to FIG. First, the time TO (first
8), the microinstruction TO is output from the instruction register 48 in FIG.
Also, at this time, channel C is connected to the input terminal of register R1.
HO ENVDATA15 to 0rI1J are supplied, and channel CHO is supplied to input terminal A of selector register R3.
FREQDATAAl5~0r0)1tJ is supplied. When the microinstruction TO is output from the instruction register 48, the load signals LDR1 to LDR4
(see FIG. 17) are supplied to registers R1 to R4, respectively. Here, load signals LDR1 and LDR3 are signals for forming a musical tone signal of channel CHO, while load signals LDR2 and LDR4 are signals for forming a musical tone signal of channel CH15. Hereinafter, only the case of forming a musical tone signal for channel CHO will be explained. When load signals LDR1 and LDR3 are supplied to registers R1 and R3, respectively, registers R1 and R
The above data 11 and ω1t are read into 3 (
(See Figure 18, Figure 18). In addition, at this time, the select signal FR
EQSEL is 0, and input terminal A of register R3 is selected. When the data ω1 is read into the register R3, this data ω1t is supplied to the sign table 96, and as a result, the data ω1t is read from the sign table 96.
is output (see Fig. 18E). Next, at time t1, ENVDATA15~0 is sent to the input terminal of register R1.
rI2J is also connected to input terminal A-. of register R3. F.R.E.
QDATA15~0'ω2tJ are each supplied, and
Microinstruction T1 from instruction register 48
(See FIG. 17) is output. This microinstruction T1 causes the load signal 1J) R1 to
LDR4 is supplied to each register R1-R4, and each data shown in FIG. 18 is read into each register R1-R4. Further, when the data ω2t is read into the register R3 and supplied to the sine table 96, the sine table 96 outputs the data Sinω2t. Also, register R
Data Sinω1t is read into register R2, data 11 is read into register R2, and these data are respectively input to multiplier 9.
When 0 is supplied, data 11Sinω is output from the multiplier 90.
1t is output (FIG. 18W). Also, at this time, the gate signal GATEMUIK is "0", so the output of the gate circuit 92 is 0 (18th diagram).
When the multiplier 90 outputs the data 11 sin ω 1t and the gate circuit 92 outputs data 0, the output of the adder 91 becomes 11 sin ω 1 t (FIG. 18 y).
. Next, at time T2, microinstruction T2 is output from instruction register 48. This causes load signals LDR2, LDR4, LDR5 to be applied to registers R2, R4. R5, each register R2, R
4, each data shown in FIG. 18 is read into R5. Note that the data in registers R1 and R3 are the same as the data at time t1. Also at this time, sign table 96,
The outputs of the multiplier 90 and the adder 91 are as shown in the figure. Next, at time T3, microinstruction T3 is output from instruction register 48. As a result, the load signals LDR1, LDR3, the select signal FREQSEL1, and the gate signal GATEMULK are supplied to the registers R1, R3 and the gate circuit 92, respectively.
When the load signal LDRl is supplied to the register R1, data A is read into the register R1. Also, at this time T3
In registers R2, R4 . The data in R5 is time T
The data is the same as in 2. Therefore, multiplier 9
The output of 0 becomes data I2sinω2t, and the output of register R5 becomes data 11sinω1t. Here, when the gate circuit 92 is opened by the gate signal GAlEMULK, the output of the adder 91 becomes the data 11.
Sinω1t+I2Sinω2t, and this data is supplied to the input terminal B of the adder 95. As a result, the output of the adder 95 is data ω. t+11Sinω1+I2S
inω2, and this data is supplied to input terminal B of register R3. Here, load signal 1 to register R3
J) When both R3 and the select signal FREQSEL are supplied, the data at the input terminal B of the register R3 is read into the register R3 and supplied to the sign table 96. As a result, at time T3, from the sign table 96, Sin(ω0t+11Sinω1t+I2Sinω
2t) is output (see FIG. 18). Next, at time T4, microinstruction T4 is output from instruction register 48. This results in
The load signals LDRl~1J)R4 are respectively applied to the registers R1~
R4, and each data shown in the figure is sent to registers R1 to R.
4. Here, each data read into registers R2 and R4 is data for forming a musical tone signal of channel CHO, while data read into registers Rl and R3 is data for forming a musical tone signal of channel CH1. It is data. That is, from this time T4, musical tone signal formation for channel CH1 is started. Register R2
, R4 receives data A and data Si of channel CHO.
When n(ω0t+11Sinω1t+I2Sinω2t) is read, the multiplier 90 outputs Asin(ω0t+1
1Sinω1t+I2Sinω2t), that is, the data of the equation (1) for channel CHO, is output, and this data is output from the adder 91. Next, at time T5, microinstruction T5 is output from instruction register 48. As a result, load signal LDR5 is supplied to register R5, and the above data is read into register R5. Next, at time T6, the instruction register 48
A microinstruction T6 is output from the microinstruction T6. As a result, the load signal LDB is supplied to the output buffer 93, and the data Asin(ω0t+11Sinω1t+I2Sinω
2t) is read into the output buffer 93. Then, the data read into this output buffer 93 is
The signal is converted into an analog signal by the -A converter 94, and produced as a musical tone from a speaker (not shown). The above is the process of forming the channel L/CHO musical tone signal, and as described above, the channel CHO musical tone signal is formed between the address signals PIA5-0 and RO-6. Further, each musical tone signal of channels CH1 to CH15 is also formed in exactly the same process. In this case, the channel CHl
The musical tone signal of channel CH2 is formed when the signal PIA5-0 is R4-10J, and the musical tone signal of channel CH2 is formed when the signal PIA5-0 is R4-10J.
is formed when R8~14J, channel CHl5
The musical tone signal is generated when the signal circles A5-0 are R60-2J. Therefore, the operation of the circuit shown in FIG. 7 described above is constantly repeated. Therefore, for example, a musical tone is assigned to the channel HO, and then various data regarding the channel CHO is transferred in the data transfer period Tt in FIG. 13, and then the musical tone calculation period Tg in FIG. 13 is entered. ENVDATA15~0 and FREQDA of channel CHO
When TAl5-0 are sequentially supplied to the circuit of FIG. 7 at the timing of signals PIA5-0r0-3J, a tone signal of channel CHO is formed in the above process. on the other hand,
When channel CHO pronunciation is not assigned,
ENVDATA15~0 of the channel CHO mentioned above,
Both FREQDATA15 to 0 become ROJ, and musical tone formation is not performed. ) Key-off processing When a pressed key in the key group 102 (FIG. 3) is released, the key assigner 103 selects the channel (CH) to which the released key is assigned a sound, as described above.
A Decay command or a dump command is output to instruct the end of the sound generation of 0 to CH15). The processes performed in response to these commands will be described below. (1) Processing for the Decay command For example, when instructing the end of sound generation on channel CHO, the key assigner 103 uses the 16-bit Decay command 66
00...01'' (the 0th bit is "1" and the other bits are 0'') is output together with the address signal. This Decay command is read into the Decay command register 38 shown in FIG. .Then clock pulse I
When NITCLK rises, the Decay command in register 38 is read into Decay register 39 and supplied to Decay multiplexer 40. The Decay multiplexer 40 has the same configuration as the eat multiplexer 34 and the run multiplexer 35 described above, and when the channel address signals CHA3 to CHA0 are RO, the data (
CH3
When ~0 is R15J, the signal of the 15th bit of the data at the human input end is output. The output of the decay multiplexer 40 is delayed by one base clock time by the register 41 and then outputted to the decay dump control circuit 29 as a signal DEOAY. Decay dump control circuit 29 detects that a Decay command is output on channel CHO based on the signal DECAY, and outputs Decay request signal DEQ when address signals PIA5 to PIA0 are R.
The output is performed at timings 0 to 3, and the following processing is performed. That is, when the data in the 0th storage slot corresponding to channel CHO of the segment memory 22 is output from the register 24, this data is checked,
The next data ED is output to the input terminal A of the adder 25 in accordance with the value of the same data. Through this processing, even if the tone formation of channel CHO at that time is in any of segments 0 to 4, the tone formation is forcibly shifted to segment 5, and thereafter the tone formation of segments 5 to 7 is performed. In addition, the musical tone formation of channel CHO is in segments 5 to 7.
In either case, musical tone formation continues as is. The above is the processing for the Decay command. (Ii
) Processing for the dump command For example, if you want to quickly end the sound of channel CHO, the key assigner 103 uses the 16-bit dump command 4.
'00...0r' (0th bit is "゜1゛)" is output together with the address signal. This dump command is read into the dump command register 42 shown in FIG. 5. Then, the clock pulse IN
When ITCLK rises, the dump command in register 42 is read into dump register 43 and supplied to dump multiplexer 44. Like the Decay multiplexer 40, the dump multiplexer 44 converts the data (16 bits) supplied to the input terminal based on the channel address signals CHA3 to CHA0 into serial data, and outputs the serial data to the register 41. The register 41 delays the output of the dump multiplexer 44 by one base clock time and outputs it to the decay dump control circuit 29 as a signal DAMP. Decay dump control circuit 29 controls channel CH based on this signal DAMP.
It is detected that the dump command for O is output, and thereafter, the dump request signal DAQC "1") is sent to the 6th address signal PIA5-0 at the timing of RO-3J.
It is output to the data selector 59 shown at the lower left of the figure. As a result, the envelopes 11, 12, and A of the channel CHO outputted from the envelope calculation memory 54 are each attenuated to 1-1164J by the attenuation circuit 63,
The data is supplied to the adder 57 via the data selector 59.
As a result, the generated musical tones are rapidly attenuated. The above is the processing for the dump command. Note that in the case of percussive musical tones, segments 9 to 7 may have already been completed at the time of key-off. In such a case, of course, no decay or dump command is output from the key assigner 103. )) Sound generation end processing The sound generation ends when the data in the segment memory 22 in FIG.
It is detected when VDATA15-0 (see FIG. 6) becomes negative. That is, the third bit of the output of the register 24 in FIG. 5 is supplied to the first input terminal of the OR gate 27. Also,
The negative data detection circuit 64 shown in the lower part of FIG.
When Al5~0 becomes negative, signal RER (゛゜1゛ signal)
This circuit outputs the signal RER, and this signal RER is supplied to the second input terminal of the OR gate 27. As a result, when the sound generation is finished, the OR gate 27 outputs the ゜“1゛ signal.
The signal is supplied to the sound generation end processing circuit 28. The sound generation end processing circuit 28 determines which channels CHO to C based on the output of the OR gate 27 and the channel address signals CHA3 to CHA0.
It detects whether the sound generation of El5 has ended, and outputs a 16-bit signal SFC indicating the ended channel CHO to CHl5. For example, when the channel CHO ends, ゜"11...10゛ (0th bit is ゜゜0゛) is output as the signal GFC. This signal SFC is sent to the run register 32.
, decay register 39, and dump register 43, thereby resetting the 0th bit of each of these registers 32, 39, and 43. When the 0th bit of the run register 32 is reset, since the output of the run register 32 is supplied to the key assigner 103,
The key assigner 103 detects the end of the sound generation of the channel CHO, and assigns a new sound generation to the channel CHO for subsequent key-on. In addition, in the description of the above embodiment,
Although this invention has been applied to an electronic organ, it is of course applicable to other similar electronic musical instruments. Furthermore, in the above embodiment, the envelope waveform is divided into 8 segments so that independent waveform calculation can be performed in each segment, but the number of divided segments is 8.
Not limited to individuals. Furthermore, the method of allocating the attack state, sustain state, and decay state of the musical sound waveform to the segments is not limited to that described in the above embodiment. [Effects of the Invention] As is clear from the above detailed description, according to the present invention, the assigner and the wave generator each operate independently, and therefore there are no design restrictions such as having them operate synchronously. There are benefits that do not arise. Further, according to the present invention, since the assigner sequentially outputs frequency data etc. to the wave generator for each channel via the bus line, there is an effect that the number of wiring between the assigner and the wave generator can be reduced. .

【図面の簡単な説明】[Brief explanation of drawings]

第1図および第2図各々、この発明の一実施例において
用いられる楽音波形形成の基本原理を説明するためのブ
ロック図および楽音信号のエンベロープ波形図、第3図
はこの発明の一実施例を適用した電子オルガンの構成を
示すブロック図、第4図〜第7図は各々同実施例におけ
るウエイブジエネレータ内の各部の構成例を示す回路図
、第8図は同実施例において用いられる各種クロックパ
ルスの波形図、第9図〜第11図は各々、同実施例にお
ける増分値データメモリ11、初期値データメモリ13
、セグメントデータメモリ15の各記憶内容を示す図、
第12図はメモリ11,13,15内のデータをメモリ
54,55,66,67,76へ各々転送する過程を説
明するためのタイミングチャート、第13図は信号1N
IT−1と信号RUN−1を説明するためのタイミング
チャート、第14図はメモリ54,55の記憶内容を示
す図、第15図は各セグメント0〜7の時間計測過程を
説明するためのタイミングチャート、第16A図、第1
6B図はエンベロープおよび位相演算の過程を説明する
ためのタイミングチャートであり、第16B図は第16
A図の続きである。 第17図はマイクロプログラムメモリ47から出力され
るマイクロ命令を示す図、第18図は第7図に示す楽音
演算回路の動作を説明するためのタイミングチャートで
ある。11・・・・・・増分値データメモリ、13・・
・・・・初期値データメモリ、15・・・・・セグメン
トデータメモ■八22・・・・セグメントメモリ、54
・・・・・エンベロープ演算メモリ、55・・・・位相
演算メモリ、57,60・・・・アダー、66・・・・
エンベロープ増分値メモリ、67・・・・・・位相増分
値メモリ、76・・セグメントカウンタメモl八103
・・・・・・キーアサイナ、104・・・・・・ウエイ
ブジエネレータ、108・・・楽音波形形成部。
1 and 2 are a block diagram and an envelope waveform diagram of a musical tone signal, respectively, for explaining the basic principle of musical sound waveform formation used in an embodiment of the present invention, and FIG. 3 is a diagram illustrating an embodiment of the present invention. A block diagram showing the configuration of the applied electronic organ, FIGS. 4 to 7 are circuit diagrams showing examples of the configuration of each part in the wave generator in the same embodiment, and FIG. 8 shows various clocks used in the same embodiment. The pulse waveform diagrams, FIGS. 9 to 11, respectively show the incremental value data memory 11 and the initial value data memory 13 in the same embodiment.
, a diagram showing each storage content of the segment data memory 15,
FIG. 12 is a timing chart for explaining the process of transferring data in the memories 11, 13, and 15 to the memories 54, 55, 66, 67, and 76, respectively, and FIG. 13 is a timing chart for the signal 1N.
A timing chart for explaining IT-1 and signal RUN-1, FIG. 14 is a diagram showing the storage contents of the memories 54 and 55, and FIG. 15 is a timing chart for explaining the time measurement process of each segment 0 to 7. Chart, Figure 16A, No. 1
Figure 6B is a timing chart for explaining the process of envelope and phase calculation, and Figure 16B is a timing chart for explaining the process of envelope and phase calculation.
This is a continuation of Figure A. FIG. 17 is a diagram showing microinstructions output from the microprogram memory 47, and FIG. 18 is a timing chart for explaining the operation of the musical tone calculation circuit shown in FIG. 7. 11... Incremental value data memory, 13...
... Initial value data memory, 15 ... Segment data memo ■822 ... Segment memory, 54
... Envelope calculation memory, 55 ... Phase calculation memory, 57, 60 ... Adder, 66 ...
Envelope increment value memory, 67...Phase increment value memory, 76...Segment counter memory 18103
. . . Key assigner, 104 . . . Wave generator, 108 . . . Musical waveform forming unit.

Claims (1)

【特許請求の範囲】 1 鍵盤キーの操作により選択された音を複数のチャン
ネルのいずれかに割り当てるアサイナと、このアサイナ
の割当てに対応して各チャンネルごとに当該チャンネル
に割り当てられた音の楽音波形を発生するウエイブジエ
ネレータとを具示た電子楽器において、上記アサイナは
、上記各チヤンネルへの音の割当に対応して割り当てた
音に関する周波数データおよびエンベロープデータを各
チャンネルごとにバスに順次出力するものであり、上記
ウエイブジエネレータは、 (a)上記バスに送出された上記周波数データおよびエ
ンベロープデータを上記各チャンネルごとにそれぞれ記
憶する記憶手段と、(b)上記記憶手段に記憶された周
波数データを各チャンネルごとにそれぞれ演算して各チ
ャンネルの位相データを形成して時分割出力する第1の
演算手段と、(c)上記記憶手段に記憶されたエンベロ
ープデータを各チャンネルごとにそれぞれ演算して各チ
ャンネルのエンベロープ波形データを形成して時分割出
力する第2の演算手段と、(d)上記第1および第2の
演算手段から出される位相データおよびエンベロープ波
形データに基づき各チャンネルごとに時分割で楽音波形
を形成する楽音波形形成手段と、を設けた電子楽器。
[Claims] 1. An assigner that assigns a sound selected by operating a keyboard key to one of a plurality of channels, and a musical waveform of the sound assigned to each channel in accordance with the assignment of the assigner. In the electronic musical instrument, the assigner sequentially outputs frequency data and envelope data regarding the assigned sound to the bus for each channel in accordance with the assignment of the sound to each channel. The wave generator includes (a) storage means for storing the frequency data and envelope data sent to the bus for each channel, and (b) the frequency data stored in the storage means. (c) calculating the envelope data stored in the storage means for each channel; and (c) calculating the envelope data stored in the storage means for each channel. (d) time-sharing for each channel based on the phase data and envelope waveform data output from the first and second calculating means; An electronic musical instrument is provided with a musical sound waveform forming means for forming a musical sound waveform.
JP51158948A 1976-12-29 1976-12-29 electronic musical instruments Expired JPS6042954B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP51158948A JPS6042954B2 (en) 1976-12-29 1976-12-29 electronic musical instruments

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP51158948A JPS6042954B2 (en) 1976-12-29 1976-12-29 electronic musical instruments

Publications (2)

Publication Number Publication Date
JPS5383610A JPS5383610A (en) 1978-07-24
JPS6042954B2 true JPS6042954B2 (en) 1985-09-25

Family

ID=15682821

Family Applications (1)

Application Number Title Priority Date Filing Date
JP51158948A Expired JPS6042954B2 (en) 1976-12-29 1976-12-29 electronic musical instruments

Country Status (1)

Country Link
JP (1) JPS6042954B2 (en)

Families Citing this family (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5583095A (en) * 1978-12-18 1980-06-23 Kawai Musical Instr Mfg Co Allocating device for keyboarddswitch information
JPS55103595A (en) * 1979-01-31 1980-08-07 Kawai Musical Instr Mfg Co Electronic musical instrument
JPS55103596A (en) * 1979-01-31 1980-08-07 Kawai Musical Instr Mfg Co Electronic musical instrument
JPS55103597A (en) * 1979-02-03 1980-08-07 Kawai Musical Instr Mfg Co Electronic musical instrument
JPS55105296A (en) * 1979-02-05 1980-08-12 Kawai Musical Instr Mfg Co Electronic musical instrument
JPS56149090A (en) * 1980-04-21 1981-11-18 Matsushita Electric Ind Co Ltd Electronic musical instrument
JPS56149091A (en) * 1980-04-21 1981-11-18 Matsushita Electric Ind Co Ltd Electronic musical instrument
JPS6241196U (en) * 1986-08-14 1987-03-12
JPS6347917Y2 (en) * 1986-09-03 1988-12-09
JPS6328476Y2 (en) * 1986-09-03 1988-08-01
JPS6271696U (en) * 1986-09-03 1987-05-07

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS4834523A (en) * 1971-09-04 1973-05-19
JPS5143912A (en) * 1974-09-27 1976-04-15 Nippon Musical Instruments Mfg
JPS52132818A (en) * 1976-04-28 1977-11-07 Nat Res Dev Harmonic digital generator for electronic instrument

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS4834523A (en) * 1971-09-04 1973-05-19
JPS5143912A (en) * 1974-09-27 1976-04-15 Nippon Musical Instruments Mfg
JPS52132818A (en) * 1976-04-28 1977-11-07 Nat Res Dev Harmonic digital generator for electronic instrument

Also Published As

Publication number Publication date
JPS5383610A (en) 1978-07-24

Similar Documents

Publication Publication Date Title
JP3243821B2 (en) Electronic musical instrument
JPS6042954B2 (en) electronic musical instruments
KR100411940B1 (en) Signal processing device
EP0218912A2 (en) Special effects device for an electronic musical instrument
US5625158A (en) Musical tone generating apparatus
US5486644A (en) Electronic musical instrument having a waveform memory for storing variable length waveform data
JPS6042953B2 (en) Wave generator for electronic musical instruments
JPS6042955B2 (en) Wave generator for electronic musical instruments
JPS6042952B2 (en) Wave generator for electronic musical instruments
JPS6114518B2 (en)
JPS6114519B2 (en)
JPS6330638B2 (en)
JP3230265B2 (en) Sound channel assignment device for electronic musical instruments
US11042380B2 (en) Apparatus, method and computer program for processing instruction
JPS58200297A (en) Envelope signal generator
JP2798077B2 (en) Sound source device for electronic musical instruments
JPS61123886A (en) Formation of musical sound
JP3721789B2 (en) Mixing equipment
JPS59838B2 (en) Initial touch response data generation circuit for electronic musical instruments
JP2727089B2 (en) Electronic musical instrument sound generator
JPS5846036B2 (en) electronic musical instruments
JPS6250898A (en) Electronic musical apparatus
JPH03269493A (en) Electronic musical instrument
JP3636580B2 (en) Sound generator for electronic musical instruments
JPS6341080B2 (en)