JP2004157350A - Performance information processing method, performance information processor, and program - Google Patents
Performance information processing method, performance information processor, and program Download PDFInfo
- Publication number
- JP2004157350A JP2004157350A JP2002323364A JP2002323364A JP2004157350A JP 2004157350 A JP2004157350 A JP 2004157350A JP 2002323364 A JP2002323364 A JP 2002323364A JP 2002323364 A JP2002323364 A JP 2002323364A JP 2004157350 A JP2004157350 A JP 2004157350A
- Authority
- JP
- Japan
- Prior art keywords
- performance information
- event
- data
- note
- information processing
- 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.)
- Granted
Links
Images
Landscapes
- Electrophonic Musical Instruments (AREA)
Abstract
Description
【0001】
【発明の属する技術分野】
本発明は、小型電子機器に用いて好適な演奏情報処理方法、演奏情報処理装置およびプログラムに関する。
【0002】
【従来の技術】
携帯電話、携帯情報ツールなどの小型の電子機器には簡易な音源が内蔵されており、着信メロディ、効果音などの楽音を発生させている。
一方、異なるシーケンサ、シーケンスソフトウェア間で演奏データの互換性を取り、相互にデータを利用するための標準フォーマットとしてスタンダードMIDIフォーマット(SMF)が知られている。なお、コンテンツ(たとえば、演奏情報)は専用のオーサリングツール(編集ツール)を用いて制作される場合が一般的であり、該コンテンツに一定の制限をかけることが出来る。また、特許文献1には、新たなノートオンが入力されたとき、発音中のノートイベントの中から同一または類似の発音を検出して加工する方法が開示されている。
【0003】
【特許文献1】特開平11−237879号公報
【0004】
【発明が解決しようとする課題】
しかし、小型電子機器に内蔵されている音源は最大発音数(チャンネル数)が少ない場合があり、小型電子機器内部でSMFに対してDVA(dynamic Voice Allocation)を行うと発音数を超えるようなコンテンツを再生する際には、非常な負荷がかかり、発音再生の遅れ、いわゆるもたりや、再生がとぎれるなどの問題が起こりやすくなる。ここで、DVAとは音源の最大発音数を超えた場合に、音切れが生じないように各パートの発音優先順位や主要パートの発音する音数をあらかじめ動的に確保する機能をいう。さらに、携帯電話では、楽音合成に費やすことの出来る処理負荷がCPUパワーの10%程度に制限されるなどの制約もある。また、特許文献1の方法において発音数を削減しても、音源の同時発音数を超えることがある。
この発明は、上述した事情に鑑みてなされたものであり、小型電子機器での負荷を軽減することが出来る演奏情報処理方法、演奏情報処理装置およびプログラムを提供することを目的とする。
【0005】
【課題を解決するための手段】
上記課題を解決するため本発明にあっては、下記構成を具備することを特徴とする。なお、かっこ内は例示である。
請求項1記載の演奏情報処理方法においては、電子機器(携帯電話機、携帯情報端末)に内蔵される音源により再生される複数のイベントを有する演奏情報(SMFファイル)を変換する演奏情報処理方法において、同時に発音されるイベント数が所定の最大発音数を超える場合、所定の優先ルールに従って、前記イベントからトランケートするトランケートイベントを検出するトランケートイベント検出過程と、同時に発音される楽音の数が前記最大発音数以下になるように、前記演奏情報を、前記トランケートイベントに応じて変換する変換過程とを有することを特徴とする。
さらに、請求項2記載の演奏情報処理方法にあっては、前記最大発音数の設定を行う最大発音数設定過程を有することを特徴とする。
さらに、請求項3記載の演奏情報処理方法にあっては、複数の異なる優先方式から前記優先ルールを選択する優先ルール選択過程を含むことを特徴とする。
また、請求項4記載の演奏情報処理方法にあっては、前記トランケートイベント検出過程は、前記同時に発音される楽音に係るイベント数が前記最大発音数を超える場合に、最も古いイベントをトランケートイベントとして検出する過程であり、前記変換過程は、該トランケートイベントに係る発音期間の最後部分を短縮するように前記演奏情報(SMFファイルにおけるDURATION)を修正する過程であることを特徴とする。
さらに、請求項5記載の演奏情報処理方法にあっては、前記同時に発音される楽音に係るイベント数が前記最大発音数を超えた時点に、前記トランケートイベントに対応したノートオフイベントを新たに挿入し、元のノートオフイベントを削除することによって最後部分を短縮することを特徴とする。
また、請求項6記載の演奏情報処理方法にあっては、前記トランケートイベント検出過程は、ノートオンとノートオフとの時間差が実質的に無い場合において、これらイベントの双方を、前記トランケートイベントとして検出する過程であり、前記変換過程は、前記トランケートイベントを削除する過程であることを特徴とする。
また、請求項7記載の演奏情報処理装置にあっては、請求項1ないし6の何れかに記載の演奏情報処理方法を実行することを特徴とする。
また、請求項8記載の演奏情報処理装置にあっては、放音する電子機器に前記演奏情報を出力する前に、請求項1記載の演奏情報処理方法を実行するように構成されていることを特徴とする。
また、請求項9記載のプログラムにあっては、請求項1ないし6の何れかに記載の演奏情報処理方法を実行させることを特徴とする。
【0006】
【発明の実施の形態】
1. 実施形態の構成
本発明の一実施形態である演奏情報処理装置の構成を図1を参照して説明する。
10は液晶表示パネルであり、最大発音数などの条件設定を行う画面が表示される。20はI/O制御部であり、ポインティングデバイス、USBインターフェース、MIDIインターフェース、携帯電話専用ケーブルが含まれる。ここで、USBインターフェースは、携帯情報端末とのインターフェース、楽音機器とのインターフェースに使用される。30はFDD部であり、SMFファイルを交換するためのフレキシブルディスクのリード/ライトを行う。40はHDD部であり、処理前後の演奏情報を保管する。50はCPUであり、各部を制御する。60はROMであり、プログラム、パラメータが記憶されている。70はRAMであり、ワークエリア、バッファとして使用される。90はバスラインであり、各部を接続する。以上の構成要素により、本実施形態の演奏情報処理装置100が構成される。
【0007】
2. 実施形態の動作
(1)SMFファイルの構造
SMFファイルにおいては、MIDI情報内の発音開始(ノートオンイベント)、発音停止(ノートオフイベント)などの情報に発生時間情報が付加される。図2(c)にSMFの各イベントでのデータ表記を示す。先頭はDURATIONデータであり、一つ前のイベントの開始時刻から次のイベントの開始時刻までの時間を示している。次のデータの集合は、ステータス、ノートナンバ、ベロシティの各データが設定される。ここで、ステータスは、nをチャンネル番号として、ノートオンメッセージの場合は「9n」であり、ノートオフメッセージの場合は「8n」である。ノートナンバは、音高を表し、ベロシティは、音量を表す。
【0008】
(2)同時に5チャンネルの音を発音し、所定時間後、同時に消音する場合
図2(b)における長方形の長辺(横方向)は音の長さを表している。それ故、図2(b)においては、同時に5チャンネルの音を発音し、所定時間後、同時に消音する場合の入力データの内容が示されている。この場合において、SMFデータには、DURATION「0」のデータおよびノートオンイベントデータの組み合わせが、第0チャンネルから第4チャンネルまでの5種類設けられる。そして、これらの発音時間に応じた任意のDURATIONデータが設けられ、その後に第0チャンネルのノートオフイベントデータが設けられ、さらに、他のチャンネルについて、DURATION「0」のデータおよびノートオフイベントデータの組み合わせが4種類設けられる。この場合において、SMFファイルが使用される電子機器の最大発音数が4音であれば、第4チャンネルのノートオンが出来ないため、第0チャンネルのノートオンをすぐにノートオフする必要がある。この結果、第0チャンネルの音が発音されることなく、第1チャンネルから第4チャンネルの音が発音されることになる。係る場合には電子機器におけるCPUの稼働時間を少なくするために、第0チャンネルのノートオンイベントデータおよびノートオフイベントデータを予め削除しておくことが望ましい。そこで、本実施形態においては、かかるイベントの削除(トランケート処理)が行われる。
【0009】
図2(b)に示す発音状態に対しては、具体的には図3(a)のようなSMFファイルが形成される。第1番目のデータは、DURATION「0」のデータである。2番目のデータは0チャンネルのノートオンイベントデータであり、ノートナンバ「60」、ベロシティ「7F」を表している。3番目のデータは、DURATION「0」のデータである。4番目のデータは第1チャンネルのノートオンイベントデータであり、ノートナンバ「50」、ベロシティ「7F」を表している。5番目から10番目のデータについても同様であるが、11番目のデータは、DURATION「10」のデータ、12番目のデータはノートナンバ「60」、ベロシティ「7F」、第0チャンネルのノートオフイベントデータである。さらに、13番目のDURATIONデータ、第1チャンネルのノートオフデータ等が続く。
【0010】
以下、上述したトランケート処理の詳細を説明する。
まず、演奏情報処理装置100において所定の操作が行われると、HDD部40に保管された処理前のSMFファイルのデータが読み込まれ、RAM70のワークエリアにて所定の処理がなされる。そして、SMFファイルは処理後HDD部40に再度保管される。
図5のルーチンが起動すると、ステップSP100においては、図4に示される画面が液晶表示パネル10上に表示され、優先モードの確認、最大発音数「4」の確認、(最大発音数+1)個分のバッファ確保が行われる。なお、詳細は後述するが、ノートオンイベントが発生すると、該イベントが該バッファに書き込まれ、ノートオフイベントが発生すると該バッファから対応するノートオンイベントが削除される。これにより、該バッファは各タイミングにおいて、発音中の楽音を表すデータが記憶されることになる。なお、優先モードの確認については、後着優先方式、先着優先方式、ドラム優先方式の選定がポインティングデバイスの設定により行われる。そして、処理はステップSP105に進む。
【0011】
ここで、後着優先方式とは、後から転送されたデータを優先的に発音して、古いデータの発音を停止する方式をいう。具体的には、図2(a)の場合において、最大発音数が4音の場合、第4チャンネルのイベントデータが転送されたときに、第0チャンネルの発音を強制的にa点で停止する方式をいう。それに対して、先着優先方式とは、第4チャンネルのイベントを発音させない方式である。ドラム優先方式とは、ドラムの音色を指定したイベントデータが転送されることによって、他の音色のイベントをノートオフさせる方式である。発音数確認においては、適用される電子機器の同時発音数に設定される。ここで、現在の音源の最大発音数は16音、32音、64音などがあるが、説明を簡単にするために以下「4」を最大発音数として説明する。
【0012】
ステップSP105においては、SMFファイルの未だ読み込まれていないイベントデータあるいはDURATIONデータのうち先頭のデータの読み込みが行われる。したがって、初回実行時には、第1番目のSMFデータの読み込みが行われる。そして、処理はステップSP110に進む。ステップSP110においては、データの種類が判定される。具体的には、DURATIONデータであるのか、ノートオンイベントデータであるのか、ノートオフイベントデータであるのかが判定される。ここで、第1番目のデータはDURATION「0」のデータであるので、ステップSP112に進み、該DURATIONデータがワークエリアに書き込まれる。そして、処理はステップSP105に戻る。
【0013】
そして、第2番目のSMFデータの読み込みが行われる。第2番目のデータは第0チャンネルのノートオンイベントデータであるので、ステップSP110を介して、処理はステップSP116に進む。ステップSP116においては、該ノートオンイベントデータがワークエリアに書き込まれ、さらに、バッファに格納される。なお、該バッファに書き込まれたデータの順番がメモリに記憶されており、一番古く書き込まれたデータが把握される。そして、処理はステップSP120に進む。ステップSP120においては、同時に発音される発音数が最大発音数を超えているか否かが判定される。現時点では、バッファ内のノートオンイベントデータ数が「1」であり、最大発音数「4」を超えないため、「NO」と判定され、処理はステップSP145に進む。ステップSP145においてはSMFデータの転送が終了しているか否かが判定される。転送が終了していないため、「NO」と判定され、処理はステップSP105に戻る。
【0014】
同様に、第1チャンネル、第2チャンネル、第3チャンネルのDURATIONデータ、ノートオンイベントがワークエリアに書き込まれ、さらに、バッファに格納される。そして、第4チャンネルのDURATIONデータがワークエリアに書き込まれ、処理はステップSP105に戻る。
【0015】
次に、第10番目のデータは第4チャンネルのノートオンイベントデータであるので、処理はステップSP105、SP110を介して、ステップSP116に進み、該ノートオンイベントデータがワークエリアに書き込まれ、さらにバッファに書き込まれる(図3(b))。ここで、図3(b)はバッファの状態を表している。そして、ステップSP120において、同時に発音される発音数が最大発音数を超えているか否かが判定される。この時点では、バッファ内のノートオンイベントデータの数が5つであり、最大発音数「4」を超えているため、「YES」と判定され、処理はステップSP130に進む。
【0016】
ステップSP130においては、トランケートするイベントが決定される。ここで、トランケートとは、SMFデータを編集する段階で、同時発音数を最大発音数以下に抑えるためにデータを追加/削除し、不要なデータを削除し、あるいはDURATIONを変更・短縮することである。具体的には、同時に発音されるイベント数が最大発音数を超える場合、後着優先方式においては、最も古いイベントをトランケートイベントとし、先着優先方式においては、最も新しいイベントをトランケートイベントとする。また、ノートオンとノートオフとの時間がほとんど無いイベントの双方を、トランケートイベントとする。図2(b)の場合、トランケートするイベントは最も古いイベントである第0チャンネルのノートオンイベントであると決定され、処理はステップSP135に進む。
【0017】
ステップSP135においては、ステップSP130において決定したイベントデータを削除するために、ワークエリアにおいて、ノートオフデータの作成、またはDURATIONの変更処理が行われる。この場合、第4チャンネルのイベントデータが転送されたとき、後着優先方式においては、第0チャンネルの発音を短縮するためにノートオフイベントデータが挿入される。すなわち、同時に発音される楽音の数が最大発音数以下になるように処理される。具体的には、DURATION「0」のデータおよびノートナンバ「60」、ベロシティ「7F」、第0チャンネルのノートオフイベントデータがワークエリアに追加される(図3(c)参照)。ここで、図3(c)から図3(e)は、ワークエリア内のデータ構造を時系列的に示している。そして、処理はステップSP140に進む。
【0018】
ステップSP140においては、無駄なデータが削除され、データの整理が行われる。具体的には、ノートオンとノートオフとの時間差が実質的に無い場合において、これらのイベントが削除され、さらに、バッファ内の整理が行われる。すなわち、第0チャンネルのノートオンイベントデータがバッファから削除される。さらに、ワークエリア内で第0チャンネルのノートオンイベントデータおよび追加されたノートオフイベントデータおよびそれらの前に設けられている値「0」のDURATIONデータが削除される(図3(d))。そして、処理はステップSP145に進む。ステップSP145において、転送が終了していないので、「NO」と判定され、処理はステップSP105に戻る。
【0019】
以下同様に、11番目のデータはDURATION「10」のデータであるから、ステップSP112において、該DURATIONデータがワークエリアに書き込まれる(図3(d))。次に、第12番目のデータは第0チャンネルのノートオフイベントデータであるので、処理はステップSP114に進む。ステップSP114においては、ワークエリアに該ノートオフイベントデータが書き込まれ、バッファ内の対応するノートオンイベントデータが削除される。ただし、バッファ内に対応するノートオンイベントデータが無い場合は、ワークエリアへの書き込みが行われない。今回の実行時においては、バッファ内から対応する第0チャンネルのノートオンイベントデータが削除されているため、該ノートオフイベントデータがワークエリアに書き込まれない(図3(d))。そして、ステップSP145においては、SMFデータの転送が終了していないので「NO」と判定され、処理はステップSP105に戻る。
【0020】
次に、13番目のSMFデータはDURATION「0」のデータであるので、ステップSP112を介して、該DURATIONデータがワークエリアに書き込まれる(図3(d))。ここで、13番目のDURATIONデータをそのまま書き込むと、第11番目のDURATIONデータと第13番目のDURATIONデータとが隣接配置されることになる。このように複数のDURATIONデータが隣接することは、データ量を無意味に増加させることになるため、これらDURATIONデータが一のDURATIONデータにまとめられる。すなわち、第13番目のデータであるDURATIONデータの値に、ワークエリア内に記憶されている第11番目のDURATIONデータの値が加算される。そして、第13番目のデータであるDURATIONデータがワークエリアに書き込まれる。このとき、第11番目のデータであるDURATIONデータは削除される。
【0021】
さらに、14番目のSMFデータは第1チャンネルのノートオフイベントであるので、処理はステップSP114に進む。この場合、該ノートオフイベントに対応する第1チャンネルのノートオンイベントデータがバッファ内に書き込まれているので、ワークエリアに該ノートオフイベントデータが書き込まれ(図3(d))、さらに、バッファに書き込まれている第1チャンネルのノートオンイベントデータが削除される。
【0022】
以下同様に、15番目以降のデータが処理され、ワークエリア内に図3(e)の演奏情報(SMFファイル)が生成される。そして、生成されたSMFファイルが、一旦、HDD部40に保管された後、I/O制御部を介して、電子機器に入力され、あるいは、フレキシブルディスクに記憶される。
【0023】
(3) 各発音チャンネルごとに発音開始時刻が異なる場合
図2(a)においては、第0チャンネルから第4チャンネルの5チャンネルが順番に発音開始し、一定時間発音後、順番に消音していく入力データの内容が示されている。この入力データを再生する場合も電子機器の発音チャンネルは4チャンネルしか用意されていないので、5チャンネル同時に発音することは出来ない。後着優先方式を採用すれば、第4チャンネルのノートオンデータが転送されるときに、最も古い第0チャンネルのノートオフタイミングが強制的にb点よりa点に変更され、発音時間が短縮される。
【0024】
この場合に入力されるSMFファイルは、第1番目のデータとして、DURATION「0」のデータが設けられ、2番目のデータとして第0チャンネルのノートオンイベントデータが設けられる。次に、第3番目のデータとして、一定時間(すなわち、第1チャンネルの発音から第2チャンネルの発音までの時間)のDURATIONデータが送られ、第4番目のデータとして第1チャンネルのノートオンイベントが設けられる。同様に、第2チャンネル、第3チャンネル、第4チャンネルについて、所定時間のDURATIONデータ、ノートオンイベントデータが設けられる。さらに、第11番目のデータとして、一定時間(すなわち、第4チャンネルの発音から第0チャンネルの消音までの時間)のDURATIONデータが設けられ、12番目のデータとして第0チャンネルのノートオフデータが設けられる。同様に、第1チャンネル、第2チャンネル、第3チャンネル、第4チャンネルについて、所定時間のDURATIONデータ、ノートオフイベントデータが設けられる。
【0025】
演奏情報処理装置100において所定の操作が行われると、図5のルーチンが起動する。ステップSP100において後着優先モードの確認、最大発音数「4」の確認、(最大発音数+1)個のバッファの確保が行われ、処理はステップSP105に進む。
【0026】
初回実行時には、ステップSP105、SP110を介して、第1番目のSMFデータの読み込みが行われ、データの種類が判定される。第1番目のデータはDURATION「0」のデータであるので、ワークエリアに該DURATIONデータが書き込まれる。さらに、第2番目のデータは、第0チャンネルのノートオンイベントデータであるので、ステップSP116において、該ノートオンイベントデータがワークエリアに書き込まれ、さらにバッファに書き込まれる。そして、ステップSP120およびステップSP145において、「NO」と判定され、処理はステップSP105に戻る。
【0027】
同様に、第1チャンネル、第2チャンネル、第3チャンネルのノートオンイベントがワークエリアに書き込まれ、さらに、バッファに書き込まれる。さらに、DURATIONデータがワークエリアに書き込まれ、処理はステップSP105に戻る。
【0028】
次の実行時に、10番目のデータは第4チャンネルのノートオンイベントデータであるので、ステップSP116において、該ノートオンイベントデータがワークエリアに書き込まれ、さらに、バッファに書き込まれる。そして、ステップSP120において、バッファ内のノートオンイベントデータが「5」であり、最大発音数「4」を超えているので「YES」と判定される。次に、処理がステップSP130に進むと、トランケートするイベントは最も古いイベントである第0チャンネルのイベントであると決定される。
【0029】
そして、ステップSP135において、第0チャンネルについてのノートオフイベントデータの作成がワークエリア内で行われる。すなわち、該ノートオフイベントデータは、9番目のデータであるDURATIONデータ(第3チャンネルのノートオンから第4チャンネルのノートオンまでの時間T(図2(a)参照))の後に追加される。したがって、第0チャンネルにおけるノートオフタイミングが時間T移動される。さらに、値「0」のDURATIONデータが、第4チャンネルのノートオンイベントの前、すなわち、新しく追加された第0チャンネルのノートオフイベントデータの後に設けられる。そして、ステップSP140において、バッファ内の第0チャンネルについてのデータが削除される。そして、ステップSP145を介して、処理はステップSP105に戻る。
【0030】
次の実行時、第11番目のデータは所定時間のDURATIONデータであるので、ワークエリアに該DURATIONデータが書き込まれる。次に、12番目のデータは第0チャンネルのノートオフイベントデータであるが、バッファ内に対応するノートオンイベントデータが存在しないので、ステップSP114において、該ノートオフイベントデータはワークエリアに書き込まれない。
【0031】
次の実行時、第13番目のデータであるDURATIONデータがワークエリアに書き込まれる。この場合、第13番目のデータであるDURATIONデータの値に、ワークエリア内に記憶されている第11番目のDURATIONデータの値が加算され、加算結果であるDURATIONデータがワークエリアに書き込まれる。このとき、第11番目のデータであるDURATIONデータは削除される。
【0032】
同様に、第15番目、第17番目のDURATIONデータおよび第2チャンネル、第3チャンネルのノートオフイベントデータがワークエリアに書き込まれ、さらに、バッファ内の対応するノートオンイベントが削除される。そして、ステップSP145において、SMFデータの転送が終了しているので本ルーチンが終了する。そして、生成されたSMFファイルが、一旦HDD部40に保管された後、I/O制御部を介して、電子機器に入力され、あるいは、フレキシブルディスクに記憶される。
【0033】
3. 変形例
本発明は上述した実施形態に限定されるものではなく、例えば以下のような種々の変形が可能であり、全て本発明の範疇に含まれる。
(1)上記実施形態は、SMFファイルに対して処理を行ったが、メーカー専用のエクスクルーシブメッセージファイルに対して処理を行ってもよい。
(2)上記実施形態は、ROM60に格納されたプログラムによって演奏情報処理方法を実行したが、パーソナルコンピュータ上で動作するアプリケーションプログラムによっても実行することが出来る。アプリケーションプログラムあるいは演奏情報処理方法を実行して得た演奏情報をCD−ROM、フレキシブルディスク等の記憶媒体に格納して頒布し、あるいは電気通信回線を通じて頒布してもよい。
【0034】
【発明の効果】
以上説明したように本発明によれば、同時に発音される楽音の数が前記最大発音数以下になるように、演奏情報を変換する変換過程を有しているので、同時に発音される楽音に係るイベント数が電子機器の最大発音数を超える演奏情報を最大発音数内に変換することが出来る。さらに、放音する電子機器に出力する前に、演奏情報を変換する構成によれば、該電子機器のCPU負荷を軽減することが出来る。
【図面の簡単な説明】
【図1】本発明の一実施形態である演奏情報処理装置の構成図である。
【図2】本発明の一実施形態である演奏情報処理方法を説明するための図およびイベント構造を説明するための図である。
【図3】本発明の一実施形態である演奏情報処理方法の具体例を示す図である。
【図4】操作パネル図である。
【図5】フローチャートを示す図である。
【符号の説明】
10…液晶表示パネル、20…I/O制御部、30…FDD部、40…HDD部、50…CPU、60…ROM、70…RAM、90…バスライン、100…演奏情報処理装置、200…イベント[0001]
TECHNICAL FIELD OF THE INVENTION
The present invention relates to a performance information processing method, a performance information processing apparatus, and a program suitable for use in a small electronic device.
[0002]
[Prior art]
A small electronic device such as a mobile phone or a portable information tool has a simple sound source built therein, and generates musical tones such as ringtones and sound effects.
On the other hand, a standard MIDI format (SMF) is known as a standard format for obtaining compatibility of performance data between different sequencers and sequence software and mutually using data. Note that content (for example, performance information) is generally produced using a dedicated authoring tool (editing tool), and a certain limit can be imposed on the content. Further,
[0003]
[Patent Document 1] Japanese Patent Application Laid-Open No. 11-237879
[0004]
[Problems to be solved by the invention]
However, a sound source built in a small electronic device may have a small maximum number of pronunciations (the number of channels), and a content that exceeds the number of pronunciations when DVA (dynamic Voice Allocation) is performed on the SMF inside the small electronic device. When reproducing is performed, a very large load is applied, and problems such as delay in sound reproduction, so-called fuzziness, and interruption of reproduction are likely to occur. Here, the DVA refers to a function of dynamically securing in advance the sounding priority of each part and the number of sounds to be emitted by the main part in advance so as to prevent sound interruption when the maximum number of sounds of the sound source is exceeded. Further, in a mobile phone, there is also a restriction that a processing load that can be spent for tone synthesis is limited to about 10% of the CPU power. Further, even if the number of sounds is reduced in the method of
The present invention has been made in view of the above circumstances, and has as its object to provide a performance information processing method, a performance information processing apparatus, and a program that can reduce the load on a small electronic device.
[0005]
[Means for Solving the Problems]
In order to solve the above problems, the present invention is characterized by having the following configuration. The contents in parentheses are examples.
The performance information processing method according to
Further, the performance information processing method according to the second aspect is characterized in that the method further comprises a maximum number of sounds setting step for setting the maximum number of sounds.
Further, the performance information processing method according to
In the performance information processing method according to the fourth aspect, the truncated event detecting step may include, when the number of events related to the simultaneously-produced musical tones exceeds the maximum number of sounds, sets the oldest event as a truncated event. The converting step is a step of correcting the performance information (DURATION in the SMF file) so as to shorten the last part of the sounding period related to the truncation event.
Further, in the performance information processing method according to the fifth aspect, a note-off event corresponding to the truncated event is newly inserted when the number of events related to the simultaneously generated musical sounds exceeds the maximum number of sounds. In addition, the last part is shortened by deleting the original note-off event.
In the performance information processing method according to claim 6, in the truncation event detecting step, when there is substantially no time difference between note-on and note-off, both of these events are detected as the truncated event. Wherein the converting step is a step of deleting the truncation event.
According to a seventh aspect of the present invention, there is provided a performance information processing apparatus for executing the performance information processing method according to any one of the first to sixth aspects.
Further, the performance information processing apparatus according to the present invention is configured to execute the performance information processing method according to the first aspect before outputting the performance information to an electronic device that emits sound. It is characterized by.
According to a ninth aspect of the present invention, there is provided a program for executing the performance information processing method according to any one of the first to sixth aspects.
[0006]
BEST MODE FOR CARRYING OUT THE INVENTION
1. Configuration of the embodiment
A configuration of a performance information processing apparatus according to an embodiment of the present invention will be described with reference to FIG.
[0007]
2. Operation of the embodiment
(1) Structure of SMF file
In the SMF file, occurrence time information is added to information such as sound generation start (note-on event) and sound generation stop (note-off event) in the MIDI information. FIG. 2C shows data notation in each event of the SMF. The beginning is DURATION data, which indicates the time from the start time of the previous event to the start time of the next event. In the next set of data, status, note number, and velocity data are set. Here, the status is “9n” for a note-on message and “8n” for a note-off message, where n is a channel number. The note number represents a pitch, and the velocity represents a volume.
[0008]
(2) When the sound of five channels is produced simultaneously and the sound is silenced after a predetermined time
The long side (horizontal direction) of the rectangle in FIG. 2B represents the length of the sound. Therefore, FIG. 2B shows the contents of the input data in the case where the sounds of the five channels are generated simultaneously and the sounds are simultaneously silenced after a predetermined time. In this case, the SMF data includes five types of combinations of DURATION “0” data and note-on event data from the 0th channel to the 4th channel. Arbitrary DURATION data corresponding to these sounding times is provided, followed by note-off event data of
[0009]
For the sound generation state shown in FIG. 2B, specifically, an SMF file as shown in FIG. 3A is formed. The first data is DURATION "0" data. The second data is the note-on event data of
[0010]
Hereinafter, details of the above-described truncation processing will be described.
First, when a predetermined operation is performed in the performance
When the routine of FIG. 5 is started, in step SP100, the screen shown in FIG. 4 is displayed on the liquid
[0011]
Here, the late arrival priority method refers to a method of giving priority to the data transferred later and stopping the sounding of old data. Specifically, in the case of FIG. 2A, if the maximum number of sounds is four, the sound of the zeroth channel is forcibly stopped at the point a when the event data of the fourth channel is transferred. Refers to the method. On the other hand, the first-come-first-served method is a method in which the event of the fourth channel is not generated. The drum priority method is a method in which event data specifying a drum timbre is transferred, so that events of other timbres are turned off. In confirmation of the number of sounds, the number of simultaneous sounds of the applicable electronic device is set. Here, the maximum number of pronunciations of the current sound source is 16, 32, 64, or the like, but for simplicity of description, “4” will be described below as the maximum number of pronunciations.
[0012]
In step SP105, the first data of the event data or the DURATION data of the SMF file which has not been read yet is read. Therefore, at the time of the first execution, the first SMF data is read. Then, the process proceeds to step SP110. In step SP110, the type of data is determined. Specifically, it is determined whether the data is DURATION data, note-on event data, or note-off event data. Here, since the first data is data of DURATION "0", the process proceeds to step SP112, and the DURATION data is written in the work area. Then, the process returns to step SP105.
[0013]
Then, the second SMF data is read. Since the second data is the note-on event data of the 0th channel, the process proceeds to step SP116 via step SP110. In step SP116, the note-on event data is written to the work area and further stored in the buffer. The order of the data written in the buffer is stored in the memory, and the oldest written data is recognized. Then, the process proceeds to step SP120. In step SP120, it is determined whether or not the number of sounds to be simultaneously generated exceeds the maximum number of sounds. At this time, the number of note-on event data in the buffer is “1” and does not exceed the maximum number of sounds “4”, so it is determined to be “NO” and the process proceeds to step SP145. In step SP145, it is determined whether the transfer of the SMF data has been completed. Since the transfer has not been completed, "NO" is determined, and the process returns to step SP105.
[0014]
Similarly, the DURATION data and the note-on event of the first channel, the second channel, and the third channel are written in the work area, and further stored in the buffer. Then, the DURATION data of the fourth channel is written to the work area, and the process returns to step SP105.
[0015]
Next, since the tenth data is the fourth channel note-on event data, the process proceeds to step SP116 via steps SP105 and SP110, where the note-on event data is written to the work area and further stored in the buffer. (FIG. 3B). Here, FIG. 3B shows the state of the buffer. Then, in step SP120, it is determined whether or not the number of sounds to be simultaneously generated exceeds the maximum number of sounds. At this point, since the number of note-on event data in the buffer is five, which exceeds the maximum number of sounds “4”, “YES” is determined, and the process proceeds to step SP130.
[0016]
In step SP130, an event to be truncated is determined. Here, truncation refers to adding / deleting data in order to reduce the number of simultaneous sounds to the maximum number of sounds or less, deleting unnecessary data, or changing or shortening the DURATION at the stage of editing the SMF data. is there. Specifically, when the number of simultaneously sounded events exceeds the maximum number of sounds, the oldest event is a truncated event in the last-arrived priority system, and the newest event is a truncated event in the first-arrived priority system. In addition, both events where there is little time between note-on and note-off are defined as truncation events. In the case of FIG. 2B, the event to be truncated is determined to be the oldest event, the note-on event of
[0017]
In step SP135, in order to delete the event data determined in step SP130, note-off data creation or DURATION change processing is performed in the work area. In this case, when the event data of the fourth channel is transferred, note-off event data is inserted in order to shorten the sound generation of the zeroth channel in the last-arrived priority system. That is, the processing is performed so that the number of musical tones that are simultaneously generated is equal to or less than the maximum number of tones. Specifically, data of DURATION “0”, note number “60”, velocity “7F”, and note-off event data of
[0018]
In step SP140, useless data is deleted, and data is organized. Specifically, when there is substantially no time difference between the note-on and the note-off, these events are deleted, and the buffer is further organized. That is, the note-on event data of
[0019]
Similarly, since the eleventh data is DURATION "10" data, the DURATION data is written to the work area in step SP112 (FIG. 3D). Next, since the twelfth data is the note-off event data of the 0th channel, the process proceeds to step SP114. In step SP114, the note-off event data is written in the work area, and the corresponding note-on event data in the buffer is deleted. However, when there is no corresponding note-on event data in the buffer, writing to the work area is not performed. At the time of this execution, since the note-on event data of the
[0020]
Next, since the thirteenth SMF data is DURATION "0" data, the DURATION data is written to the work area via step SP112 (FIG. 3D). Here, if the thirteenth DURATION data is written as it is, the eleventh DURATION data and the thirteenth DURATION data are arranged adjacently. Since a plurality of DURATION data are adjacent to each other as described above, the data amount is meaninglessly increased. Therefore, these DURATION data are combined into one DURATION data. That is, the value of the eleventh DURATION data stored in the work area is added to the value of the DURATION data that is the thirteenth data. Then, DURATION data, which is the thirteenth data, is written to the work area. At this time, the DURATION data which is the eleventh data is deleted.
[0021]
Further, since the 14th SMF data is a note-off event of the first channel, the process proceeds to step SP114. In this case, since the note-on event data of the first channel corresponding to the note-off event has been written in the buffer, the note-off event data is written in the work area (FIG. 3D). Is deleted from the first channel.
[0022]
Similarly, the 15th and subsequent data are processed, and the performance information (SMF file) shown in FIG. 3E is generated in the work area. Then, after the generated SMF file is temporarily stored in the
[0023]
(3) When the sounding start time differs for each sounding channel
FIG. 2A shows the contents of input data in which the five channels from the 0th channel to the 4th channel start to emit sound in order, and after the sound is emitted for a certain time, the sound is sequentially turned off. Also when reproducing the input data, only four channels of the electronic device are prepared, so that five channels cannot be generated simultaneously. If the late arrival priority method is adopted, when the note-on data of the fourth channel is transferred, the oldest note-off timing of the zeroth channel is forcibly changed from the point b to the point a, and the sounding time is shortened. You.
[0024]
In this case, the input SMF file has DURATION “0” data as the first data, and note-on event data of
[0025]
When a predetermined operation is performed in the performance
[0026]
At the first execution, the first SMF data is read via steps SP105 and SP110, and the type of data is determined. Since the first data is DURATION "0" data, the DURATION data is written in the work area. Further, since the second data is the note-on event data of the 0th channel, in step SP116, the note-on event data is written to the work area and further written to the buffer. Then, in steps SP120 and SP145, “NO” is determined, and the process returns to step SP105.
[0027]
Similarly, note-on events of the first channel, the second channel, and the third channel are written to the work area and further written to the buffer. Further, DURATION data is written to the work area, and the process returns to step SP105.
[0028]
At the next execution, the tenth data is the note-on event data of the fourth channel, so in step SP116, the note-on event data is written to the work area and further written to the buffer. Then, in step SP120, since the note-on event data in the buffer is "5" and exceeds the maximum number of sounds "4", "YES" is determined. Next, when the process proceeds to step SP130, the event to be truncated is determined to be the oldest event of the 0th channel.
[0029]
Then, in step SP135, note-off event data for the 0th channel is created in the work area. That is, the note-off event data is added after DURATION data (time T from note-on of the third channel to note-on of the fourth channel (see FIG. 2A)) that is ninth data. Therefore, the note-off timing in the 0th channel is shifted by time T. Further, DURATION data having a value “0” is provided before the note-on event of the fourth channel, that is, after the newly added note-off event data of the zeroth channel. Then, in step SP140, the data for the 0th channel in the buffer is deleted. Then, the processing returns to step SP105 via step SP145.
[0030]
At the next execution, the eleventh data is DURATION data for a predetermined time, so that the DURATION data is written to the work area. Next, the twelfth data is the note-off event data of the 0th channel, but since there is no corresponding note-on event data in the buffer, the note-off event data is not written to the work area in step SP114. .
[0031]
At the next execution, DURATION data, which is the thirteenth data, is written to the work area. In this case, the value of the eleventh DURATION data stored in the work area is added to the value of the DURATION data as the thirteenth data, and the DURATION data as the addition result is written to the work area. At this time, the DURATION data which is the eleventh data is deleted.
[0032]
Similarly, the fifteenth and seventeenth DURATION data and the note-off event data of the second and third channels are written to the work area, and the corresponding note-on event in the buffer is deleted. Then, in step SP145, since the transfer of the SMF data has been completed, this routine ends. Then, after the generated SMF file is temporarily stored in the
[0033]
3. Modified example
The present invention is not limited to the above-described embodiments, and for example, various modifications as described below are possible, and all of them are included in the scope of the present invention.
(1) In the above embodiment, the processing is performed on the SMF file. However, the processing may be performed on an exclusive message file dedicated to a maker.
(2) In the above embodiment, the performance information processing method is executed by a program stored in the
[0034]
【The invention's effect】
As described above, according to the present invention, since there is a conversion step of converting performance information so that the number of simultaneously-produced musical tones is equal to or less than the maximum number of pronunciations, the present invention relates to the simultaneously-produced musical tones. Performance information in which the number of events exceeds the maximum number of sounds of the electronic device can be converted into the maximum number of sounds. Further, according to the configuration in which the performance information is converted before outputting to the electronic device that emits sound, the CPU load of the electronic device can be reduced.
[Brief description of the drawings]
FIG. 1 is a configuration diagram of a performance information processing apparatus according to an embodiment of the present invention.
FIG. 2 is a diagram for explaining a performance information processing method according to an embodiment of the present invention and a diagram for explaining an event structure.
FIG. 3 is a diagram showing a specific example of a performance information processing method according to an embodiment of the present invention.
FIG. 4 is an operation panel diagram.
FIG. 5 is a diagram showing a flowchart.
[Explanation of symbols]
DESCRIPTION OF
Claims (9)
同時に発音されるイベント数が所定の最大発音数を超える場合、所定の優先ルールに従って、前記イベントからトランケートするトランケートイベントを検出するトランケートイベント検出過程と、
同時に発音される楽音の数が前記最大発音数以下になるように、前記演奏情報を、前記トランケートイベントに応じて変換する変換過程と
を有することを特徴とする演奏情報処理方法。In a performance information processing method for converting performance information having a plurality of events reproduced by a sound source built in an electronic device,
If the number of simultaneously pronounced events exceeds a predetermined maximum number of pronunciations, according to a predetermined priority rule, a truncated event detection step of detecting a truncated event to be truncated from the event,
Converting the performance information in accordance with the truncation event so that the number of simultaneously generated musical tones is equal to or less than the maximum number of sounds.
前記変換過程は、該トランケートイベントに係る発音期間の最後部分を短縮するように前記演奏情報を修正する過程である
ことを特徴とする請求項1記載の演奏情報処理方法。The truncated event detection step is a step of detecting the oldest event as a truncated event when the number of events related to the simultaneously generated musical sounds exceeds the maximum number of sounds,
2. The performance information processing method according to claim 1, wherein the conversion step is a step of correcting the performance information so as to shorten a last part of a sounding period related to the truncation event.
前記変換過程は、前記トランケートイベントを削除する過程である
ことを特徴とする請求項1記載の演奏情報処理方法。The truncated event detection step is a step of detecting both of these events as the truncated event when there is substantially no time difference between note-on and note-off,
2. The performance information processing method according to claim 1, wherein the conversion step is a step of deleting the truncation event.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2002323364A JP3982388B2 (en) | 2002-11-07 | 2002-11-07 | Performance information processing method, performance information processing apparatus and program |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2002323364A JP3982388B2 (en) | 2002-11-07 | 2002-11-07 | Performance information processing method, performance information processing apparatus and program |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2004157350A true JP2004157350A (en) | 2004-06-03 |
JP3982388B2 JP3982388B2 (en) | 2007-09-26 |
Family
ID=32803241
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2002323364A Expired - Fee Related JP3982388B2 (en) | 2002-11-07 | 2002-11-07 | Performance information processing method, performance information processing apparatus and program |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3982388B2 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2009008934A (en) * | 2007-06-28 | 2009-01-15 | Brother Ind Ltd | Music reproduction device |
JP2010522360A (en) * | 2007-03-22 | 2010-07-01 | クゥアルコム・インコーポレイテッド | Waveform fetch device for processing audio files |
JP2012189900A (en) * | 2011-03-11 | 2012-10-04 | Roland Corp | Electronic musical instrument |
-
2002
- 2002-11-07 JP JP2002323364A patent/JP3982388B2/en not_active Expired - Fee Related
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2010522360A (en) * | 2007-03-22 | 2010-07-01 | クゥアルコム・インコーポレイテッド | Waveform fetch device for processing audio files |
JP2009008934A (en) * | 2007-06-28 | 2009-01-15 | Brother Ind Ltd | Music reproduction device |
JP2012189900A (en) * | 2011-03-11 | 2012-10-04 | Roland Corp | Electronic musical instrument |
Also Published As
Publication number | Publication date |
---|---|
JP3982388B2 (en) | 2007-09-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4655812B2 (en) | Musical sound generator and program | |
JP5134078B2 (en) | Musical instrument digital interface hardware instructions | |
JP3293434B2 (en) | Tone generation method | |
US7279628B2 (en) | Editing apparatus of setting information for electronic music apparatuses | |
JP2004157350A (en) | Performance information processing method, performance information processor, and program | |
JP2002169564A (en) | Sound source system | |
JP3978928B2 (en) | Music generator | |
CN110322863B (en) | Electronic musical instrument, performance information storage method, and storage medium | |
JP3572847B2 (en) | Sound source system and method using computer software | |
JP7063354B2 (en) | Electronic musical instruments, performance information storage methods, and programs | |
JP3799711B2 (en) | Musical sound generation method and musical sound generator | |
JP3405181B2 (en) | Musical tone generation method | |
JP3278857B2 (en) | Musical tone generator | |
JP3781171B2 (en) | Music generation method | |
JP4254677B2 (en) | Musical sound generator and musical sound generation processing program | |
JP3518357B2 (en) | Music generating method, musical sound generating apparatus and computer readable recording medium storing musical sound generating processing program | |
JP2005092191A (en) | Data exchange format of musical piece sequence data, sound source system, and musical piece file generation tool | |
JP2956550B2 (en) | Music sound generating apparatus and music sound generating method | |
JP2001228897A (en) | Speech input device and control method for the same, and memory medium stored with program code thereon | |
JPH10149161A (en) | Karaoke device | |
JP3031392B2 (en) | Performance reproducing apparatus and performance reproducing method | |
JP2006267173A (en) | Device and program to edit performance data | |
JP4674623B2 (en) | Sound source system and music file creation tool | |
JP2583377B2 (en) | Automatic performance device | |
JP2005215709A (en) | Musical sound generating device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20050728 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20060626 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20060711 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20060908 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20061107 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20070106 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20070227 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20070228 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20070612 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20070625 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100713 Year of fee payment: 3 |
|
R150 | Certificate of patent (=grant) or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100713 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110713 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110713 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120713 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130713 Year of fee payment: 6 |
|
LAPS | Cancellation because of no payment of annual fees |