data:image/s3,"s3://crabby-images/42e4f/42e4fd79e94dad623d0c38d2aacbb13d6b58db20" alt=""
Activity 9
Playing with Notes
I look forward to this activity so much because it involves music!!! When I was younger, my mother always drag me and my siblings to singing contests and talent shows. If my course is not physics, I'd be a theater major.
This activity let's make SCILAB SING SING SIIIIIIIINNNGGGG! To do this we, need to integrate a lot of the things we've learned from the past activities.
By the way, I feel so refreshed today for I finished blogging the dreaded and long Activity 8 on Morphological Operations.
Let me first discuss some music notation basics. In a stanza, there are five lines. Letters are used to denote the placement of the notes in the stanza. A sample code that makes SCILAB sing Mary had a little lamp is illustrated below:
data:image/s3,"s3://crabby-images/885b5/885b5bf5d9f8d91b48301a05984984d90372973c" alt=""
The values of the notes are frequency values that I got from [4]. For this activity, I chose a very simple score. My childhood favorite, Twinkle, Twinkle, Little Star. The score is shown below:
data:image/s3,"s3://crabby-images/1db4f/1db4f1d5128a6808fd998071afaddc36240932c4" alt=""
I then cropped the stanzas in GIMP:
cropped stanza 1 and 2
data:image/s3,"s3://crabby-images/145a3/145a3fbe9a3560e894b55c48b95e144496354925" alt=""
data:image/s3,"s3://crabby-images/459d8/459d815755614bdd35af1309b6f21eafdbce1b95" alt=""
It is easier for me to manipulate images with a black background such that the blobs will have the highest intensity value. Using the SegmentByThreshold() function in SCILAB, I binarized the image with a threshold value of 100.
black and white thr < 100
data:image/s3,"s3://crabby-images/f8e6d/f8e6dca2c22ccbc132ea6926b29f18fadf13b3fe" alt=""
data:image/s3,"s3://crabby-images/3adfc/3adfcc5e24c126c5a17dd6661e7e70ab2f58c6be" alt=""
Next, using my vast knowledge on morphological operations thanks to Activity 8, I opened the image with a vertical line 3 pixels thick thus removing horizontal profiles as shown:
clean 1
data:image/s3,"s3://crabby-images/7a4b6/7a4b652accd414dcdd89113098b024aa2a40540e" alt=""
data:image/s3,"s3://crabby-images/9887c/9887c164f288b27f0dedd7d7de1fb1710044c745" alt=""
For the music that I am trying to recreate, I am only considering full notes. So my next step is to close holes and what better operation to use other than the closing operator. I used a circular structuring element with radius 6 resulting to:
clean 2
data:image/s3,"s3://crabby-images/edec2/edec2c0d63a144e5a08e8718354a1ec63376971f" alt=""
data:image/s3,"s3://crabby-images/700fb/700fb82b28ae5213a080d7cbf225b207de6160cc" alt=""
The next step is to remove the vertical lines by doing an opening operation with a horizontal line as a structuring element:
clean 3
data:image/s3,"s3://crabby-images/0e3f0/0e3f088ac258731e48a0459abdfd529e83fdb9ea" alt=""
data:image/s3,"s3://crabby-images/36f61/36f61cc7a036c511fea409c71c7011b48453f735" alt=""
Finally to make the blobs roundish, I open the image again but this time by using a circle with radius 6 as a structuring element:
clean 4
data:image/s3,"s3://crabby-images/33594/3359446f4337ee49271b49e51a954f411c8b80d2" alt=""
data:image/s3,"s3://crabby-images/8d2fc/8d2fccf98ba6e96f308aecac8d8d3a3cb19b6f56" alt=""
The next thing that I need to do is to determine the note by virtue of its vertical position. I imported the image in GIMP and identified the ranges (with corresponding frequency values) as:
data:image/s3,"s3://crabby-images/4fbd3/4fbd3c9c043bf70d67bd2d4551e51c561bb14544" alt=""
C = 120 - 145 [261.63*2]
G = 77 - 107 [392.00*2]
A = 63 - 95 [440.00*2]
F = 89 - 115 [349.23*2]
E = 97 - 125 [329.63*2]
D = 108 - 135 [293.66*2]
By using SearchBlobs() and AnalyzeBlobs(), I calculated the centroid of each blob. After SearchBlobs(), the image looks like this:
data:image/s3,"s3://crabby-images/ff0cb/ff0cb5d267b40523e423f4dc6ebab8d4f74c8338" alt=""
data:image/s3,"s3://crabby-images/6f912/6f91251280a33546f9c1ef94efd9f50692a74674" alt=""
When the centroid of the blob falls under a specific range of a note, it plays that note. I saved the output as an mp3 file, converted it to video using [2] and uploaded the video in YouTube. I only generated a music file for the first stanza. Feel free to listen.
The reconstruction wasn't at all perfect yet since I approximated (or closed) the half note to a full note.
My take away in this activity is that it really takes talent to do morphological operations. To further improve the quality of the reconstruction a more accurate method should be devised to depict the range of the note. My method of manually identifying in GIMP was not at all accurate.
I would give myself a rating of 12/10 for producing all the required images. I would like to thank wix.com for their very nice website platform.
References:
[1] M. Soriano. “A9 - Playing Notes by Image Processing,” Applied Physics 186 Activity Hand-outs, 2016.
[2] tovid.io [for converting my mp3 to video with a photo]
[3] singing-bell.com http://www.singing-bell.com/wp-content/uploads/2014/12/TwinkleTwinkle_C_Image.jpg
[4] Physics of Music - Notes. http://www.phy.mtu.edu/~suits/notefreqs.html