Piano Chord Builder
Piano Chord Builder
Piano Chord Builder
Artem Kuligin
CS 470 –Project Write-up
1. Introduction 3
2. Project Overview 4
2.1 - General Source of Data. 4
2.2. Basic idea – Theory 6
2.3. Basic Features of application 7
3. Project Requirements 8
3.1. System Specifications. 8
4. System Design. 9
4.1. User Interface 9
4.2 Data Structures 10
4.3 System Architecture 11
4.4. Algorithms 13
5. Software Development Process 14
5.1 Prototyping Challenges 15
6. Schedule 16
7. Results 16
8. References 17
9. Program interface and features. User’s 18
Manual
2
Piano Chord Builder
Artem Kuligin
1. Introduction
This application has been developed as testing template project for further
development using different hardware platforms and operating systems.
There are many similar products on the market designed to help train people to learn
music basics. Especially there are dominant quantities of applications for kids.
But, according to my research, one of the reasons that we have such diversity of
similar programs. Is the way how programs being designed to present a music theory.
Some application are giving us a specifics of some certain rule, without providing any
kind general info , as an example a musical chord structure and it’s origin. So, my idea
was to design an application that will provide a basic help for beginners to learn music
theory, without going deep into specifics.
The project was carried out with a help of professional pianist - Lubov Mikhailova.
From whom I have received a lots of clues and ideas how to design my application,
since at very beginning I did not have any knowledge about music theory.
3
2. Project Overview
Many people taking piano lessons. And they find it very interesting. But playing piano
is not just following the sequence of musical notes. It is also ability to know the
general principles of music construction. This is a way to understand why music some
progressions sound ear friendly to us, and why others don’t. To produce a melodic or
harmonic sequence we have to understand how music is made.
In music, a chord is any set of harmonically-related notes that is heard as if sounding
simultaneously (a "harmonic simultaneity"). The most frequently encountered chords
in theory and music are triads: major and minor and then the augmented and
diminished triads. The descriptions "major", "minor", "augmented" and "diminished"
are referred to collectively as chordal "quality".
All chords are formed by combining certain scale tones according to definitive
rule (“Circle of fifths”).
4
Figure 2-1.
The place where music theory and more specifically knowledge of the Circle of
Fifths (Fig. 2-1) can help user when he needs to write a song or to figure a song out by
ear. The Circle of Fifths can help user easily construct hundreds of Chord Progressions,
Lead Lines, Harmonies, and just about anything else once user get the hang of it.
5
2.2. Basic idea – Theory
Music chords are constructed from musical intervals. Each chord has:
1) A Root note
2) A note a Major third (M3) or minor third (m3) above the Root
3) A note a Perfect fifth (P5), Augmented fifth (A5), or diminished fifth above
the Root
If we choose a C - Major chord (Fig. 2-2-I) for example we begin by picking a Root note.
We could pick any of the 12 notes but in this case we will choose C. The next note we
need is a Major third (M3) above the Root, which in this case would be the note E. The
final note we need is a Perfect fifth above the root, which in this case would be the
note G. Now we have all three notes of our Major chord: C, E, and G.
Figure 2-2.
The same Chord Progression can be indicated on the Circle of fifths. (Fig. 2-3)
6
Figure 2-3.
So my goal was to deliver an application that will help beginning piano players
to learn and use musical construction rules. To be able to utilize a modern music
devices to produce a practice musical Chord Progressions.
To have a good foundation for further development (Portable Devices, Embedded
Software and etc…). To get a good practical skills, while working with musical hardware
and software communication.
7
3. Project Requirements
Generally my program should have a user friendly interface to help user to understand
principles of construction of Chord Progressions. As I mentioned before, I received an
objective support from my friend who happed to be a pro pianist.
So, after we have composed a general idea of how we can deliver a useful information
to the user. I have composed necessary features of my application.
8
4. System Design.
4.1. User Interface
Generally during I was trying to keep every thing on the screen. All controls had been
placed on the form, so that user would not have to use a computer input devices all
the time. Since the program has a MIDI input support.
Figure 4-1.
The main form (Figure 4-1) of application has a combined set of controls required to
perform a Chord Progression modulation and edition.
MIDI output device: To select a MIDI sound device to be used for audio output
MIDI input device: To select a MIDI input device to be used for note input
“Chord Selector” group.
o “Notes in chord”: An editable text box Indicate note structure of a
chord
o “ROOT NOTE”: A selectable list for chord root note.
o “CHORD”: A selectable list of Chord Progression based on selected Root
Note.
o “SCALE”: A list of keyboard major scales available in program DB.
9
o “Display Type”: A group of controls, to select the way that notes in a
chord shall be visualized.
o Button Controls – “Copy”, “Paste”, “Clear”: A basic Windows Clipboard
control buttons for “Notes in chord” text filed.
FULL Scale 88 key piano keyboard: An advanced input and output control
presented as a virtual piano keyboard.
Circle of Fifths: Visual presentation of music note used in Chord progression.
The controls that are not being listed, used for development purposes.
There are not too many places in application where I used any advanced data
structures. Since the application is modular (Sound input and output, Keyboard
controls, Chord Recognition), I tried not too overcomplicating things, since this is a
template project for a bigger final product. The main data structure for used, was
a modified Binary Tree to Data tree – too organize a Chord Progressions stored in a
program by default, and its'.
To store a Chord Progressions the basic binary tree was really helpful. All data
shall be imported using a text file stored in program folder.
During importing this text file, the nodes of a data trees being constructed.
Text file entries and tree node example:
C-Major,C,E,G
C-Minor 7 Th, C, D# / Eb, G, A# / Bb C
E D# / Eb
G, C-Major G
A# / Bb, C-Minor 7 Th
10
Figure 4-2-1. The simple presentation of binary tree nodes to store Chord
Progressions. In this example two Chord Progressions (C-Major and C-Minor 7Th)
had been stored in a binary tree node.
The data tree mostly been utilized to generate and search Chord Progressions.
11
later. The program is continuously listening for any MIDI message to come in through
MIDI input device. And the if the user want to capture any keys that being pressed, all
that is required is to enable capture feature of external input device.
Also there are 3 alternative note input modes available:
o Using a text editor – User directly modifies a chord formula text field to see the
layout on the screen
o Virtual piano input - User directly press a virtual piano key to add note to the
chord field to see the layout on the screen
o External Piano - User directly press a piano key to add note to the chord field
to see the layout on the screen .
Virtual piano keyboard – An event driven user control that enable user to utilize a
features of real piano keyboard, without having one. Each individual key is a separate
sub user control that carries it unique properties: Key Name, Tone, Position and color.
When user presses a virtual piano key, a system event is being raised, that affect a
behavior of virtual piano key and system note recognizer.
External Piano keyboard – A real hardware device that is attached to the computer
to produce note phrases using a piano keyboard. When user presses a piano key, a
system event is being raised, that affect a behavior of virtual piano key and system
note recognizer. The keyboard is being attached to system via Microsoft standard open
source libraries and system files included in Window OS.
12
4.4. Algorithms
3) Virtual Piano keyboard animation event – To implement this user control, I used
standard graphic function of C#. Basically each time then we press and release a piano
key there two messages being raised. Press Piano Key - indicates that we could press
a piano key a hold a finger on the key. Release Piano Key –indicates the we removed a
finger from piano key. To do a proper highlighting a have developed a simple logic and
algorithms to maintain a proper animation.
13
5. Software Development Process
During a period of development I have switched to several approaches how to
organize my program logic that will be flexible enough to add or remove unnecessary
feature. There still some features that need to be implemented but this goes beyond
time limit that I had for development.
There several major fields that I had to study before starting this project. Initially I had
no info and no experience in music theory. For example, in order to understand how
the piano keyboard been organized, I moved myself from a field of computer science
to the world of music science. Also I had no experience working with external devices
such as MIDI keyboard. The MIDI as a technology in a protocol that enables musical
devices to pass a musical data between each other. MIDI – Contrary to other audio
formats, MIDI does not transmit the actual audio signal or waveform to be played.
Instead, it simply transmit a series of event messages such as "press a 'C' key and
release it when I tell you”. If you play back the recording of a real piano performance,
it will sound very similar on all players, and differences in sound will only depend on
the quality of the playback system and the speakers. So the challenge was to create a
class to receive MIDI messages from input MIDI devices and send it back. And instead
of reinventing a wheel. I used a Microsoft open source code to connect and pass
messages to General MIDI audio device.
There major steps that I had to go over during development of this application:
o Music theory research – The major part of entire project. I spent a majority
of my time cover this field and I’m glad that I got such a good opportunity
to be familiar with music construction principles.
o MIDI Technology – This part is closely related to computer science but still
requires knowing basic principles of music instruments, like piano.
As a protocol, it is not complicated at all. But requires a huge time
investment into research. In my case, it was the problem of understanding
external keyboard messages using a standard techniques. As we all know
there are dozens of digital piano keyboard manufactures. Each keyboard of
some brand produces a set of messages that is slightly different from
14
others. For example Yamaha keyboard produce message format like: Key,
Velocity and Weight. And Casio keyboards produce Key, Velocity and
Average hammer travel time. In both cases Velocity value is not in the same
range. Yamaha’s range is from 1 to 160, Casio’s is 1-100. So it was really had
to tell how we should process these type of commands. After all I found
easy solution for both cases. All I had to do, is to disable advanced keyboard
features like hammer touch and after sensor. But these is a very important
system requirement, that is MIDI device must support General MIDI
protocol.
o Development Steps:
1) User controls aka virtual piano keyboard.
2) Music Note processing. To or from Output audio device.
3) Chord Formula Builder
4) Visualization of presented chord.
5) Output to audio MIDI enabled device.
15
Also there are several issues that faced during development . I wish to list most critical:
o MIDI format for different brands. Interesting fact, that there is no universal
software on the market that knows everything about keyboards.
o The visual presentation of “The Circle of Fifths” has been suspended. Since
C#. NET does not support graphic files with pixel transparent data.
6. Schedule
WEEK.
1-6: Music theory research. General idea development. Requirements and
Input data generalization. Documentation.
6-7: XML Engine implementation. Hardware research. MIDI Protocol.
8-9: UI. Final Specification Review.
10-12: Hardware testing.
13-14: Documentation. Final Debugging.
15: Demonstration. And Final write-up
7. Results
My goal was to demonstrate that music production software is one of the most
interesting fields. This project pushed me a lot farther in this area than I expected.
The program is still under development but it is in a good stage when I can tell that it
has potential and may be a good place in a software market.
My personal idea is to deliver a good product that will help beginning piano players to
learn and use musical construction rules. To have a good foundation for further
development (Portable Devices, Embedded Software and etc…)
To get a good practical skills, while working with musical hardware and software
communication
16
8. References
2) Desktop Audio Technology: Digital audio and MIDI principles (Music Technology),
Francis Rumsey, Focal Press; 2003
3) Music Theory: A Practical Guide for All Musicians, Hal Leonard 2006
17
9. Program interface and features. User’s Manual
The main application window has all combined controls in one place.
1) Virtual keyboard - To play music notes on virtual keyboard. Just use your mouse
and clicks keyboard key to activate it.
18
3) To use your external input device in a program. Connect your keyboard before
launching the application. And make sure that all drivers had been installed
properly. If the device successfully recognized by application it will automatically
added to the list of available input devices.
4) To use chord recognition system, try to play any general chord on your external
keyboard. If Chord progression identified it will be displayed in console window.
5) When you would like to exit the application, choose F)ile, E)xit or click the X in the
upper right corner.
19
Appendix A: Code Listing
20