Mercurial > hg > c4dm-chord-transcriptions
view chordtools/note2pitchclass.m @ 1:8973548174c1 tip
adding tools to repo
author | christopherh |
---|---|
date | Mon, 06 May 2013 14:43:47 +0100 |
parents | |
children |
line wrap: on
line source
% %NOTE2PITCHCLASS convert a note to a pitchclass value w.r.t middle C % % [pitchclass, success, errormessage] = note2pitchclass(note, {verbose}) % % Converts a note string to a pitch class (integer) with C as reference % pitch class 0 % % Success = 1 if symbols parsed correctly, 0 otherwise. % % If optional argument 'verbose' is 1, function prints any errormessage to % the screen. % % returns: pitchclass (integer) % success (boolean) % errormessage (string) % % % Author: Christopher Harte, March 2009 % % Copyright: Centre for Digital Music, Queen Mary University of London 2005 % % This file is part of the C4DM Chord Toolkit V2.0 % % The C4DM Chord Toolkit is free software; you can redistribute it and/or % modify it under the terms of the GNU General Public License as published % by the Free Software Foundation; either version 2 of the License, or % (at your option) any later version. % % The C4DM Chord Toolkit is distributed in the hope that it will be useful, % but WITHOUT ANY WARRANTY; without even the implied warranty of % MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the % GNU General Public License for more details. % % You should have received a copy of the GNU General Public License % along with the C4DM Toolkit; if not, write to the Free Software % Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA % function [pitchclass, success, errormessage] = note2pitchclass(note, verbose) if nargin < 2 verbose = 0; end errormessage = ''; ilength = length(note); index = 1; success = 1; % first char should be a natural name A-G switch note(index) case 'C' % natural C pitchclass = 0; index = index + 1; case 'D' % natural D pitchclass = 2; index = index + 1; case 'E' % natural E pitchclass = 4; index = index + 1; case 'F' % natural F pitchclass = 5; index = index + 1; case 'G' % natural G pitchclass = 7; index = index + 1; case 'A' % natural A pitchclass = 9; index = index + 1; case 'B' % natural B pitchclass = 11; index = index + 1; otherwise %Unrecognised character errormessage = sprintf(['Error in Note2PitchClass: Unrecognised note "' note '"\n']); index = ilength + 1; pitchclass=-1; success = 0; end % any other characters should be either flats or sharps while index <= ilength switch(note(index)) case 'b' % FLAT pitchclass = pitchclass - 1; %decrement pitchclass value index = index + 1; case '#' % SHARP pitchclass = pitchclass + 1; %increment pitchclass value index = index + 1; otherwise % Unrecognised character errormessage = sprintf(['Error in Note2PitchClass: Unrecognised note "' note '"\n']); index = ilength + 1; pitchclass=-1; success = 0; end end % Use modulo command to make sure that we are back within range 0-12 if(success == 1) pitchclass = mod(pitchclass,12); else if(verbose == 1) fprintf(1,errormessage); end end