JP5071441B2 - Music difficulty evaluation device and music difficulty evaluation program - Google Patents
Music difficulty evaluation device and music difficulty evaluation program Download PDFInfo
- Publication number
- JP5071441B2 JP5071441B2 JP2009129809A JP2009129809A JP5071441B2 JP 5071441 B2 JP5071441 B2 JP 5071441B2 JP 2009129809 A JP2009129809 A JP 2009129809A JP 2009129809 A JP2009129809 A JP 2009129809A JP 5071441 B2 JP5071441 B2 JP 5071441B2
- Authority
- JP
- Japan
- Prior art keywords
- classification
- value
- note
- music
- difficulty level
- 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.)
- Active
Links
Images
Landscapes
- Auxiliary Devices For Music (AREA)
- Electrophonic Musical Instruments (AREA)
Description
本発明は、楽曲の難易度を評価する楽曲難易度評価装置および楽曲難易度評価プログラムに関する。 The present invention relates to a music difficulty evaluation device and a music difficulty evaluation program for evaluating the difficulty of music.
従来、楽曲の難易度を評価するときに、音楽教育の専門家や演奏家が、その楽曲における種々の要素、たとえば、音符の連なりなどに基づいて、主観的な評価を行なっていた。従来の主観的な評価では、たとえば、楽曲の構成要素についての客観的な難易度は存在せず、楽曲全体としての評価(たとえば、10段階評価など)がなされているに過ぎない場合が多かった。 Conventionally, when evaluating the difficulty level of a music piece, music education specialists and performers have made subjective evaluations based on various elements in the music piece, for example, a series of musical notes. In the conventional subjective evaluation, for example, there is no objective difficulty level regarding the constituent elements of the music, and the evaluation of the entire music (for example, 10-level evaluation, etc.) is often performed. .
これに対して、楽曲を鍵盤楽器にて演奏する際の運指情報に基づいて、当該運指の難易度を算出する装置が提案されている。特許文献1には、ある音程の2音を2つの指にて押さえるような全ての場合を想定し、当該全ての場合のコストを定義し、運指情報が示す運指を行なう上での難易度を算出する難易度算出方法が提案されている。
On the other hand, an apparatus for calculating the degree of difficulty of fingering based on fingering information when playing a musical piece with a keyboard instrument has been proposed. In
しかしながら、従来の難易度を算出する装置では、2音を2つの指にて押さえるような全ての場合の全てについてコスト値を定義するのが容易ではないという問題点があった。また、楽曲の難易度は運指のみではなく、他にも種々の要素が存在する。したがって、他の要素も考慮したうえで難易度を算出することが望ましい。 However, the conventional apparatus for calculating the difficulty level has a problem that it is not easy to define cost values for all cases where two sounds are pressed with two fingers. In addition, the degree of difficulty of music is not limited to fingering, but includes various other elements. Therefore, it is desirable to calculate the difficulty level in consideration of other factors.
本発明は、楽曲を構成する種々の要素を考慮して、適切に楽曲の難易度を算出する楽曲難易度算出装置および楽曲難易度算出プログラムを提供することを目的とする。 An object of the present invention is to provide a music difficulty level calculation device and a music difficulty level calculation program that appropriately calculate the difficulty level of a music in consideration of various elements constituting the music.
本発明の目的は、楽曲を構成する音符ごとの音高情報、当該音符を押鍵する際の運指情報、および、当該音符についての時間情報を含む楽音データを格納した記憶手段と、
前記音高情報および運指情報に基づいて、隣接する音符を押鍵するときの指の状態夫々を表わす各分類項目について、当該各分類項目における具体的態様を表わす分類値のうち、少なくとも1つの分類項目についても分類値を取得するとともに、前記音符ごとに、前記分類項目中の分類値が所定の値であるときに、前記分類項目の分類値のカウント値を格納する、前記記憶手段中のカウントマップにおいて、対応するカウント値を増分させる第1の分類項目値取得手段と、
前記分類項目の夫々において、対応する前記カウントマップ中のカウント値を参照して、前記カウント値が「1」以上であるときに、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得するとともに、当該コスト値を累算し、前記累算されたコスト値を前記運指に関する難易度として取得する第1のコスト累算手段と、
前記音符についての時間情報に基づいて、音符長及び音符の小節中の位置に関する各分類項目について、当該分類項目夫々における具体的態様を示す分類値のうち、少なくとも1つの分類項目についても分類値を取得する第2の分類項目値取得手段と、
前記分類項目の夫々において、前記分類項目における分類値に基づいて、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得し、前記コスト値を累算し、前記累算されたコスト値を前記リズムに関する難易度として取得する第2のコスト累算手段と、
前記音符の音高情報に基づいて、前記楽曲の調性を特定し、前記特定された調性の音階と前記楽曲中の音符の音高との一致度、および、前記特定された調性の音階と前記楽曲中の音符の音高との不一致度に基づき、当該楽曲の調性に関する調性難易度を算出する調性難易度算出手段と、
前記取得された運指に関する難易度及びリズムに関する難易度と、前記算出された調性難易度とに基づき、楽曲の難易度を算出する全体難易度算出手段と、を備えたことを特徴とする楽曲難易度算出装置により達成される。
An object of the present invention is to store musical tone data including pitch information for each note constituting a musical piece, fingering information for pressing the note, and time information about the note;
Based on the pitch information and fingering information, for each classification item representing each state of a finger when pressing an adjacent note , at least one of the classification values representing a specific mode in each classification item A classification value is also acquired for a classification item, and a count value of the classification value of the classification item is stored for each note when the classification value in the classification item is a predetermined value. First count item value acquisition means for incrementing the corresponding count value in the count map;
In each of the classification items, with reference to the count value in the corresponding count map, when the count value is “1” or more, a cost value for the specific mode in the classification item is stored, A cost value for the specific mode in the classification item is acquired from a cost table in the storage means, the cost value is accumulated, and the accumulated cost value is acquired as a difficulty level for the fingering. 1 cost accumulating means,
Based on the time information about the note, for each classification item related to the note length and the position in the measure of the note, among the classification values indicating specific modes in each of the classification items, classification values are also obtained for at least one classification item. Second classification item value acquisition means for acquiring;
In each of the classification items, based on the classification value in the classification item, the cost value for the specific mode in the classification item is stored, and from the cost table in the storage unit, the specific mode in the classification item Second cost accumulating means for obtaining a cost value, accumulating the cost value, and obtaining the accumulated cost value as a difficulty level related to the rhythm;
The tonality of the music is specified based on the pitch information of the notes, the degree of coincidence between the scale of the specified tonality and the pitch of the notes in the music, and the specified tonality A tonality difficulty calculating means for calculating a tonality difficulty relating to the tonality of the music based on the disagreement between the scale and the pitch of the notes in the music;
An overall difficulty level calculating means for calculating the difficulty level of the music based on the acquired difficulty level regarding fingering and difficulty related to rhythm and the calculated tonality difficulty level; This is achieved by the music difficulty level calculation device.
好ましい実施例においては、前記第1の分類項目値取得手段が、
隣接する音符を押鍵するときの指のポジションに関する第1の分類項目について、当該分類項目における具体的態様を示す第1の分類値、隣接する音符を押鍵するときの指の開き具合に関する第2の分類項目について、当該第2の分類項目における具体的態様を示す第2の分類値、指くぐり或いは指返しに関する第3の分類項目について、当該第3の分類項目における具体的態様を示す第3の分類値、および、隣接する音符を押鍵するときの指換えに関する第4の分類項目について、当該第4の分類項目における具体的態様を示す第4の分類値のうち、少なくとも1つの分類項目について分類値を取得する。
In a preferred embodiment, the first classification item value acquisition means includes:
For the first classification item related to the finger position when pressing an adjacent note, the first classification value indicating a specific mode in the classification item, the first regarding the degree of opening of the finger when pressing an adjacent note For the second category item, the second category value indicating a specific mode in the second category item, the third category item relating to finger penetration or finger return, and the third category item indicating a specific mode in the third category item At least one classification among the fourth classification value indicating a specific mode in the fourth classification item, with respect to the fourth classification item related to finger change when pressing the adjacent note and the third classification value Get the classification value for the item .
より好ましい実施態様においては、前記調性難易度算出手段が、
前記一致度と不一致度との差異に対する前記不一致度の割合に基づいて、前記調性難易度を算出する。
In a more preferred embodiment, the tonality difficulty calculating means includes:
The tonality difficulty level is calculated based on the ratio of the mismatch level to the difference between the match level and the mismatch level.
また、好ましい実施態様においては、前記楽音データが、楽曲のテンポを示すデータを含み、
前記全体難易度算出手段が、前記運指に関する難易度およびリズムに関する難易度のそれぞれに、前記楽曲のテンポに応じた重みを与え、重みが与えられた運指に関する難易度およびリズムに関する難易度により全体難易度を算出するように構成されている。
In a preferred embodiment, the musical sound data includes data indicating the tempo of the music,
The whole difficulty calculation means, on each of difficulty regarding the difficulty and rhythm for said fingering, giving weight corresponding to the tempo of the music, the difficulty relating to the difficulty and rhythm about fingering weight given The total difficulty level is calculated.
また、別の好ましい実施態様においては、前記第1の分類値取得手段が、前記音符ごとに、前記運指に関する分類項目のそれぞれの分類値を、前記音符に関連付けて記憶手段に格納するように構成され、
前記楽曲を構成する音符が五線譜上に配置された楽譜を含む画像データを生成して表示装置の画面上に表示させる画像生成手段を備え、
前記画像生成手段が、前記音符のそれぞれについて、前記記憶手段に格納された、当該音符に関連付けられた、前記運指に関する分類項目の分類値が所定の値であるときに、前記音符が当該分類項目に該当することを示す印を配置した前記楽譜を含む画像データを生成するように構成されている。
In another preferred embodiment, the first classification value acquisition unit stores each classification value of the classification item related to the fingering in the storage unit in association with the note for each note. Configured,
Image generating means for generating image data including a musical score in which musical notes constituting the music are arranged on a musical score and displaying the image data on a screen of a display device;
For each of the notes, when the image generating means stores a classification value of a classification item related to the fingering, which is stored in the storage means, and is associated with the note, the note is classified into the classification Image data including the musical score in which a mark indicating that it corresponds to the item is arranged is generated.
さらに別の好ましい実施態様においては、前記第2の分類値取得手段が、前記音符ごとに、前記リズムに関する分類項目のそれぞれの分類値を、前記音符に関連付けて記憶手段に格納するように構成され、
前記楽曲を構成する音符が五線譜上に配置された楽譜を含む画像データを生成して表示装置の画面上に表示させる画像生成手段を備え、
前記画像生成手段が、前記音符のそれぞれについて、前記記憶手段に格納された、当該音符に関連付けられた、前記リズムに関する分類項目の分類値が所定の値であるときに、前記音符が当該分類項目に該当することを示す印を配置した前記楽譜を含む画像データを生成するように構成されている。
In still another preferred embodiment, the second classification value acquisition unit is configured to store, for each note, each classification value of the classification item related to the rhythm in the storage unit in association with the note. ,
Image generating means for generating image data including a musical score in which musical notes constituting the music are arranged on a musical score and displaying the image data on a screen of a display device;
For each of the notes, when the image generation means is associated with the note and the classification value of the classification item relating to the rhythm stored in the storage means is a predetermined value, the note is the classification item. The image data including the musical score in which a mark indicating that it corresponds to is arranged is generated.
また、本発明の目的は、楽曲を構成する音符ごとの音高情報、当該音符を押鍵する際の運指情報、および、当該音符についての時間情報を含む楽音データを格納した記憶手段を備えたコンピュータに、
前記音高情報および運指情報に基づいて、隣接する音符を押鍵するときの指の状態夫々を表わす各分類項目について、当該各分類項目における具体的態様を表わす分類値のうち、少なくとも1つの分類項目についても分類値を取得するとともに、前記音符ごとに、前記分類項目中の分類値が所定の値であるときに、前記分類項目の分類値のカウント値を格納する、前記記憶手段中のカウントマップにおいて、対応するカウント値を増分させる第1の分類項目値取得ステップと、
前記分類項目の夫々において、対応する前記カウントマップ中のカウント値を参照して、前記カウント値が「1」以上であるときに、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得するとともに、当該コスト値を累算し、前記累算されたコスト値を前記運指に関する難易度として取得する第1のコスト累算ステップと、
前記音符についての時間情報に基づいて、音符長及び音符の小節中の位置に関する各分類項目について、当該分類項目夫々における具体的態様を示す分類値のうち、少なくとも1つの分類項目についても分類値を取得する第2の分類項目値取得ステップと、
前記分類項目の夫々において、前記分類項目における分類値に基づいて、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得し、前記コスト値を累算し、前記累算されたコスト値を前記リズムに関する難易度として取得する第2のコスト累算ステップと、
前記音符の音高情報に基づいて、前記楽曲の調性を特定し、前記特定された調性の音階と前記楽曲中の音符の音高との一致度、および、前記特定された調性の音階と前記楽曲中の音符の音高との不一致度に基づき、当該楽曲の調性に関する調性難易度を算出する調性難易度算出ステップと、
前記取得された運指に関する難易度及びリズムに関する難易度と、前記算出された調性難易度とに基づき、楽曲の難易度を算出する全体難易度算出ステップと、
を実行させることを特徴とする楽曲難易度算出プログラムにより達成される。
Another object of the present invention is to provide storage means for storing musical tone data including pitch information for each note constituting a musical piece, fingering information for pressing the note, and time information about the note. Computer
Based on the pitch information and fingering information, for each classification item representing each state of a finger when pressing an adjacent note , at least one of the classification values representing a specific mode in each classification item It obtains the classification value also categories, the note your capital, when the classification value in the classification item is a predetermined value, and stores the count value of the classification values of the classification items, the storage means in A first classification item value acquisition step of incrementing a corresponding count value in the count map of:
In each of the classification items, with reference to the count value in the corresponding count map, when the count value is “1” or more, a cost value for the specific mode in the classification item is stored, A cost value for the specific mode in the classification item is acquired from a cost table in the storage means, the cost value is accumulated, and the accumulated cost value is acquired as a difficulty level for the fingering. 1 cost accumulation step;
Based on the time information for the note, for each classification item relating to the position of the note length and in the notes bar, among the classification item classification value indicating a specific aspect of each classification value also for at least one category A second classification item value acquisition step of acquiring
In each of the classification items, based on the classification value in the classification item, the cost value for the specific mode in the classification item is stored, and from the cost table in the storage unit, the specific mode in the classification item A second cost accumulation step of obtaining a cost value, accumulating the cost value, and obtaining the accumulated cost value as a difficulty relating to the rhythm;
The tonality of the music is specified based on the pitch information of the notes, the degree of coincidence between the scale of the specified tonality and the pitch of the notes in the music, and the specified tonality A tonality difficulty level calculating step for calculating a tonality difficulty level relating to the tonality of the music piece based on the degree of disagreement between the scale and the pitch of the notes in the music piece;
An overall difficulty level calculating step for calculating the difficulty level of the music based on the difficulty level regarding the acquired fingering and the difficulty level regarding the rhythm and the calculated tonality difficulty level ;
Is achieved by a music difficulty level calculation program characterized in that
本発明によれば、楽曲を構成する種々の要素を考慮して、適切に楽曲の難易度を算出する楽曲難易度算出装置および楽曲難易度算出プログラムを提供することが可能となる。 According to the present invention, it is possible to provide a music difficulty level calculation device and a music difficulty level calculation program that appropriately calculate the difficulty level of music in consideration of various elements constituting the music.
以下、添付図面を参照して、本発明の実施の形態について説明する。図1は、本発明の第1の実施の形態にかかる楽曲難易度評価装置の構成を示すブロックダイヤグラムである。図1に示すように、本実施の形態にかかる楽曲難易度評価装置10は、CPU11、ROM12、RAM13、大規模記憶装置14、入力装置15、表示装置16、サウンドシステム17および鍵盤18を有している。
Embodiments of the present invention will be described below with reference to the accompanying drawings. FIG. 1 is a block diagram showing the configuration of the music difficulty level evaluation device according to the first embodiment of the present invention. As shown in FIG. 1, the music
CPU11は、後述する楽曲の難易度を評価するための種々の処理(運指難易度評価処理、リズム難易度評価処理、調性難易度評価処理、全体難易度の算出処理)を実行する。ROM12は、楽音難易度を評価するための種々の処理(運指難易度評価処理、リズム難易度評価処理、調性難易度評価処理、全体難易度の算出処理)のプログラムや、処理に使用するパラメータなどを格納する。RAM13は、プログラムの実行の過程で生じたパラメータ、入力データ、出力データなどを一時的に記憶する。大規模記憶装置14は、ハードディスク装置やメモリカードなどであり、楽曲データなどを格納する。
The
入力装置15は、スイッチ類、キーボード、マウスなどを含み、操作者のスイッチ操作、キー操作、マウスの操作に基づく種々の指示などをCPU11に与える。表示装置12の画面上には、楽曲データに基づく楽譜、楽曲難易度の評価結果などを含む画像データが表示される。サウンドシステム40は、楽音生成回路、増幅器、スピーカなどを含み、楽曲データにしたがって、或いは、操作者による鍵盤18の押鍵操作にしたがって所定の楽音を生成して、楽音に基づく音響信号を出力する。なお、上記実施の形態において、鍵盤18は必須ではない。
The
また、本実施の形態にかかる楽曲難易度評価装置10は、鍵盤楽器の形態であっても良いし、或いは、パーソナルコンピュータのような形態であっても良い。鍵盤楽器の形態であれば、操作者は、表示装置16の画面上に表示された楽譜を参照して、鍵盤18の鍵を押鍵し、サウンドシステム17が、操作者の押鍵に応答して、押鍵された鍵の音高に対応する楽音データを生成することで、サウンドシステム17から楽音を出力することができる。
Further, the music difficulty
図2は、本実施の形態にかかる楽曲難易度評価装置10において実行される処理の概略を示すフローチャートである。図2に示すように、本実施の形態にかかる楽曲難易度評価装置10のCPU11は、RAM13に格納されたパラメータ等のクリア、表示装置16の画面上に表示された画像のクリアなどを含むイニシャライズを実行する(ステップ201)。次いで、CPU11は、操作者が入力装置15を操作して楽曲指定の入力があったかを判断する(ステップ202)。たとえば、楽曲指定の入力は、楽曲データの番号を入力することにより実現される。
FIG. 2 is a flowchart showing an outline of processing executed in the music
ステップ202でYesと判断された場合には、CPU11は、大規模記憶装置14に格納された楽曲データ群から、指定された楽曲の楽曲データを読み出して、RAM13に一時的に記憶する(ステップ203)。次いで、CPU11は、難易度評価処理を実行して、データを読み出された楽曲の難易度を示す値iCostを算出する(ステップ204)。ステップ202でNoと判断されると、CPU11は、難易度算出が行なわれた楽曲のそれぞれについて、算出された難易度と楽曲中の音符との関連を示す画像を生成して表示装置16の画面上に表示する難易度表示処理を実行する(ステップ205)。難易度評価処理および難易度表示処理については、以下に詳述する。
If it is determined Yes in
図3は、本実施の形態にかかる楽曲データのデータ構成例を示す図である。図3に示すように、ある楽曲の楽曲データは、音符(ノート)ごとに、発音すべき楽音を示す楽音データのレコード(符号301、302参照)を有する。楽音データのレコード(たとえば、先頭のノートのレコードNote[0]:符号301)は、音高情報「Pit」、鍵盤位置情報「Pos」、運指情報「Fig」、発音時刻「Time」、発音時間「Gate」、次のノートのレコードへのポインタ「*Next」および前のノートのレコードへのポインタ「*prev」という項目を含む。
FIG. 3 is a diagram illustrating a data configuration example of music data according to the present embodiment. As shown in FIG. 3, the music data of a certain music has a record of musical sound data (see
音高情報「Pit」は、たとえば、音名「C−1」を「0」として、音高が1つ高くなるごとに「1」を増分させた値である。鍵盤位置情報「Pos」は、当該音高に対応する鍵の横方向の中心位置を示す座標値である。たとえば、図16に示すように、ある位置のC(たとえば、C4:Pit=60)の鍵盤位置情報Pos=X0とすると、C#4〜C5までの鍵盤位置情報は、それぞれ、X1〜X12で示すような値となる。図16から理解できるように、隣接する白鍵と黒鍵、黒鍵と白鍵との間の座標値の差は「1」である。その一方、連続する白鍵(EとF、BとC)との間の座標値の差は「2」となる。
The pitch information “Pit” is, for example, a value obtained by incrementing “1” every time the pitch is increased by setting the pitch name “C-1” to “0”. The keyboard position information “Pos” is a coordinate value indicating the lateral center position of the key corresponding to the pitch. For example, as shown in FIG. 16, if the keyboard position information Pos = X 0 of C at a certain position (for example, C4: Pit = 60), the keyboard position information from
図4は、本実施の形態にかかる難易度評価処理の例を概略的に示すフローチャートである。図4に示すように、CPU11は、運指難易度評価処理(ステップ401)、リズム難易度評価処理(ステップ402)、調性難易度評価(ステップ403)、全体難易度の算出処理(ステップ404)を実行する。運指難易度評価処理において、CPU11は、楽音データ中の運指情報などに基づいて、運指難易度iFCostを算出する。リズム難易度評価処理において、CPU11は、楽音データ中の発音時刻、発音時間などに基づいて、リズム難易度RCostを算出する。また、調性難易度評価処理において、CPU11は、楽音データの音高情報などに基づいて、調性難易度iTCostを算出する。
FIG. 4 is a flowchart schematically showing an example of the difficulty level evaluation process according to the present embodiment. As shown in FIG. 4, the
CPU11は、算出した運指難易度iFCost、リズム難易度iRCost、調性難易度iTCostおよび楽曲データ中のノート数(iCnt)に基づいて、それぞれに、重み係数RF、RR、RTおよびRCを乗じて加算することで楽曲の難易度iCostを算出する(ステップ404)。すなわち、難易度iCostは以下の数式のようになる。
The
iCost=iFCost×RF+iRCost×RR
+iTCost×RT+iCnt×RC
以下、運指難易度評価処理、リズム難易度評価処理および調性難易度評価処理について詳細に説明する。図5および図6は、本実施の形態にかかる運指難易度評価処理の例を示すフローチャートである。なお、本実施の形態においては、楽曲データは、右手で演奏する楽曲(メロディ)の音符についての楽音データから構成される。したがって、運指難易度においては、右手で演奏する場合の運指難易度が算出され。楽曲データ中、楽音データのレコードの運指情報は、右手のどの指で押鍵するかを示している。また、指番号「1」〜「5」は、それぞれ、親指〜小指で押鍵すべきことを示している。
iCost = iFCost × RF + iRCost × RR
+ ITCost x RT + iCnt x RC
Hereinafter, the fingering difficulty evaluation process, the rhythm difficulty evaluation process, and the tonality difficulty evaluation process will be described in detail. 5 and 6 are flowcharts showing an example of the fingering difficulty evaluation process according to the present embodiment. In the present embodiment, the music data is composed of musical tone data for musical notes of a music piece (melody) played with the right hand. Therefore, in the fingering difficulty level, the fingering difficulty level when playing with the right hand is calculated. In the music data, the fingering information of the musical sound data record indicates with which finger the right hand is pressed. Finger numbers “1” to “5” indicate that the keys should be pressed with the thumb to the little finger, respectively.
図5に示すように、CPU11は、楽音データに示す楽曲のノート(音符)数を示すパラメータiCntを「0」に初期化するとともに(ステップ501)、RAM13の楽曲データ中、最初の楽音データのレコードNote[0]を、配列me[]に格納する(ステップ502)。CPU11は、楽曲データにおいて全ての楽音データのレコードについて処理が終了するまで(ステップ503でYes)、ステップ504〜515を繰り返す。
As shown in FIG. 5, the
まず、CPU11は、配列me[]に格納された楽音データのレコードの、一つ前の楽音でデータのレコードを特定し、それを配列prev[]に格納する(ステップ504)。次いで、CPU11は、配列me[]および配列prev[]に格納された値に基づいて、テクニック分類処理を実行する(ステップ505)。テクニック分類処理においては、楽曲の隣接する音符間の運指について、ポジションタイプ(PosType)、指開きタイプ(iSpreadType)、リバースタイプ(RevType)、および、指使いテクニック(Tech)という4つの分類項目のそれぞれの何れに該当するかを判断する。
First, the
ここで、ポジションタイプ(PosType)という分類項目は、どのような指のポジションで運指が行なわれるかを示す。また、指開きタイプ(iSpreadType)は、隣接する音符を押鍵する指の開き具合を示す。また、リバースタイプ(RevType)は、後述する指くぐり、或いは、指返し(乗り越え)の存在を示す。さらに、指使いテクニック(Tech)は、隣接する音符を押鍵するときにどのような指使い(指換え)がなされているかを示す。 Here, the classification item of position type (PosType) indicates at what kind of finger position fingering is performed. The finger opening type (iSpreadType) indicates the opening degree of the finger pressing the adjacent note. The reverse type (RevType) indicates the presence of a finger penetration or a finger turn (getting over) described later. Further, the fingering technique (Tech) indicates what kind of fingering (finger change) is performed when the adjacent note is pressed.
テクニック分類処理では、それぞれの分類項目について、当該分類項目における具体的提要を示す分類値が算出される。図7および図8は、本実施の形態にかかるテクニック分類処理の例を示すフローチャートである。CPU11は、配列me[]中の運指情報「Fig」、音高情報「Pit」および鍵盤位置情報「Pos」について、f1=Fig、p1=Pit、ps1=Posとする。また、音高情報「Pit」に基づき、鍵が白鍵か黒鍵かを判断し、白鍵、黒鍵の何れかを示す情報をb1とする。値b1は、鍵が黒鍵であることを示す値「1」或いは鍵が白鍵であることを示す値「0」の何れかをとる。これら値f1、p1、ps1、b1は、RAM13に格納される。
In the technique classification process, for each classification item, a classification value indicating a specific requirement in the classification item is calculated. 7 and 8 are flowcharts showing an example of technique classification processing according to the present embodiment. The
また、CPU11は、配列prev[]中の運指情報「Fig」、音高情報「Pit」および鍵盤位置情報「Pos」について、f2=Fig、p2=Pit、ps2=Posとする。また、音高情報「Pit」に基づき、鍵が白鍵か黒鍵かを判断し、白鍵、黒鍵の何れかを示す情報をb2とする。これら値f2、p2、ps2、b2は、RAM13に格納される。CPU11は、p1、p2、f1およびf2に基づき、音高差を示す指標iDistを算出する(ステップ703)。
The
音高差を示す指標iDistは、楽曲において音符の進行が上行であったときに、指番号が増大あるいは減少しているか、また、進行が下行であったときに、指番号が減少或いは増大しているかを示す指標である。本実施の形態においては、iDistは以下のように求められる。 The index iDist indicating the pitch difference indicates that the finger number is increased or decreased when the progress of the note is upward in the music, and the finger number is decreased or increased when the progress is downward. It is an index indicating whether or not In the present embodiment, iDist is obtained as follows.
iDist=(p1−p2)*(f1−f2)
したがって、iDist>0である場合には、音符の進行が上行かつ指番号が増大するような指使いである場合、或いは、音符の進行が下行かつ指番号が減少するような指使いである場合を意味している。すなわち、iDist>0である場合には、指が開く形態で運指が行なわれる(指くぐりや指返しが行なわれない)ことを示している。
iDist = (p1-p2) * (f1-f2)
Therefore, when iDist> 0, the finger is used to increase the finger number and increase the number of notes, or the finger is used to increase the finger number and decrease the number of fingers. Means. That is, when iDist> 0, it is indicated that fingering is performed in a form in which the finger is opened (no finger penetration or finger turning is performed).
CPU11は、f2=f1かつp2=p1であるかを判断する(ステップ704)。ステップ704でYesとなる場合とは、隣接する音符間で、同じ音高の鍵が同じ指で押鍵されることを示す。ステップ704でYesと判断された場合には、CPU11は、指使いテクニック(Tech)という分類項目について、分類値Techとして、「Tech=3」という値を与える(ステップ705)。与えられた値は、RAM13に格納される。次いで、CPU11は、f2≠f1かつp2=p1であるかを判断する(ステップ706)。ステップ706でYesとなる場合とは、隣接する音符間で、同じ音高の鍵が異なる指で押鍵されることを示す。ステップ706でYesと判断された場合には、CPU11は、指使いテクニック(Tech)という分類項目について、「Tech=2」という値を与える(ステップ707)。
The
次いで、CPU11は、f2=f1かつp2≠p1であるかを判断する(ステップ708)。ステップ708でYesとなる場合とは、隣接する音符間で異なる音高の鍵が同じ指で押鍵されることを示す。ステップ708でYesと判断された場合には、CPU11は、指使いテクニック(Tech)という分類項目について、「Tech=4」という値を与える(ステップ709)。ステップ708でNoと判断された場合には、CPU11は、指使いテクニック(Tech)という分類項目について、「Tech=1」という値を与える(ステップ710)。
Next, the
次に、CPU11は、iDist>0であるかを判断する(ステップ801)。上述したように、iDist>0であることは、指が開く形態で運指が行なわれる(指くぐりや指返しが行なわれない)ことを示している。ステップ801でYesと判断された場合には、CPU11は、b2、b1、f2およびf1に基づいて、所定のテーブルiPType[][][][]に基づいて、分類値PosTypeとして、PosType=iPType[b2][b1][f2][f1]を取得する(ステップ802)。テーブルiPType[][][][]は、隣接する音符について、指番号および白鍵/黒鍵の種別に基づく値を含み、RAM13に格納される。
Next, the
テーブルiPType[][][][]における値について以下に簡単に説明する。テーブルiPtype[][][][]は、隣接する音符に配置すべき指の指番号およびその位置(白鍵或いは黒鍵)の関係に基づいて、その指のポジションタイプを格納したテーブルである。たとえば、現在の音符および一つ前の音符の双方が白鍵であれば、iPType[0][0][f2][f1]=1となる。また、一つ前の音符が親指でかつ白鍵が押鍵されていれば、現在の音符が黒鍵であった場合に、iPType[0][1][1][f1]=2となる。また、一つ前の音符が親指でかつ黒鍵が押鍵されていれば、現在の音符が黒鍵であった場合に、iPType[1][1][1][f1]=3となる。 The values in the table iPType [] [] [] [] will be briefly described below. The table iPtype [] [] [] [] is a table that stores the position type of a finger based on the relationship between the finger number of the finger to be placed on an adjacent note and its position (white key or black key). . For example, if both the current note and the previous note are white keys, iPType [0] [0] [f2] [f1] = 1. If the previous note is a thumb and a white key is pressed, iPType [0] [1] [1] [f1] = 2 when the current note is a black key. . If the previous note is a thumb and a black key is pressed, iPType [1] [1] [1] [f1] = 3 when the current note is a black key. .
このように、テーブルiPtypeにおいては、隣接する音符を押鍵するときの手のむきや指の位置の難易度が高まるのに応じて、値が大きくなるようになっている。 As described above, in the table iPtype, the value increases as the difficulty of the peeling of the hand or the position of the finger when pressing adjacent notes is increased.
ステップ802が実行された後、CPU11は、指開き特定処理を実行する(ステップ803)。図9は、本実施の形態にかかる指開き特定処理の例を詳細に示すフローチャートである。
After
図9に示すように、CPU11は、指開きの度合いを示すパラメータであるiMin、iL1およびiL2(iMin<iL1<iL2)をRAM13から取得する(ステップ901)。たとえば、iMinは、白鍵での長2度の幅に相当する「2」、iL1は、白鍵での長3度に相当する「4」、iL1は、白鍵での完全8度に相当する「14」である。指開き特定処理においては、iDistと、iMin、iL1およびiL2とを比較して、指開きタイプ(iSpreadType)の分類値を決定していく。
As shown in FIG. 9, the
CPU11は、鍵盤位置に基づく距離iKDist=|ps2−ps1|を算出する(ステップ902)。
The
ステップ703において算出されたiDist<0である場合には(ステップ903でYes)、CPU11は、指開きタイプ(iSpreadType)という分類項目について、分類値iSpreadTypeとして、「iSpreadType=0」という値を与える(ステップ904)。なお、図9が実行されるときには、iDist>0であることが前提である(図8のステップ801参照)。したがって、これは実際には起こりえないことであるため、ステップ904はエラー処理となる。
When iDist <0 calculated in Step 703 (Yes in Step 903), the
iKDist=iMinである場合(ステップ905でYes)、CPU11は、指開きタイプ(iSpreadType)という分類項目について、分類値iSpreadTypeとして、「iSpreadType=1」という値を与える(ステップ906)。iMin<iKDist≦iL1である場合(ステップ907でYes)、CPU11は、指開きタイプ(iSpreadType)という分類項目について、「iSpreadType=2」という値を与える(ステップ908)。iKDist<iMinである場合(ステップ909でYes)、CPU11は、指開きタイプ(iSpreadType)という分類項目について、「iSpreadType=3」という値を与える(ステップ910)。
When iKDist = iMin (Yes in Step 905), the
iKDist<iL2である場合(ステップ911でYes)、CPU11は、指開きタイプ(iSpreadType)という分類項目について、「iSpreadType=4」という値を与える(ステップ912)。その一方、iKDist≧iL2である場合(ステップ911でNo)、CPU11は、指開きタイプ(iSpreadType)という分類項目について、「iSpreadType=5」という値を与える(ステップ913)。
When iKDist <iL2 (Yes in Step 911), the
指開き特定処理によって、iKDistの値にしたがって、以下のようなiSpreadTypeの値が付与される。 By the finger opening specifying process, the following iSpreadType values are assigned according to the iKDist value.
0≦iKDist<Min iSpreadType=3
iKDist=iMin iSpreadType=1
iMin<iKDist≦iL1 iSpreadType=2
iL1<iKDist<iL2 iSpreadType=4
iL2≦iKDist iSpreadType=5
指開き特定処理が終了すると、CPU11は、リバースタイプ(RevType)という分類項目について、分類値RevTypeとして、「RevType=1」という分類値を与える(ステップ804)。その後、CPU11は、配列me[]に格納された楽音データについて算出されたPosType、iSpreadType、RevTypeおよびTechという分類値を、当該楽音データと関連付けて記憶装置(RAM13)に格納する(ステップ805)。
0 ≦ iKDist <Min iSpreadType = 3
iKDist = iMin iSpreadType = 1
iMin <iKDist ≦ iL1 iSpreadType = 2
iL1 <iKDist <iL2 iSpreadType = 4
iL2 ≦ iKDist iSpreadType = 5
When the finger opening identification process ends, the
ステップ801でNoと判断された場合には、所定のテーブルiRType[][][][]に基づいて、RevType=iRType[p2][p1][f2][f1]を取得する(ステップ806)。テーブルiRType[][][][]は、隣接する音符について、指番号および音高に基づく値を含み、RAM13に格納される。
If it is determined No in
テーブルiRType[][][][]における値について以下に簡単に説明する。テーブルiRtype[][][][]は、隣接する音符に配置すべき指の指番号および音高の関係に基づいて、運指における指くぐりや指返し(乗り越え)を示す情報を格納したテーブルである。本実施の形態において、iDist≦0のときには、上行音形において、「1」より大きな指番号の指から指番号「1」の指に移行すること(いわゆる「指くぐり」)、或いは、下行音形において、指番号「1」の指から「1」より大きな指番号の指に移行すること(いわゆる「指返し」ないし「指の乗り越え」)が行なわれ得ることを意味している。 The values in the table iRTType [] [] [] [] will be briefly described below. The table iRtype [] [] [] [] stores information indicating finger penetration and finger turn-over (overcoming) in fingering based on the relationship between finger numbers and pitches of fingers to be placed on adjacent notes. It is. In the present embodiment, when iDist ≦ 0, in the ascending sound form, the finger having the finger number larger than “1” is shifted to the finger having the finger number “1” (so-called “finger penetration”), or the descending sound In terms of shape, it means that a finger having a finger number “1” can be shifted to a finger having a finger number larger than “1” (so-called “finger turn” or “finger over”).
本実施の形態においては、指くぐりのとき、つまり、p2<p1,f2>1、f1=1のときには、iRType[p2][p1][f2][f1]=3となる。また、指返しのとき、つまり、p2>p1、f2=1、f1>1のときには、iRType[p2][p1][f2][f1]=2となる。一般的に、運指において、指返しより指くぐりの方が難しいといわれているため、指くぐりについて、RevType=3、指返しについてRevType=2となるようにしている。 In the present embodiment, iRtype [p2] [p1] [f2] [f1] = 3 in the case of finger penetration, that is, when p2 <p1, f2> 1 and f1 = 1. When the finger is turned back, that is, when p2> p1, f2 = 1, and f1> 1, iRTtype [p2] [p1] [f2] [f1] = 2. In general, it is said that fingering is more difficult for fingering than fingering, so RevType = 3 for fingering and RevType = 2 for fingering.
ステップ806の後、CPU11は、ポジションタイプ(PosType)という分類項目について、「PosType=1」という分類値、指開きタイプ(iSpreadType)という分類項目について、「iSpreadType=1」という分類値を与える(ステップ807)。その後、CPU11は、配列me[]に格納された楽音データについて算出されたPosType、iSpreadType、RevTypeおよびTechという分類値を、当該楽音データと関連付けて記憶装置(RAM13)に格納する(ステップ805)。
After
次に、2次元マップiFMap[i][j](iは分類項目、jは分類項目において付与された値)において、テクニック分類処理により得られた分類項目に対応する値をインクリメントする処理を実行する(図5のステップ506〜512)。本実施の形態においては、ポジションタイプ(PosType)、指開きタイプ(iSpreadType)、リバースタイプ(RevType)、および、指使いテクニック(Tech)という4つの分類項目が存在する。したがって、2次元のマップiFMap[i][j]のそれぞれの要素は以下の分類項目に対応する。
Next, in the two-dimensional map iFMap [i] [j] (i is a classification item, j is a value assigned to the classification item), a process of incrementing a value corresponding to the classification item obtained by the technique classification process is executed. (
iFMap[0][j]:jが「PosType」の値
iFMap[1][j]:jが「iSpreadType」の値
iFMap[2][j]:jが「RevType」の値
iFMap[3][j]:jが「Tech」の値
なお、以下のステップ506、508、510、512から理解できるように、j=0、2のときの値は存在せず、j>1のみについて値を有する。
iFMap [0] [j]: j is a value of “PosType” iFMap [1] [j]: j is a value of “iSpreadType” iFMMap [2] [j]: j is a value of “RevType” iFMMap [3] [ j]: j is a value of “Tech” Note that, as can be understood from the following
CPU11は、PosType>1である場合には(ステップ506でYes)、対応するマップの値であるiFMap[0][PosType]をインクリメントする(ステップ507)。また、CPU11は、iSpreadType>1である場合には(ステップ508でYes)、対応するマップの値であるiFMap[1][iSpreadType]をインクリメントする(ステップ509)。CPU11は、RevType>1である場合には(ステップ510でYes)、対応するマップの値であるiFMap[2][RevType]をインクリメントする(ステップ511)。さらに、CPU11は、Tech>1である場合には(ステップ512でYes)、対応するマップの値であるiFMap[3][Tech]をインクリメントする(ステップ513)。
If PosType> 1 (Yes in Step 506), the
次いで、CPU11は、ノート数(音符数)を示すパラメータiCntをインクリメントして(ステップ514)、配列me[]に、次の楽音データのレコードを格納し(ステップ515)、その後、ステップ503に戻る。
Next, the
ステップ503でYesと判断された場合には、CPU11は、パラメータiおよびiFCostを「0」に初期化する(ステップ601)。CPU11は、パラメータiが「4」以上であるかを判断する(ステップ602)。上記パラメータiは、iFMap[i][j]の「i」を特定するためのものである。ステップ602でNoと判断された場合には、パラメータjを「0」に初期化して(ステップ603)、jが所定数より大きくなるまで(ステップ604)、ステップ605〜607の処理を繰り返す。
If it is determined Yes in
CPU11は、マップの値iFMap[i][j]が「0」より大きいかを判断する(ステップ605)。ステップ605でYesと判断された場合には、CPU11は、マップの値iFMap[i][j]に対応付けられたコスト値iFCost[i][j]を、運指難易度の値iFCostに加算する(ステップ606)。
The
以下、コスト値iFCost[i][j]を格納したコストテーブル(iFCost[][][])について説明する。コストテーブルは、コスト値iFCost[i][j]のそれぞれに対応する、「i×j」個のコスト値iFCost[i][j]を格納している。たとえば、iFCost[0][j]は、テクニック分類処理(図8)のステップ802で取得された「PosType」の値のそれぞれに対応するコスト値であり、ポジションタイプのそれぞれの値に固有の値となっている。i=1以上の他のコスト値も同様である。
Hereinafter, the cost table (iFCost [] [] []) storing the cost value iFCost [i] [j] will be described. The cost table stores “i × j” number of cost values iFCost [i] [j] corresponding to each of the cost values iFCost [i] [j]. For example, iFCost [0] [j] is a cost value corresponding to each value of “PosType” acquired in
本実施の形態においては、ポジションタイプ「PosType」、指開きタイプ「iSpreadType」、リバースタイプ「RevType」および指使いテクニック「Tech」のそれぞれにおいて、値が大きくなるのにしたがって、それぞれの分類項目において運指の困難度が高まるようになっている。したがって、コスト値iFCost[i][j]も、jが増大するのにしたがって、コスト値が増大するようになっている。 In the present embodiment, as the value increases in each of the position type “PosType”, the finger opening type “iSpreadType”, the reverse type “RevType”, and the fingering technique “Tech”, the operation is performed for each classification item. The difficulty level of fingers is increasing. Therefore, the cost value iFCost [i] [j] also increases as j increases.
また、本実施の形態においては,マップの値iFMap[i][j]が幾つであるかは考慮せず、0より大きければ(すなわち1以上であれば)、コスト値iFCost[i][j]を、運指難易度の値iFCostに加算している。すなわち、マップの値の多寡にかかわらず、加算される値はコスト値iFCost[i][j]である。これは、分類項目「i」(例えば、ポジションタイプや指開きタイプ)において、iFMap[i][j]において1より大きい値を有する音符が1つあれば、その場合には、当該iFMap[i][j]に対応する難易度を含むため、そのノートの数は、難易度を示すコスト値にそれほど大きく影響しないであろうという知見に基づく。 Also, in the present embodiment, the number of map values iFMap [i] [j] is not considered, and if it is larger than 0 (that is, 1 or more), the cost value iFCost [i] [j ] Is added to the fingering difficulty value iFCost. That is, regardless of the number of map values, the added value is the cost value iFCost [i] [j]. This is because if there is one note having a value greater than 1 in iFMap [i] [j] in the classification item “i” (for example, position type or finger-open type), in this case, the iFMap [i ] [J] is included, the number of notes is based on the knowledge that the cost value indicating the difficulty level will not be significantly affected.
無論、マップの値iFMap[i][j]に応じて、加算されるiFCost[i][j]に重みを与えても良い。つまりこの場合には、
iCost=iCost+
f(iFCost[i][j])×iFCost[i][j]
となる。ここで、f(iFCost[i][j])は、変数iFCost[i][j]が増大するのにしたがって増大するが、変数iFCost[i][j]が増大するのにしたがって、関数値fの増分は小さくなっていく関数である。たとえば、fとして対数関数を使用しても良い。
Of course, iFCost [i] [j] to be added may be given a weight according to the map value iFMap [i] [j]. In this case,
iCost = iCost +
f (iFCost [i] [j]) × iFCost [i] [j]
It becomes. Here, f (iFCost [i] [j]) increases as the variable iFCost [i] [j] increases, but the function value increases as the variable iFCost [i] [j] increases. The increment of f is a decreasing function. For example, a logarithmic function may be used as f.
ステップ605でNoと判断された場合、或いは、ステップ606が実行された後、CPU11は、jをインクリメントして(ステップ607)、ステップ604に戻る。また、ステップ604でYesと判断された場合には、CPU11は、iをインクリメントして(ステップ608)、ステップ602に戻る。
When it is determined No in
このように本実施の形態においては、楽曲に含まれるあるノートが、運指に関する分類項目の具体的態様についてのマップ値iFMap[i][j]が「0」でない場合には、当該分類項目の具体的態様に対応するコスト値iFCost[i][j]が、運指難易度iFCostに加算される。 As described above, in the present embodiment, when a note included in a musical piece has a map value iFMap [i] [j] for a specific aspect of a classification item related to fingering, the classification item is not “0”. The cost value iFCost [i] [j] corresponding to the specific mode is added to the fingering difficulty iFCost.
次に、リズム難易度評価処理について説明する。図10および図11は、本実施の形態にかかるリズム難易度評価処理の例を示すフローチャートである。図10に示すように、CPU11は、RAM13の楽曲データ中、最初の楽音データのレコードNote[0]を、配列me[]に格納する(ステップ1001)。CPU11は、楽曲データにおいて全ての楽音データのレコードについて処理が終了するまで(ステップ1002でYes)、ステップ1003〜1007を繰り返す。
Next, the rhythm difficulty level evaluation process will be described. 10 and 11 are flowcharts showing an example of the rhythm difficulty evaluation process according to the present embodiment. As shown in FIG. 10, the
CPU11は、RAM13に格納された、リズム評価処理用のパラメータ(リズムパラメータ)を取得する(ステップ1003)。リズムパラメータには、1小節の長さを示すiMeasLen、リズムの分解能を示すResolutionなどが含まれ、これらは、次のリズムコスト算出処理において利用される。CPU11は、リズムコスト算出処理を実行する(ステップ1004)。図12および図13は、本実施の形態にかかるリズムコスト算出処理の例を示すフローチャートである。リズムコスト算出処理においては、音符の音符長(次の音符までの間隔に基づく音符長)に相当する分類項目であるステップタイム(iStepTime)についての分類値と、音符の小節中の位置に相当する分類項目であるポジション(iPos)についての分類値とが得られる。
The
図12に示すように、CPU11は、配列me[]に示す楽音データのレコードの、次のレコードを参照して、その発音時刻Timeを取得する(ステップ1201)。次いで、CPU11は、配列me[]中の発音時刻Timeと、ステップ1201で取得した次の発音データのレコードにおける発音時刻Timeとに基づいて、次の音符までの間隔iTを算出する(ステップ1202)。CPU11は、時間間隔iTと、1小節の長さiMeasLenとに基づいて、上記時間間隔の小節内での音符長iStepTimeを算出する(ステップ1203)。得られたiStepTimeが、音符長という分類項目についての分類値となる。
As shown in FIG. 12, the
本実施の形態において、音符長iStepTimeは以下のように求められる。 In the present embodiment, the note length iStepTime is obtained as follows.
iStepTime=32×iT/iMeasLen
本実施の形態においては、楽曲は4/4拍子としており、iStepTimeは、iTが32分音符いくつ分に相当するかを示している。
iStepTime = 32 × iT / iMeasLen
In this embodiment, the music has a 4/4 time signature, and iStepTime indicates how many 32nd notes correspond to iT.
次いで、CPU11は、配列me[]中の発音時刻Timeに基づき、小節内の音符位置iTickInMeas、拍内での音符位置iTickInBeatおよび当該音符の属する拍iBeatを算出する(ステップ1304)。iTickInMeasは、1小節を32分割したときの音符の位置、つまり、小節の先頭から32分音符でいくつ目に位置しているかを示す。また、iTickInBeatは、拍の先頭から32分音符でいくつ目に位置しているかを示す。
Next, the
CPU11は、パラメータiおよびiPosを「0」に初期化して(ステップ1205)、iが8未満である限り(ステップ1206でYes)、ステップ1207から1210の処理を実行する。CPU11は、iTickInBeatの位置を特定するために、a=iTickInBeat−iResolution×i/8を算出する(ステップ1207)。ここで、iTickInBeatは、「0」〜「7」の何れかの値をとる。したがって、いずれかのiについて、a=0となり、次のステップ1208でYesと判断される。ステップ1208でNoと判断された場合には、CPU11は、パラメータiをインクリメントして(ステップ1209)、ステップ1206に戻る。ステップ1208でYesと判断された場合には、CPU11は、パラメータiPos=iとする(ステップ1210)。
The
ステップ1206でNoと判断された場合、或いは、ステップ1210の処理が終了した後、図13のステップ1301に進む。なお、本実施の形態においては、ステップ1204においてiTickInBeatの算出の際に、32分音符の分解能にクォンタイズされる。したがって、ステップ1210においてNoと判断されることは本来ありえない。したがって、この場合は、演算において何らかのエラーが生じたことになる。
If it is determined No in
このようにして得られたiPosは、音符が、拍の頭から32分音符で何番目の位置にあるかを示すものである。これをそのまま使って良いが、本実施の形態においては、小節の先頭、小節の中央および拍の先頭として、iPosとして異なる値を与える。iTickInMeas=0の場合、すなわち、音符が拍の先頭に位置している場合には(ステップ1301でYes)、CPU11は、iPos=32とする(ステップ1302)。また、iTickInBeat=0かつiBeat=2、つまり、音符が3拍目の先頭(小節の中央)に位置している場合には(ステップ1303でYes)、CPU11は、iPos=16とする(ステップ1304)。さらに、iTickInBeat=0、つまり、音符が2拍目或いは4拍目の先頭に位置している場合には(ステップ1305でYes)、CPU11は、iPos=8とする(ステップ1306)。
The iPos obtained in this way indicates the position of the note at the 32nd note from the beginning of the beat. Although this may be used as it is, in the present embodiment, different values are given as iPos as the beginning of the measure, the center of the measure, and the beginning of the beat. If iTickInMeas = 0, that is, if the note is located at the beginning of the beat (Yes in step 1301), the
リズムコスト算出処理によって得られる分類項目の1つであるポジション(iPos)の分類値は、音符の小節中の位置によって以下のような値をとる。 The classification value of the position (iPos), which is one of the classification items obtained by the rhythm cost calculation process, takes the following values depending on the position in the measure of the note.
音符の位置が、小節の先頭:iPos=32
音符の位置が、3拍目の先頭:iPos=16
音符の位置が、他の拍(2拍目、4拍目)の先頭:iPos=8
音符の位置が他の場合:iPos=拍を8等分した場合の位置を示す値
上記iPosは、楽曲が4/4拍子の場合の例であり、他の拍子(たとえば、3/4)の場合には、iPosは異なる。楽曲が3/4拍子であれば、分類値「iPos」は以下の値をとり得る。
The note position is the beginning of the measure: iPos = 32
Note position is at the beginning of the third beat: iPos = 16
The position of the note is the beginning of another beat (2nd beat, 4th beat): iPos = 8
When the position of the note is other: iPos = a value indicating the position when the beat is divided into eight equal parts The above-mentioned iPos is an example in the case where the music has 4/4 time, and other time signatures (for example, 3/4) In some cases, iPos is different. If the music is 3/4 time, the classification value “iPos” can take the following values.
音符の位置が、小節の先頭:iPos=32
音符の位置が、他の拍(2拍目、3拍目)の先頭:iPos=8
音符の位置が他の場合:iPos=拍を8等分した場合の位置を示す値
リズムコスト算出処理が終了すると、CPU11は、2次元マップの値であるiRMap[0][iStepTime]をインクリメントする(ステップ1005)とともに、iRMap[1][iPos]をインクリメントする(ステップ1006)。その後、CPU11は、配列me[]に、次の楽音データのレコードを格納し(ステップ1007)、その後、ステップ1002に戻る。
The note position is the beginning of the measure: iPos = 32
Note position is the beginning of other beats (2nd beat, 3rd beat): iPos = 8
When the position of the note is other: iPos = a value indicating the position when the beat is divided into eight equal parts When the rhythm cost calculation process ends, the
ステップ1002でYesと判断された場合には、CPU11は、パラメータiおよびiRCostを「0」に初期化する(ステップ1101)。CPU11は、パラメータiが「2」以上であるかを判断する(ステップ1102)。上記パラメータiは、iRMap[i][j]の「i」を特定するためのものである。ステップ1102でNoと判断された場合には、パラメータjを「0」に初期化して(ステップ1103)、jが所定数より大きくなるまで(ステップ1104)、ステップ1105〜1107の処理を繰り返す。
When it is determined Yes in
CPU11は、マップ値iRMap[i][j]が「0」より大きいかを判断する(ステップ1105)。ステップ1105でYesと判断された場合には、CPU11は、マップの値iRMap[i][j]に対応付けられたコスト値iRCost[i][j]を、運指難易度の値iRCostに加算する(ステップ1106)。
The
以下、コスト値iRCost[i][j]を格納したコストテーブルiRCost[][]について説明する。運指難易度についてのコスト値iR[i][j]を格納したコストテーブルと同様に、コストテーブルiRCost[][]は、コスト値iRCost[i][j]のそれぞれに対応する、「i×j」個のコスト値iRCost[i][j]を格納している。たとえば、iRCost[0][j]は、リズムコスト算出処理(図12)のステップ1203で取得された音符長iStepTimeのそれぞれに対応するコスト値であり、音符長のそれぞれに固有の値となっている。また、iRCost[1][j]は、ステップ1210、ステップ1302、1304、1306で得られた拍内の音符位置iPosのそれぞれに対応するコスト値であり、音符位置のそれぞれに固有の値となっている。
Hereinafter, the cost table iRCost [] [] storing the cost value iRCost [i] [j] will be described. Similar to the cost table storing the cost values iR [i] [j] for the fingering difficulty, the cost table iRCost [] [] corresponds to each of the cost values iRCost [i] [j]. Xj ”cost values iRCost [i] [j] are stored. For example, iRCost [0] [j] is a cost value corresponding to each note length iStepTime acquired in
たとえば、iRCost[0][iStepTime]においては、iStepTime=32、16、8、4、および、それら以外の値、について、コスト値iRCost[0][iStepTime]が増大するようになっている。つまり、音符長が、全音符であるとき、そのコスト値iRCost[0][32]がもっとも小さく、2分音符、4分音符、8分音符、その他の音符となるのにしたがって、コスト値は大きくなる。 For example, in iRCost [0] [iStepTime], the cost value iRCost [0] [iStepTime] increases for iStepTime = 32, 16, 8, 4, and other values. That is, when the note length is a full note, its cost value iRCost [0] [32] is the smallest, and the cost value becomes as the second note, quarter note, eighth note, and other notes become. growing.
また、iRCost[1][iPod]においても、iPos=32、16、8、それら以外の値、について、コスト値iRCost[1][iPos]が増大するようになっている。つまり、音符が小節の先頭に位置するとき、そのコスト値iRCost[1][32]がもっとも小さく、3拍目の先頭、2拍目或いは4拍目の先頭、その他の位置となるのにしたがって、コスト値は大きくなる。 Also in iRCost [1] [iPod], the cost value iRCost [1] [iPos] increases for iPos = 32, 16, 8 and other values. That is, when the note is positioned at the beginning of the measure, the cost value iRCost [1] [32] is the smallest, and the beginning of the third beat, the beginning of the second beat, the beginning of the fourth beat, and other positions. The cost value will increase.
運指難易度コストの算出と同様に、マップの値iRMap[i][j]が幾つであるかは考慮せず、0より大きければ(すなわち1以上であれば)、コスト値iRCost[i][j]を、リズム難易度の値iRCostに加算している。すなわち、マップの値の多寡にかかわらず、加算される値はコスト値iRCost[i][j]である。 Similar to the calculation of the fingering difficulty level cost, the number of map values iRMMap [i] [j] is not considered, and if it is greater than 0 (that is, 1 or more), the cost value iRCost [i] [J] is added to the rhythm difficulty value iRCost. That is, regardless of the number of map values, the added value is the cost value iRCost [i] [j].
ステップ1105でNoと判断された場合、或いは、ステップ1106が実行された後、CPU11は、jをインクリメントして(ステップ1107)、ステップ1104に戻る。また、ステップ1104でYesと判断された場合には、CPU11は、iをインクリメントして(ステップ1108)、ステップ1102に戻る。
When it is determined No in
このように本実施の形態においては、音符についてのリズム、特に、音符長および音符位置のそれぞれについて、対応するコスト値iRCost[i][j]が、リズム難易度iRCostに加算される。 Thus, in the present embodiment, the corresponding cost value iRCost [i] [j] is added to the rhythm difficulty iRCost for each of the rhythms of the notes, particularly the note length and note position.
次に、本実施の形態にかかる調性難易度評価処理について説明する。図14および図15は、本実施の形態にかかる調性難易度評価処理の例を示すフローチャートである。図15に示すように、CPU11は、配列me[]に先頭の楽音データのレコードを格納する(ステップ1401)。CPU11は、楽曲データにおいて全ての楽音データのレコードについて処理が終了するまで(ステップ1402でYes)、ステップ1403、1404を繰り返す。
Next, the tonality difficulty level evaluation process according to the present embodiment will be described. 14 and 15 are flowcharts showing an example of the tonality difficulty level evaluation process according to the present embodiment. As shown in FIG. 15, the
CPU11は、配列me[]中の音高情報「Pit」に基づいて、カウント値iPC[Pit mod 12]をインクリメントする(ステップ1403)。ステップ1403においては、音符の、CからBまでの何れかの音名に対応するカウント値iPCがインクリメントされる。次いで、CPU11は、配列me[]に次の楽音データのレコードを格納して(ステップ1404)、ステップ1402に戻る。ステップ1402〜1404の処理によって、楽曲に含まれるノート(音符)の音名のそれぞれについて、累算値を格納した配列iPC[]が取得される。
The
ステップ1402でYesと判断された場合には、CPU11は、パラメータiTonality、iMax,iATMaxおよびiを「0」に初期化する(ステップ1405〜1407)。CPU11は、パラメータiが12以上になるまで(ステップ1408でNo)、図15のステップ1501〜1512を実行する。
If it is determined as Yes in
図15に示すように、CPU11は、パラメータiSumおよびiATonalityを「0」に初期化する。ここに、iSumは、楽曲が含んでいたノート(音符)の音名の累算値と、各調の長音階との一致度を示すパラメータであり、iATonalityは、上記音名の累算値と、各調の長音階との不一致度を示すパラメータである。なお、本実施の形態においては、長音階の楽曲について、各調の長音階との一致度、不一致度を見出しているが、これに限定されるものではない。短音階の楽曲については、各調の短音階との一致度や不一致度を見出せば良い。
As shown in FIG. 15, the
CPU11は、パラメータjを「0」に初期化して(ステップ1504)、iSumに、iPC[(j+i) mod 12]×iBaseScale[j]を加算する。また、CPU11は、iATonalityに、iPC[(j+i) mod 12]×iATonal[j]を加算する(ステップ1505)。その後、CPU11はjをインクリメントしてステップ1503に戻る。
The
図17(a)は、本実施の形態にかかるベーススケール配列iBaseScale[]の例を示す図である。図17(a)に示すように、iBaseScale[](符号1701)は、11個の要素(j=0〜11)を有し、長音階の音名に相当する要素(j=0、2、4、5、7、9、11)が「1」となり、それ以外が「0」となっている。なお、図17(a)において、配列の要素の上に配置された数字、♭(フラット)、#(シャープ)は、最も左のj=0の要素(根音)に対する間隔(度)を示している。また、図17(b)は、本実施の形態にかかる非ベーススケール配列iATonal[]の例を示す図である。iATonal[](符号1702参照)は、iBaseScale[]1701と同様に、11個の要素(j=0〜11)を有し、その値は、iBaseScaleと逆となっている。すなわち、長音階の音名に該当しない要素(j=1、3、6、8、10)が「1」となり、それ以外が「0」となっている。 FIG. 17A is a diagram illustrating an example of the base scale array iBaseScale [] according to the present embodiment. As shown in FIG. 17A, iBaseScale [] (reference numeral 1701) has 11 elements (j = 0 to 11), and elements corresponding to the major scale pitch names (j = 0, 2, 4). 5, 7, 9, 11) is “1”, and the others are “0”. In FIG. 17A, numbers, 数字 (flat), and # (sharp) arranged on the elements of the array indicate the interval (degree) with respect to the leftmost element (root sound) of j = 0. ing. FIG. 17B is a diagram illustrating an example of the non-base scale array iATonal [] according to the present embodiment. iATonal [] (see reference numeral 1702) has 11 elements (j = 0 to 11), similar to iBaseScale [] 1701, and its value is the reverse of iBaseScale. That is, the elements (j = 1, 3, 6, 8, 10) that do not correspond to the note names of the major scale are “1”, and other elements are “0”.
以下、ステップ1504における、iSumに加算される値iPC[(j+i) mod 12]×iBaseScale[j]について説明する。たとえば、図18において、符号1801は、ステップ1402〜1404で得られた配列iPC[]の例を示す図、符号1802は、ベーススケール配列iBaseScale[]の例を示す図である。
The value iPC [(j + i) mod 12] × iBaseScale [j] added to iSum in
iPC[j+i mod 12]×iBaseScale[j]において、i=0のときには、j=0、2、4、5、7、9において、0以外の値をとり、全てのjについて処理が実行された場合のiSumの最終値は、
iSum=Σ(iPC[j mod 12]×iBaseScale[j])
=7+2+3+10+4+5=31となる。
In iPC [j + i mod 12] × iBaseScale [j], when i = 0, j = 0, 2, 4, 5, 7, and 9 take values other than 0, and processing is performed for all j The final value of iSum is
iSum = Σ (iPC [j mod 12] × iBaseScale [j])
= 7 + 2 + 3 + 10 + 4 + 5 = 31.
i=1のときには、j=4、5、9、11において、0以外の値をとり、全てのjについて処理が実行された場合のiSumの最終値は、
iSum=1+3+5+8=17となる。
When i = 1, j = 4, 5, 9, 11 takes a value other than 0, and when the process is executed for all j, the final value of iSum is
iSum = 1 + 3 + 5 + 8 = 17.
また、i=5のときには、j=0、2、4、5、7、9、22において、0以外の値をとり、全てのjについて処理が実行された場合のiSumの最終値は、
iSum=10+4+5+8+7+2+3=39となる。
Further, when i = 5, j = 0, 2, 4, 5, 7, 9, 22 takes a value other than 0, and the final value of iSum when processing is executed for all j is
iSum = 10 + 4 + 5 + 8 + 7 + 2 + 3 = 39.
さらに、i=7のときには、j=0、2、5、7、9において、0以外の値をとり、全てのjについて処理が実行された場合のiSumの最終値は、
iSum=4+5+7+2+3=22となる。
Further, when i = 7, when j = 0, 2, 5, 7, and 9, a value other than 0 is taken, and the final value of iSum when processing is executed for all j is
iSum = 4 + 5 + 7 + 2 + 3 = 22.
iATonalityにiPC(j+i mod 12)×iATonal[j]を加算する演算も、iSumの演算と同様に実行され得る。 The operation of adding iPC (j + i mod 12) × iATonal [j] to iATonality can be performed in the same manner as the iSum operation.
図19において、符号1901は、ステップ1402〜1404で得られた配列iPC[]の例を示す図、符号1902は、非ベーススケール配列iATonlity[]の例を示す図である。配列iPC[]は、図18の符号1801と同様である。
In FIG. 19,
i=0のときには、iATonalityの最終値
iATonality=Σ(iPC[j mod 12]×iATonal[j]
=1+5+8=14となる。
When i = 0, the final value of iATonality is iATonality = Σ (iPC [j mod 12] × iATonal [j]
= 1 + 5 + 8 = 14.
また、i=1のときのiATonalityの最終値は、
iATonality=7+2+10+4+5=28(符号1903参照)
i=5のときのiATonalityの最終値は、
iATonality=5+1=6(符号1904参照)
i=7のときのiATonalityの最終値は、
iATonality=5+8+1+10=24(符号1905参照)となる。
Also, the final value of iATonality when i = 1 is
iATonality = 7 + 2 + 10 + 4 + 5 = 28 (see reference numeral 1903)
The final value of iATonality when i = 5 is
iATonality = 5 + 1 = 6 (see reference numeral 1904)
The final value of iATonality when i = 7 is
iATonality = 5 + 8 + 1 + 10 = 24 (see reference numeral 1905).
ステップ1503でNoと判断された場合、つまり、特定のiについて、j=0〜11のiSumおよびiATonalityが算出された場合には、CPU11は、一致度iSumと不一致度iATonalityの差分値a(=iSum−iATonality)を算出する(ステップ1507)。
When it is determined No in
CPU11は、ステップ1507において得られた差分値aが、RAM13に記憶された差分値aの最大値iMaxより大きいかを判断する(ステップ1508)。ステップ1508でYesと判断された場合には、CPU11は、差分値aを最大値iMaxとしてセットし(ステップ1509)、かつ、最大値iMaxを得たときの調性を示すパラメータiTonalityにiをセットする(ステップ1510)。また、CPU11は、得られた不一致度iATonalityを、iSumの最大値が得られたときの対応する不一致度iATMaxとしてセットする(ステップ1511)。
The
ステップ1508でNoと判断された場合、または、ステップ1511が実行された後に、CPU11は、iをインクリメントして、ステップ1408に戻る。ステップ1408でNoと判断された場合には、CPU11は、調性難易度を示すiTCostを以下のように算出する(ステップ1409)。
When it is determined No in
iTCost=(iATMax×A)/iMax
ここに、Aは所定の定数である。したがって、iTCostは、調性の一致度が最大となったときの、音符の音階との一致度iSumとそのときの不一致度iATonalityとの差分値に対する、そのときの不一致度の比に、定数Aを乗じたものとなる。
iTCost = (iATMax × A) / iMax
Here, A is a predetermined constant. Therefore, iTCost is a constant A based on the ratio of the degree of mismatch at this time to the difference value between the degree of coincidence iSum with the musical note scale and the degree of mismatch iATonality at the time when the degree of coincidence of tonality is maximized. Multiplied by.
先に説明したように、運指難易度iFCost、リズム難易度iRCostおよび調性難易度iTCostが算出されると、これら難易度および楽曲のノート数iCntに基づいて、以下のように楽曲の難易度iCostが算出される。 As described above, when the fingering difficulty iFCost, the rhythm difficulty iRCost, and the tonality difficulty iTCost are calculated, the difficulty of the music is as follows based on the difficulty and the number of notes iCnt of the music. iCost is calculated.
iCost=iFCost×RF+iRCost×RR
+iTCost×RT+iCnt×RC
次に、本実施の形態にかかる難易度表示処理について説明する。難易度評価処理(ステップ204)が終了し、新たな楽曲指定の入力が無かった場合(ステップ202でNo)、CPU11は、難易度表示処理を実行する(ステップ205)。難易度表示処理205では、難易度iCostが算出された楽曲について、音符ごとに対応する難易度を示す印を付した楽譜を生成して、表示装置16の画面上に表示する。本実施の形態においては、音符ごとの運指難易度を楽譜上に示している。
iCost = iFCost × RF + iRCost × RR
+ ITCost x RT + iCnt x RC
Next, the difficulty level display process according to the present embodiment will be described. When the difficulty level evaluation process (step 204) ends and no new music designation is input (No in step 202), the
図20は、本実施の形態にかかる難易度表示処理の例を示すフローチャートである。図20に示すように、CPU11は、配列me[]に先頭の楽音データのレコードを格納する(ステップ2001)。CPU11は、楽曲データにおいて全ての楽音データのレコードについて処理が終了するまで(ステップ2002でYes)、ステップ2003〜2009を繰り返す。
FIG. 20 is a flowchart illustrating an example of the difficulty level display process according to the present embodiment. As shown in FIG. 20, the
CPU11は、配列me[]中の音高情報「Pit」、発音時刻「Time」および発音時間「Gate」に基づいて、画像において、五線譜中の所定の位置に所定の音長の音符を配置する(ステップ2003)。また、CPU11は、配列me[]中の運指情報「Fig」に基づいて、画像において、音符の上部に指番号を配置する(ステップ2004)。次いで、CPU11は、me[]で特定される楽音データに関連付けられて、RAM13に記憶されたポジションタイプ(PosType)、指開きタイプ(iSpreadType)、リバースタイプ(RevType)、指使いテクニック(Tech)のそれぞれの分類項目についての分類値を取得する(ステップ2005)。
Based on the pitch information “Pit”, the sound generation time “Time”, and the sound generation time “Gate” in the array me [], the
次いで、CPU11は、それぞれの値の何れかが「1」より大きいかを判断する(ステップ2006)。ステップ2006でYesと判断された場合には、CPU11は、該当する分類項目を示す印を、音符の上部に配置する(ステップ2007)。たとえば、PosType>1であれば「P」、iSpreadType>1であれば「S」、RevType>1であれば「R」、Tech>1であれば「T」という印が、画像において音符の上部に配置される。
Next, the
さらに、CPU11は、音符に印が付された分類項目に対応する色彩を付与する(ステップ2008)。たとえば、PosType>1であれば赤、iSpreadType>1であれば水色、RevType>1であれば黄緑、Tech>1であれば桃色という色彩が音符に付与される。なお、PosTypeおよびiSpreaTypeの双方とも、1より大きい値を持っていた場合には、PosTypeについてのコスト値iFCost[0][PosType]と、iSpreadTypeについてのコスト値iFcost[1][iSpreadType]とを比較して、コスト値の大きい方の分類項目に対応する色彩が選択される。
Further, the
その後、CPU11は、配列me[]に次の楽音データのレコードを格納して(ステップ2009)、ステップ2002に戻る。
Thereafter, the
図21は、本実施の形態にかかる難易度表示処理により生成された楽譜の画像の例を示す図である。図21に示すように、楽曲を構成する音符の上部には、1〜5の指番号が表示されるとともに、特定の音符においては、分類項目に対応する印(「P」、「S」、「R」、「T」)が音符の上部に付加されている。また、図21では表われていないが、印「T」が付された音符(たとえば、第2小節第3拍の「G4」)には、対応する色彩である桃色が付されている。同様に、印「S」が付された音符(たとえば、第3小節第1拍の「E5」)には、対応する色彩である水色が付され、印「R」が付された楽譜(たとえば、第7小節第1拍の「F#4」、第2拍の「G4」)には、対応する色彩である黄緑色が付される。
FIG. 21 is a diagram illustrating an example of a score image generated by the difficulty level display processing according to the present embodiment. As shown in FIG. 21,
さらに、印「S」および「P」の双方が付されている音符(たとえば、第3小節の第3.5拍の「F#5」、第4小節の第1拍の「G5」)においては、コスト値の大きい方の分類項目(この場合には、PosType)の色彩(この場合には、赤色)が付される。
Further, in notes marked with both “S” and “P” (for example, “
上述したように、本実施の形態においては、CPU11により、音高情報および運指情報に基づいて、隣接する音符を押鍵する運指に関する運指難易度を算出する運指難易度算出処理、音符についての時間情報に基づいて、音符長および音符のタイミングに関するリズム難易度を算出するリズム難易度算出処理、音符の音高情報に基づいて、当該楽曲の調性に関する調性難易度を算出する調性難易度算出処理、並びに、運指難易度、リズム難易度および調性難易度に基づき、楽曲の難易度を算出する全体難易度の算出処理が実行される。したがって、運指だけではなく、楽曲を構成するリズム、調性を含む要素を考慮した楽曲の難易度を算出することが可能となる。
As described above, in the present embodiment, the
また、本実施の形態においては、運指難易度算出処理において、CPU11は、隣接する音符を押鍵するときの指のポジションに関する第1の分類項目(PosType)について、当該分類項目における具体的態様を示す第1の分類値、隣接する音符を押鍵するときの指の開き具合に関する第2の分類項目(iSpredType)について、当該第2の分類項目における具体的態様を示す第2の分類値、指くぐり或いは指返しに関する第3の分類項目(RevType)について、当該第3の分類項目における具体的態様を示す第3の分類値、および、隣接する音符を押鍵するときの指換えに関する第4の分類項目(Tech)について、当該第4の分類項目における具体的態様を示す第4の分類値を取得する。また、CPU11は、分類項目のそれぞれにおいて、分類項目における分類値(PosType、iSpreadType、RevType、Tech)に基づいて、分類項目における前記具体的態様に対するコスト値を格納した、記憶装置中のコストテーブルiFCost[][]から、分類項目における具体的態様に対するコスト値iFCost[i][j]を取得し、コスト値を累算し、累算されたコスト値を運指に関する難易度iFcostとして取得する。
In the present embodiment, in the fingering difficulty calculation process, the
上述したように、本実施の形態によれば、運指を規定する種々の分類項目のそれぞれについて、その具体的態様に基づくコスト値を取得することができる。したがって、実際の運指の困難さに沿った適切な難易度を算出することができる。 As described above, according to the present embodiment, a cost value based on a specific aspect can be acquired for each of various classification items that define fingering. Therefore, it is possible to calculate an appropriate difficulty level in accordance with actual fingering difficulty.
また、本実施の形態においては、上記第1の分類項目の分類値の取得において、CPU11は、音符ごとに、分類項目中の分類値が所定の値であるときに、分類項目の分類値のカウント値を、マップ値として格納するカウントマップiFMap[][]において、対応するカウント値iFMap[i][j]を増分させ、また、コスト累算において、CPU11は、カウントマップiFMap[][]中のカウント値iFMap[i][j]を参照して、カウント値が「1」以上であるときに、コストテーブルiFCost[][]中の、対応するコスト値iFCost[i][j]をiFCostに加算する。したがって、コストテーブルiFCost[][]にコスト値を格納しておくことで、分類項目中の具体的態様に対応した適切なコスト値を取得することが可能となる。
In the present embodiment, in acquiring the classification value of the first classification item, the
また、本実施の形態においては、リズム難易度算出処理において、CPU11は、音符長に関する第5の分類項目(iStepTime)について、当該分類項目における具体的態様を示す第5の分類値、音符の小節中の位置に関する第6の分類項目(iPos)について、当該分類項目における具体的態様を示す第6の分類値を取得する。また、CPU11は、分類項目のそれぞれにおいて、分類項目における分類値に基づいて、分類項目における具体的態様に対するコスト値を格納した、記憶装置中のコストテーブルiRCost[][]から、分類項目における具体的態様に対するコスト値iRCost[i][j]を取得して、コスト値を累算し、累算されたコスト値をリズムに関する難易度iRCostとして取得する。
Further, in the present embodiment, in the rhythm difficulty calculation process, for the fifth classification item (iStepTime) related to the note length, the
上述したように、本実施の形態によれば、音符のリズムを規定する種々の分類項目のそれぞれについて、その具体的態様に基づくコスト値を取得することができる。したがって、実際に演奏する際のリズムの困難さに沿った適切な難易度を算出することができる。 As described above, according to the present embodiment, the cost value based on the specific mode can be acquired for each of the various classification items that define the rhythm of the note. Therefore, it is possible to calculate an appropriate difficulty level in accordance with the difficulty of the rhythm when actually performing.
また、本実施の形態によれば、調性難易度算出処理において、CPU11は、音符の音高情報に基づいて前記楽曲の調性を特定し、特定された調性の音階と楽曲中の音符の音高との一致度iSum、および、特定された調性の音階と楽曲中の音符の音高との不一致度iATonalityに基づき調性難易度を算出する。したがって、単なる調性自体の難易度ではなく、楽曲を構成する音符と音階との関係に基づく調性難易度を取得することができる。
Further, according to the present embodiment, in the tonality difficulty level calculation process, the
特に、本実施の形態においては、調性難易度算出ステップにおいて、CPU11は、一致度iSumと不一致度iATonalityとの差異(iSum−iAtonality)に対する不一致度iAtonalityの割合に基づいて、調性難易度を算出する。したがって、より適切な楽曲の調性難易度を得ることが可能となる。
In particular, in the present embodiment, in the tonality difficulty level calculating step, the
また、本実施の形態においては、難易度表示処理において、CPU11は、楽曲を構成する音符のそれぞれについて、当該音符に関連付けられた、運指に関する分類項目の分類値が所定の値であるときに、音符が当該分類項目に該当することを示す印を含むような楽譜を含む画像データを生成して、表示装置16の画面上に表示する。これにより、操作者(演奏者)は、楽曲において運指上、所定の難易度を持つような音符を容易に知ることができる。
In the present embodiment, in the difficulty level display process, for each note constituting the music piece, the
次に、本発明の第2の実施の形態ついて説明する。第2の実施の形態においては、難易度算出処理(図2のステップ204)中、全体難易度の算出において、楽曲のテンポを校了している。また、第2の実施の形態においては、楽曲データ中に、楽曲のテンポを示す値BPM(Beat per Minite)が含まれる。図22は、第2の実施の形態にかかる難易度評価処理の概略を示すフローチャートである。図22において、ステップ2201〜2203は、図4のステップ401〜403と同様である。したがって、第1の実施の形態と同様の運指難易度iFCost、リズム難易度iRCostおよび調性難易度iTCostが算出される。
Next, a second embodiment of the present invention will be described. In the second embodiment, during the difficulty level calculation process (step 204 in FIG. 2), the music tempo is completed in the calculation of the overall difficulty level. In the second embodiment, the music data includes a value BPM (Beat per Minute) indicating the tempo of the music. FIG. 22 is a flowchart illustrating an outline of the difficulty level evaluation process according to the second embodiment. 22,
ステップ2201〜2203が終了すると、CPU11は、運指難易度に関する係数RFを調整する(ステップ2204)。本実施の形態においては、係数RFは以下の式に基づいて調整される。
When
RF=RF×(0.5+0.5×(BPM/120))
すなわち、基準テンポを120(毎分120ビート)としたときの楽曲のテンポの比に基づいて、RFの半分にBPM/120という重みを付けることで、RFを調整している。
RF = RF × (0.5 + 0.5 × (BPM / 120))
That is, based on the ratio of the tempo of music when the reference tempo is 120 (120 beats per minute), RF is adjusted by assigning a weight of BPM / 120 to half of the RF.
また、CPU11は、リズム難易度に関数係数RRを調整する(ステップ2205)。本実施の形態においては、係数RRは以下の式に基づいて調整される。
Further, the
RR=RR×BPM/120
すなわち、基準テンポを120(毎分120ビート)としたときの楽曲のテンポの比を重みとして、RRに当該重みを付与することでRRを調整している。つまり、リズム難易度に用いられる係数RRは、運指難易度に用いられる係数RFと比較して、テンポがより係数値に直接的に反映されるようになっている。
RR = RR × BPM / 120
That is, the RR is adjusted by assigning the weight to the RR, using the ratio of the music tempo when the reference tempo is 120 (120 beats per minute) as a weight. That is, the coefficient RR used for the rhythm difficulty level is more directly reflected in the coefficient value than the coefficient RF used for the fingering difficulty level.
その後、CPU11は、CPU11は、算出した運指難易度iFCost、リズム難易度iRCost、調性難易度iTCostおよび楽曲データ中のノート数(iCnt)に基づいて、それぞれに、調整された重み係数RFおよびRR、予め定められた重み係数RTおよびRCを乗じて加算することで楽曲の難易度iCostを算出する(ステップ2206)。
Thereafter, the
第2の実施の形態によれば、全体難易度の算出処理において、CPU11は、運指難易度iFCostおよびリズム難易度iRCostのそれぞれに、楽曲のテンポBPMに応じた重みを与え、重みが与えられた運指難易度およびリズム難易度により全体難易度を算出する。したがって、テンポも考慮したより適切な難易度の算出が可能となる。
According to the second embodiment, in the overall difficulty level calculation process, the
本発明は、以上の実施の形態に限定されることなく、特許請求の範囲に記載された発明の範囲内で、種々の変更が可能であり、それらも本発明の範囲内に包含されるものであることは言うまでもない。 The present invention is not limited to the above embodiments, and various modifications can be made within the scope of the invention described in the claims, and these are also included in the scope of the present invention. Needless to say.
たとえば、第1の実施の形態にかかる難易度表示処理においては、音符ごとの運指難易度に関する分類項目の分類値を記憶装置(RAM13)に格納し、当該分類値に基づいて、音符ごとに運指難易度に関する表示を行なっていた。本発明はこれに限定されず、他の難易度、たとえば、リズム難易度に関する表示も可能である。 For example, in the difficulty level display processing according to the first embodiment, the classification value of the classification item regarding the fingering difficulty level for each note is stored in the storage device (RAM 13), and for each note based on the classification value. The display was related to the fingering difficulty. The present invention is not limited to this, and it is possible to display other difficulty levels, for example, rhythm difficulty levels.
図23は、本発明の第3の実施の形態にかかるリズムコスト算出処理の後半部分の例を示すフローチャートである。図23は、図12に示すリズムコスト算出処理のステップ1206でNoの場合、或いは、ステップ1210が終了した場合に開始される。図23のステップ2301〜2306は、図13のステップ1301〜1306と同様である。ステップ2302、2304、2306が終了した後、或いは、ステップ2305でNoと判断された場合には、CPU11は、配列me[]に格納された楽音データについて算出された音符長を示すiStepTime、および、音符の小節中の位置示すiPosという分類値を、当該楽音データと関連付けて記憶装置(RAM13)に格納する(ステップ2307)。
FIG. 23 is a flowchart illustrating an example of the latter half of the rhythm cost calculation process according to the third embodiment of the present invention. FIG. 23 is started when
図24は、本発明の第3の実施の形態にかかる難易度表示処理の例を示すフローチャートである。図24において、ステップ2401〜2404は、図20のステップ2001〜2004と同様である。ステップ2404の後、CPU11は、CPU11は、me[]で特定される楽音データに関連付けられて、RAM13に記憶された音符長を示すiStepTime、および、音符の小節中の位置示すiPosというそれぞれの分類項目についての分類値を取得する(ステップ2405)。
FIG. 24 is a flowchart illustrating an example of the difficulty level display process according to the third embodiment of the present invention. 24,
次いで、CPU11は、iStepTimeが所定の値であるか、或いは、iPosが所定の値であるかを判断する(ステップ2406)。たとえば、iStepTimeが、「32」、「16」、「8」、「4」以外の値である場合に、ステップ2406でYesと判断される。また、iPosが、「32」、「16」、「8」以外の値である場合に、ステップ2406でYesと判断される。ステップ2406でYesと判断された場合には、CPU11は、該当する分類項目を示す印を、音符の上部に配置する(ステップ2407)。たとえば、iStepTimeが所定の値であれば「T」という印が、iPosが所定の値であれば「P」という印が、画像において音符の上部に配置される。
Next, the
さらに、CPU11は、音符に印が付された分類項目に対応する色彩を付与する(ステップ2408)。その後、CPU11は、配列me[]に次の楽音データのレコードを格納して(ステップ2409)、ステップ2402に戻る。
Further, the
第3の実施の形態によれば、難易度表示処理において、CPU11は、楽曲を構成する音符のそれぞれについて、当該音符に関連付けられた、リズムに関する分類項目の分類値が所定の値であるときに、音符が当該分類項目に該当することを示す印を含むような楽譜を含む画像データを生成して、表示装置16の画面上に表示する。これにより、操作者(演奏者)は、楽曲においてリズムについて、所定の難易度を持つような音符を容易に知ることができる。
According to the third embodiment, in the difficulty level display process, for each note constituting the music piece, the
10 楽曲難易度評価装置
11 CPU
12 ROM
13 RAM
14 大規模記憶装置
15 入力装置
16 表示装置
17 サウンドシステム
18 鍵盤
10 Music
12 ROM
13 RAM
14 Large-
Claims (7)
前記音高情報および運指情報に基づいて、隣接する音符を押鍵するときの指の状態夫々を表わす各分類項目について、当該各分類項目における具体的態様を表わす分類値のうち、少なくとも1つの分類項目についても分類値を取得するとともに、前記音符ごとに、前記分類項目中の分類値が所定の値であるときに、前記分類項目の分類値のカウント値を格納する、前記記憶手段中のカウントマップにおいて、対応するカウント値を増分させる第1の分類項目値取得手段と、
前記分類項目の夫々において、対応する前記カウントマップ中のカウント値を参照して、前記カウント値が「1」以上であるときに、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得するとともに、当該コスト値を累算し、前記累算されたコスト値を前記運指に関する難易度として取得する第1のコスト累算手段と、
前記音符についての時間情報に基づいて、音符長及び音符の小節中の位置に関する各分類項目について、当該分類項目夫々における具体的態様を示す分類値のうち、少なくとも1つの分類項目についても分類値を取得する第2の分類項目値取得手段と、
前記分類項目の夫々において、前記分類項目における分類値に基づいて、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得し、前記コスト値を累算し、前記累算されたコスト値を前記リズムに関する難易度として取得する第2のコスト累算手段と、
前記音符の音高情報に基づいて、前記楽曲の調性を特定し、前記特定された調性の音階と前記楽曲中の音符の音高との一致度、および、前記特定された調性の音階と前記楽曲中の音符の音高との不一致度に基づき、当該楽曲の調性に関する調性難易度を算出する調性難易度算出手段と、
前記取得された運指に関する難易度及びリズムに関する難易度と、前記算出された調性難易度とに基づき、楽曲の難易度を算出する全体難易度算出手段と、を備えたことを特徴とする楽曲難易度算出装置。 Storage means for storing musical tone data including pitch information for each note constituting the musical piece, fingering information for pressing the note, and time information about the note;
Based on the pitch information and fingering information, for each classification item representing each state of a finger when pressing an adjacent note , at least one of the classification values representing a specific mode in each classification item A classification value is also acquired for a classification item, and a count value of the classification value of the classification item is stored for each note when the classification value in the classification item is a predetermined value. First count item value acquisition means for incrementing the corresponding count value in the count map;
In each of the classification items, with reference to the count value in the corresponding count map, when the count value is “1” or more, a cost value for the specific mode in the classification item is stored, A cost value for the specific mode in the classification item is acquired from a cost table in the storage means, the cost value is accumulated, and the accumulated cost value is acquired as a difficulty level for the fingering. 1 cost accumulating means,
Based on the time information about the note, for each classification item related to the note length and the position in the measure of the note, among the classification values indicating specific modes in each of the classification items, classification values are also obtained for at least one classification item. Second classification item value acquisition means for acquiring;
In each of the classification items, based on the classification value in the classification item, the cost value for the specific mode in the classification item is stored, and from the cost table in the storage unit, the specific mode in the classification item Second cost accumulating means for obtaining a cost value, accumulating the cost value, and obtaining the accumulated cost value as a difficulty level related to the rhythm;
The tonality of the music is specified based on the pitch information of the notes, the degree of coincidence between the scale of the specified tonality and the pitch of the notes in the music, and the specified tonality A tonality difficulty calculating means for calculating a tonality difficulty relating to the tonality of the music based on the disagreement between the scale and the pitch of the notes in the music;
An overall difficulty level calculating means for calculating the difficulty level of the music based on the acquired difficulty level regarding fingering and difficulty related to rhythm and the calculated tonality difficulty level; Music difficulty calculation device.
隣接する音符を押鍵するときの指のポジションに関する第1の分類項目について、当該分類項目における具体的態様を示す第1の分類値、隣接する音符を押鍵するときの指の開き具合に関する第2の分類項目について、当該第2の分類項目における具体的態様を示す第2の分類値、指くぐり或いは指返しに関する第3の分類項目について、当該第3の分類項目における具体的態様を示す第3の分類値、および、隣接する音符を押鍵するときの指換えに関する第4の分類項目について、当該第4の分類項目における具体的態様を示す第4の分類値のうち、少なくとも1つの分類項目について分類値を取得することを特徴とする請求項1に記載の楽曲難易度算出装置。 The first classification item value acquisition unit includes:
For the first classification item related to the finger position when pressing an adjacent note, the first classification value indicating a specific mode in the classification item, the first regarding the degree of opening of the finger when pressing an adjacent note For the second category item, the second category value indicating a specific mode in the second category item, the third category item relating to finger penetration or finger return, and the third category item indicating a specific mode in the third category item At least one classification among the fourth classification value indicating a specific mode in the fourth classification item, with respect to the fourth classification item related to finger change when pressing the adjacent note and the third classification value The music difficulty level calculating device according to claim 1, wherein a classification value is acquired for the item.
前記一致度と不一致度との差異に対する前記不一致度の割合に基づいて、前記調性難易度を算出することを特徴とする請求項1に記載の楽曲難易度算出装置。 The tonality difficulty calculating means includes:
The music difficulty level calculation device according to claim 1, wherein the tonality difficulty level is calculated based on a ratio of the mismatch level to a difference between the match level and the mismatch level .
前記全体難易度算出手段が、前記運指に関する難易度およびリズムに関する難易度のそれぞれに、前記楽曲のテンポに応じた重みを与え、重みが与えられた運指に関する難易度およびリズムに関する難易度により全体難易度を算出するように構成されたことを特徴等する請求項1ないし3の何れか一項に記載の楽曲難易度算出装置。 The musical sound data includes data indicating the tempo of the music,
The overall difficulty level calculation means assigns a weight according to the tempo of the music to each of the difficulty level related to the fingering and the difficulty level related to the rhythm, and the difficulty level related to the fingering given the weight and the difficulty level related to the rhythm The music difficulty calculation device according to any one of claims 1 to 3, wherein the music difficulty calculation device is configured to calculate an overall difficulty level .
前記楽曲を構成する音符が五線譜上に配置された楽譜を含む画像データを生成して表示装置の画面上に表示させる画像生成手段を備え、
前記画像生成手段が、前記音符のそれぞれについて、前記記憶手段に格納された、当該音符に関連付けられた、前記運指に関する分類項目の分類値が所定の値であるときに、前記音符が当該分類項目に該当することを示す印を配置した前記楽譜を含む画像データを生成するように構成されたことを特徴とする請求項1ないし4の何れか一項に記載の楽曲難易度算出装置。 The first classification value acquisition unit is configured to store, for each note, each classification value of the classification item related to the fingering in a storage unit in association with the note.
Image generating means for generating image data including a musical score in which musical notes constituting the music are arranged on a musical score and displaying the image data on a screen of a display device;
For each of the notes, when the image generating means stores a classification value of a classification item related to the fingering, which is stored in the storage means, and is associated with the note, the note is classified into the classification 5. The music difficulty level calculation device according to claim 1 , wherein the music difficulty level calculation device is configured to generate image data including the score in which a mark indicating that the item corresponds is placed .
前記楽曲を構成する音符が五線譜上に配置された楽譜を含む画像データを生成して表示装置の画面上に表示させる画像生成手段を備え、
前記画像生成手段が、前記音符のそれぞれについて、前記記憶手段に格納された、当該音符に関連付けられた、前記リズムに関する分類項目の分類値が所定の値であるときに、前記音符が当該分類項目に該当することを示す印を配置した前記楽譜を含む画像データを生成するように構成されたことを特徴とする請求項1ないし5の何れか一項に記載の楽曲難易度算出装置。 The second classification value acquisition unit is configured to store, for each of the notes, each classification value of the classification item related to the rhythm in a storage unit in association with the note,
Image generating means for generating image data including a musical score in which musical notes constituting the music are arranged on a musical score and displaying the image data on a screen of a display device;
For each of the notes, when the image generation means is associated with the note and the classification value of the classification item relating to the rhythm stored in the storage means is a predetermined value, the note is the classification item. 6. The music difficulty level calculation device according to claim 1 , wherein the music difficulty level calculation device is configured to generate image data including the musical score in which a mark indicating that it corresponds to is arranged .
前記音高情報および運指情報に基づいて、隣接する音符を押鍵するときの指の状態夫々を表わす各分類項目について、当該各分類項目における具体的態様を表わす分類値のうち、少なくとも1つの分類項目についても分類値を取得するとともに、前記音符ごとに、前記分類項目中の分類値が所定の値であるときに、前記分類項目の分類値のカウント値を格納する、前記記憶手段中のカウントマップにおいて、対応するカウント値を増分させる第1の分類項目値取得ステップと、
前記分類項目の夫々において、対応する前記カウントマップ中のカウント値を参照して、前記カウント値が「1」以上であるときに、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得するとともに、当該コスト値を累算し、前記累算されたコスト値を前記運指に関する難易度として取得する第1のコスト累算ステップと、
前記音符についての時間情報に基づいて、音符長及び音符の小節中の位置に関する各分類項目について、当該分類項目夫々における具体的態様を示す分類値のうち、少なくとも1つの分類項目についても分類値を取得する第2の分類項目値取得ステップと、
前記分類項目の夫々において、前記分類項目における分類値に基づいて、前記分類項目における前記具体的態様に対するコスト値を格納した、前記記憶手段中のコストテーブルから、前記分類項目における前記具体的態様に対するコスト値を取得し、前記コスト値を累算し、前記累算されたコスト値を前記リズムに関する難易度として取得する第2のコスト累算ステップと、
前記音符の音高情報に基づいて、前記楽曲の調性を特定し、前記特定された調性の音階と前記楽曲中の音符の音高との一致度、および、前記特定された調性の音階と前記楽曲中の音符の音高との不一致度に基づき、当該楽曲の調性に関する調性難易度を算出する調性難易度算出ステップと、
前記取得された運指に関する難易度及びリズムに関する難易度と、前記算出された調性難易度とに基づき、楽曲の難易度を算出する全体難易度算出ステップと、
を実行させることを特徴とする楽曲難易度算出プログラム。 A computer comprising storage means for storing musical tone data including pitch information for each note constituting the music, fingering information for pressing the note, and time information about the note,
Based on the pitch information and fingering information, for each classification item representing each state of a finger when pressing an adjacent note, at least one of the classification values representing a specific mode in each classification item It obtains the classification value also categories, the note your capital, when the classification value in the classification item is a predetermined value, and stores the count value of the classification values of the classification items, the storage means in A first classification item value acquisition step of incrementing a corresponding count value in the count map of:
In each of the classification items, with reference to the count value in the corresponding count map, when the count value is “1” or more, a cost value for the specific mode in the classification item is stored, A cost value for the specific mode in the classification item is acquired from a cost table in the storage means, the cost value is accumulated, and the accumulated cost value is acquired as a difficulty level for the fingering. 1 cost accumulation step;
Based on the time information about the note, for each classification item related to the note length and the position in the measure of the note, among the classification values indicating specific modes in each of the classification items, classification values are also obtained for at least one classification item. A second classification item value acquisition step to be acquired;
In each of the classification items, based on the classification value in the classification item, the cost value for the specific mode in the classification item is stored, and from the cost table in the storage unit, the specific mode in the classification item A second cost accumulation step of obtaining a cost value, accumulating the cost value, and obtaining the accumulated cost value as a difficulty relating to the rhythm;
The tonality of the music is specified based on the pitch information of the notes, the degree of coincidence between the scale of the specified tonality and the pitch of the notes in the music, and the specified tonality A tonality difficulty level calculating step for calculating a tonality difficulty level relating to the tonality of the music piece based on the degree of disagreement between the scale and the pitch of the notes in the music piece;
An overall difficulty level calculating step for calculating the difficulty level of the music based on the difficulty level regarding the acquired fingering and the difficulty level regarding the rhythm and the calculated tonality difficulty level;
A program for calculating the degree of difficulty of music.
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2009129809A JP5071441B2 (en) | 2009-05-29 | 2009-05-29 | Music difficulty evaluation device and music difficulty evaluation program |
US12/782,914 US8106281B2 (en) | 2009-05-29 | 2010-05-19 | Music difficulty level calculating apparatus and music difficulty level calculating method |
DE102010029365A DE102010029365B4 (en) | 2009-05-29 | 2010-05-27 | Method and apparatus for calculating the difficulty level of the music |
CN201010192940.7A CN101901299B (en) | 2009-05-29 | 2010-05-28 | Music difficulty level calculation apparatus and music difficulty level calculating method |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2009129809A JP5071441B2 (en) | 2009-05-29 | 2009-05-29 | Music difficulty evaluation device and music difficulty evaluation program |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2010276891A JP2010276891A (en) | 2010-12-09 |
JP5071441B2 true JP5071441B2 (en) | 2012-11-14 |
Family
ID=43423909
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2009129809A Active JP5071441B2 (en) | 2009-05-29 | 2009-05-29 | Music difficulty evaluation device and music difficulty evaluation program |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP5071441B2 (en) |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP5782744B2 (en) * | 2011-02-24 | 2015-09-24 | ヤマハ株式会社 | Singing voice evaluation device |
JP5360510B2 (en) * | 2011-09-22 | 2013-12-04 | カシオ計算機株式会社 | Performance evaluation apparatus and program |
KR101714432B1 (en) * | 2015-09-03 | 2017-03-09 | 동국대학교 산학협력단 | Apparatus and method for estimating difficulty level of music score |
KR101795760B1 (en) * | 2015-12-28 | 2017-11-08 | 동국대학교 산학협력단 | Apparatus and method for classifying level of electronic music score |
WO2018216423A1 (en) * | 2017-05-26 | 2018-11-29 | ヤマハ株式会社 | Musical piece evaluation apparatus, musical piece evaluation method, and program |
JP7398812B2 (en) * | 2021-04-16 | 2023-12-15 | 株式会社コナミアミューズメント | Game system, computer program used therefor, and control method |
Family Cites Families (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4182637B2 (en) * | 2000-03-14 | 2008-11-19 | カシオ計算機株式会社 | Fingering information generation device, fingering information generation method, and storage medium storing fingering information generation program |
JP2002182642A (en) * | 2000-12-18 | 2002-06-26 | Casio Comput Co Ltd | Playing guide device and playing guide method |
JP3915428B2 (en) * | 2001-04-25 | 2007-05-16 | カシオ計算機株式会社 | Music analysis apparatus and program |
JP2005345557A (en) * | 2004-05-31 | 2005-12-15 | Daiichikosho Co Ltd | Karaoke system for singing ability judgment entry |
JP4613817B2 (en) * | 2005-12-27 | 2011-01-19 | カシオ計算機株式会社 | Fingering display device and program |
JP2007178696A (en) * | 2005-12-27 | 2007-07-12 | Casio Comput Co Ltd | Fingering information generating device and program |
JP4742288B2 (en) * | 2006-11-16 | 2011-08-10 | カシオ計算機株式会社 | Practice procedure generation device and practice procedure generation processing program |
JP5286793B2 (en) * | 2007-10-05 | 2013-09-11 | ヤマハ株式会社 | Scoring device and program |
-
2009
- 2009-05-29 JP JP2009129809A patent/JP5071441B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
JP2010276891A (en) | 2010-12-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8106281B2 (en) | Music difficulty level calculating apparatus and music difficulty level calculating method | |
JP5799977B2 (en) | Note string analyzer | |
US8680387B2 (en) | Systems and methods for composing music | |
EP3407344A2 (en) | Digital sight-singing piano with a fixed-solfège keyboard, continuous keys and adjustable tones by kneading piano keys | |
US20160148606A1 (en) | Automatic composition apparatus, automatic composition method and storage medium | |
JP5071441B2 (en) | Music difficulty evaluation device and music difficulty evaluation program | |
JP4916947B2 (en) | Rhythm detection device and computer program for rhythm detection | |
US8912418B1 (en) | Music notation system for two dimensional keyboard | |
JP6493543B2 (en) | Performance assist device and method | |
US20160148604A1 (en) | Automatic composition apparatus, automatic composition method and storage medium | |
JP5790686B2 (en) | Chord performance guide apparatus, method, and program | |
KR101931087B1 (en) | Method for providing a melody recording based on user humming melody and apparatus for the same | |
JP5196550B2 (en) | Code detection apparatus and code detection program | |
JP6481319B2 (en) | Music score display apparatus and music score display method | |
JP5272900B2 (en) | Music difficulty calculation device and music difficulty calculation program | |
JP5272899B2 (en) | Music difficulty calculation device and music difficulty calculation program | |
US20150310876A1 (en) | Raw sound data organizer | |
JP5696435B2 (en) | Code detection apparatus and program | |
US20130284000A1 (en) | Music note position detection apparatus, electronic musical instrument, music note position detection method and storage medium | |
US5403967A (en) | Electronic musical instrument having melody correction capabilities | |
JP4698606B2 (en) | Music processing device | |
JP4367156B2 (en) | Tuning device and program thereof | |
JP6606844B2 (en) | Genre selection device, genre selection method, program, and electronic musical instrument | |
Page | Perfect harmony: A mathematical analysis of four historical tunings | |
JP5564921B2 (en) | Electronic musical instruments |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20110422 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20110928 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20111004 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20111116 |
|
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: 20120724 |
|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20120806 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 5071441 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20150831 Year of fee payment: 3 |