cwScoreFollower.cpp : Added pedal state info to write_sync_perf_csv().

This commit is contained in:
kevin 2023-12-17 08:56:56 -05:00
parent 960f028a9a
commit dce0049b76

View File

@ -121,6 +121,21 @@ namespace cw
return rc; return rc;
} }
bool _processPedal(const char* pedalLabel, unsigned barNumb, bool curPedalDownStateFl, uint8_t d1)
{
bool newStateFl = midi::isPedalDown(d1);
/*
if( newStateFl == curPedalDownStateFl )
{
const char* upDownLabel = newStateFl ? "down" : "up";
cwLogWarning("Double %s pedal %s in bar number:%i.",pedalLabel,upDownLabel,barNumb);
}
*/
return newStateFl;
}
rc_t _destroy( score_follower_t* p) rc_t _destroy( score_follower_t* p)
{ {
destroy(p->dynRefH); destroy(p->dynRefH);
@ -576,10 +591,14 @@ cw::rc_t cw::score_follower::midi_state_rt_report( handle_t h, const char* out_f
cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fname, const midi::file::trackMsg_t** msgA, unsigned msgN ) cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fname, const midi::file::trackMsg_t** msgA, unsigned msgN )
{ {
score_follower_t* p = _handleToPtr(h); score_follower_t* p = _handleToPtr(h);
rc_t rc = kOkRC; rc_t rc = kOkRC;
unsigned resultN = result_count(p->trackH); unsigned resultN = result_count(p->trackH);
auto resultA = result_base(p->trackH); auto resultA = result_base(p->trackH);
bool dampPedalDownFl = false;
bool sostPedalDownFl = false;
bool softPedalDownFl = false;
unsigned curBarNumb = 1;
file::handle_t fH; file::handle_t fH;
if( msgN == 0 ) if( msgN == 0 )
@ -602,7 +621,7 @@ cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fn
} }
// write the header line // write the header line
file::printf(fH,"meas,index,voice,loc,tick,sec,dur,rval,dots,sci_pitch,dmark,dlevel,status,d0,d1,bar,section,bpm,grace,pedal\n"); file::printf(fH,"meas,index,voice,loc,tick,sec,dur,rval,dots,sci_pitch,dmark,dlevel,status,d0,d1,bar,section,bpm,grace,damp_down_fl,soft_down_fl,sost_down_fl\n");
for(unsigned i=0; i<msgN; ++i) for(unsigned i=0; i<msgN; ++i)
{ {
@ -615,36 +634,72 @@ cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fn
{ {
uint8_t d0 = m->u.chMsgPtr->d0; uint8_t d0 = m->u.chMsgPtr->d0;
uint8_t d1 = m->u.chMsgPtr->d1; uint8_t d1 = m->u.chMsgPtr->d1;
if( midi::isNoteOn(m->status,d1) ) if( midi::isNoteOn(m->status,d1) )
{ {
const unsigned INVALID_LOC = 0;
char sciPitch[ midi::kMidiSciPitchCharCnt + 1 ];
unsigned bar = 0; unsigned bar = 0;
midi::midiToSciPitch( d0, sciPitch, midi::kMidiSciPitchCharCnt ); unsigned loc = score_parse::kInvalidLocId;
unsigned loc = INVALID_LOC; unsigned dlevel = -1;
char sciPitch[ midi::kMidiSciPitchCharCnt + 1 ];
midi::midiToSciPitch( d0, sciPitch, midi::kMidiSciPitchCharCnt );
// locate score matching record for this performed note
for(unsigned i=0; i<resultN; ++i) for(unsigned i=0; i<resultN; ++i)
{ {
const sfscore::event_t* e;
// FIX THIS: // FIX THIS:
// THE perfA[] INDEX IS STORED IN resultA[i].muid // THE perfA[] INDEX IS STORED IN resultA[i].muid
// this isn't right.
assert( resultA[i].muid != kInvalidIdx && resultA[i].muid < p->perfN ); assert( resultA[i].muid != kInvalidIdx && resultA[i].muid < p->perfN );
if( p->perfA[resultA[i].muid].muid == m->uid ) if( p->perfA[resultA[i].muid].muid == m->uid && resultA[i].scEvtIdx != kInvalidIdx)
{ {
assert( resultA[i].pitch == d0 ); assert( resultA[i].pitch == d0 );
loc = resultA[i].oLocId == kInvalidId ? INVALID_LOC : resultA[i].oLocId;
if((e = event( p->scoreH, resultA[i].scEvtIdx )) == nullptr )
{
cwLogError(kInvalidStateRC,"The performed, and matched, note with muid %i does not have a valid score event index.",m->uid);
goto errLabel;
}
bar = e->barNumb;
curBarNumb = std::max(bar,curBarNumb);
dlevel = e->dynLevel;
loc = resultA[i].oLocId == kInvalidId ? score_parse::kInvalidLocId : resultA[i].oLocId;
break; break;
} }
} }
rc = file::printf(fH, "%i,%i,%i,%i,0,%f,0.0,0.0,0,%s,,,%i,%i,%i,,,,,\n", rc = file::printf(fH, "%i,%i,%i,%i,0,%f,0.0,0.0,0,%s,,%i,%i,%i,%i,,,,,%i,%i,%i\n",
bar,i,1,loc,secs,sciPitch,m->status,d0,d1); bar,i,1,loc,secs,sciPitch,dlevel,m->status,d0,d1,dampPedalDownFl,softPedalDownFl,sostPedalDownFl);
} }
else else
{ {
rc = file::printf(fH, ",%i,,,%i,%f,,,,,,,%i,%i,%i,,,,,\n",i,0,secs,m->status,d0,d1);
if( midi::isPedal(m->status,d0) )
{
switch( d0 )
{
case midi::kSustainCtlMdId:
dampPedalDownFl = _processPedal("damper",curBarNumb,dampPedalDownFl,d1);
break;
case midi::kSostenutoCtlMdId:
sostPedalDownFl = _processPedal("sostenuto",curBarNumb,sostPedalDownFl,d1);
break;
case midi::kSoftPedalCtlMdId:
softPedalDownFl = _processPedal("soft",curBarNumb,softPedalDownFl,d1);
break;
}
}
rc = file::printf(fH, ",%i,,,%i,%f,,,,,,,%i,%i,%i,,,,,%i,%i,%i\n",i,0,secs,m->status,d0,d1,dampPedalDownFl,softPedalDownFl,sostPedalDownFl);
} }
} }