// // Programmer: Craig Stuart Sapp // Creation Date: Mon Nov 20 17:32:36 PST 2000 // Last Modified: Tue Nov 28 16:53:34 PST 2000 // Last Modified: Wed Jan 1 22:40:22 PST 2003 added Maxwell class access // Last Modified: Fri Mar 11 09:10:03 PST 2011 added mark system. // Filename: ...sig/examples/all/dissic.cpp // Web Address: http://sig.sapp.org/examples/museinfo/humdrum/dissic.cpp // Syntax: C++; museinfo // // Description: determination of dissonance in context using rules given // by John Maxwell in: // // Reference: "An Expert System for Harmonizing Analysis of Tonal // Music." pp 335-353 in: "Understanding Music with AI: // Perspectives on Music Cognition." Ed. by Mira Balaban, // Kemal Ebcioglu, and Otto Laske. MIT Press; 1992. // [ISBN 0-262-52170-9] // // #include "humdrum.h" #include "PerlRegularExpression.h" #include #include #include // function declarations void checkOptions (Options& opts, int argc, char* argv[]); void example (void); void printAnalysis (HumdrumFile& infile, Array& dissic); void usage (const char* command); void printTokenWithMarks (const char* token, const char* mark); void printAnalysisMark (HumdrumFile& infile, Array& dissic); // global variables Options options; // database for command-line arguments int debugQ = 0; // used with --debug option int appendQ = 0; // used with -a option int compoundQ = 1; // used with -c option int markQ = 0; // used with -m option /////////////////////////////////////////////////////////////////////////// int main(int argc, char* argv[]) { HumdrumFile infile; Array dissic; // process the command-line options checkOptions(options, argc, argv); // figure out the number of input files to process int numinputs = options.getArgCount(); for (int i=0; i& dissic) { int i, j; const char* markchar = "@"; for (i=0; i > tokens; pre.getTokens(tokens, "\\s+", token); int i; for (i=0; i& dissic) { int i; if (appendQ) { for (i=0; i