CMS50F37 debug test 7

This commit is contained in:
Mark Watkins 2014-08-18 18:00:21 +10:00
parent 807d8e3e39
commit 6283cb52ce
3 changed files with 160 additions and 73 deletions

View File

@ -123,9 +123,11 @@ int CMS50F37Loader::Open(QString path)
// Cheating using path for two serial oximetry modes
if (path.compare("import") == 0) {
//serial.clear();
serial.clear();
sequence = 0;
buffer.clear();
nextCommand();
setStatus(IMPORTING);
@ -142,81 +144,171 @@ int CMS50F37Loader::Open(QString path)
return 0;
}
static unsigned char cms50_sequence[] = { 0xa7, 0xa2, 0xa0, 0xb0, 0xac, 0xb3, 0xad, 0xa3, 0xab, 0xa4, 0xa5, 0xaf, 0xa7, 0xa2, 0xa6 };
unsigned char cms50_sequence[] = { 0xa7, 0xa2, 0xa0, 0xb0, 0xac, 0xb3, 0xad, 0xa3, 0xab, 0xa4, 0xa5, 0xaf, 0xa7, 0xa2, 0xa6 };
int cms50_seqlength = sizeof(cms50_sequence);
void CMS50F37Loader::processBytes(QByteArray bytes)
{
if (sequence < cms50_seqlength) {
unsigned char cmd = cms50_sequence[sequence];
int data;
if (cmd == 0xa5) { // DateTime
// > 7d 81 a5 80 80 80 80 80 80
// < 07 80 80 80 94 8e 88 92
// < 12 80 80 80 80 a3 bb 80
QString tmpstr;
}
}
int lengths[32] = { 0, 0, 0, 0, 0, 9, 4, 8, 8, 6, 4, 0, 2, 0, 3, 8, 3, 9, 8, 9, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
QStringList data;
buffer.append(bytes);
int size = buffer.size();
int len = bytes.size();
for (int i=0; i < len; ++i) {
data.append(QString::number((unsigned char)bytes.at(i),16));
}
if (++sequence < cms50_seqlength) {
qDebug() << "Read:" << data.join(",");
nextCommand();
} else {
qDebug() << "Read:" << data.join(",");
}
m_status = IMPORTING;
}
int CMS50F37Loader::doImportMode()
{
int available = buffer.size();
// Q_ASSERT(!finished_import);
int hour,minute;
int idx = 0;
while (idx < available) {
unsigned char c=(unsigned char)buffer.at(idx);
}
return idx;
}
int len;
int CMS50F37Loader::doLiveMode()
{
Q_ASSERT(oxirec != nullptr);
do {
unsigned char res = bytes.at(idx);
int available = buffer.size();
int idx = 0;
len = lengths[res & 0x1f];
QByteArray plethy;
while (idx < available-5) {
if (((unsigned char)buffer.at(idx) & 0x80) != 0x80) {
if (len < size)
break;
if (len == 0) {
// lost sync
idx++;
continue;
}
int pwave=(unsigned char)buffer.at(idx + 1);
int pbeat=(unsigned char)buffer.at(idx + 2);
int pulse=((unsigned char)buffer.at(idx + 3) & 0x7f) | ((pbeat & 0x40) << 1);
int spo2=(unsigned char)buffer.at(idx + 4) & 0x7f;
for (int i = 1; i < len; i++) {
buffer[idx+i] = buffer[idx+i] ^ 0x80;
}
oxirec->append(OxiRecord(pulse, spo2));
plethy.append(pwave);
switch(res) {
case 0x05: // 5,80,80,f5,f3,e5,f2,80,80
break;
case 0x6: // 6,80,80,87
data = buffer.at(idx+3) ^ 0x80;
break;
case 0x07: // 7,80,80,80,94,8e,88,92
tmpstr = QString().sprintf("%02i%02i%02i%02i",buffer.at(idx+5), buffer.at(idx+4), buffer.at(idx+6), buffer.at(idx+7));
imp_date = QDate::fromString(tmpstr, "yyyyMMdd");
break;
case 0x08: // 8,80,80,80,a4,81,80,80
break;
case 0x0a: // a,80,80,81
data = buffer.at(idx+3);
break;
case 0xc: // a7 & a2 // responds with: c,80
data = buffer.at(idx+1);
break;
case 0x0e: // e,80,81
break;
case 0x10: // 10,80,81
data = buffer.at(idx+2);
break;
case 0x11: // 11,80,81,81,80,80,80,80,80
break;
case 0x12: // 12,80,80,80,82,a6,92,80
tmpstr = QString().sprintf("%02i:%02i:%02i",buffer.at(idx+4), buffer.at(idx+5), buffer.at(idx+6));
imp_time = QTime::fromString(tmpstr, "HHmmss");
break;
case 0x13: // 13,80,a0,a0,a0,a0,a0,a0,a0
break;
case 0x14: //14,80,80,80,80,80,80,80,80
break;
idx += 5;
case 0x09: // cms50i data sequence
case 0x0f: // f,80,de,c2,de,c2,de,c2 cms50F data...
if (!started_import) {
started_import = true;
started_reading = true;
finished_import = false;
m_importing = true;
m_itemCnt=0;
m_itemTotal=5000;
m_startTime = QDateTime(imp_date, imp_time);
oxirec = new QVector<OxiRecord>;
oxirec->reserve(30000);
cb_reset = 1;
resetTimer.singleShot(2000,this,SLOT(resetImportTimeout()));
}
break;
default:
qDebug() << "unknown cms50 result?" << hex << (int)res;
break;
}
if (res == 0x09) {
int pi = buffer.at(idx + 4) | buffer.at(idx + 5) << 7;
oxirec->append(OxiRecord(buffer.at(idx+3), buffer.at(idx+2), pi));
// 9,80,e1,c4,ce,82 // cms50i data
} else if (res == 0x0f) {
oxirec->append(OxiRecord(buffer.at(idx+3), buffer.at(idx+2)));
oxirec->append(OxiRecord(buffer.at(idx+5), buffer.at(idx+4)));
oxirec->append(OxiRecord(buffer.at(idx+7), buffer.at(idx+6)));
// f,80,de,c2,de,c2,de,c2 cms50F data...
}
QStringList str;
for (int i=0; i < len; ++i) {
str.append(QString::number((unsigned char)bytes.at(idx + i),16));
}
if (!started_import) {
if (++sequence < cms50_seqlength) {
qDebug() << "Read:" << str.join(",");
// Send the next command packet in sequence
nextCommand();
}
} else {
qDebug() << "Import:" << str.join(",");
}
idx += len;
} while (idx < size);
if (!started_import) {
imp_callbacks = 0;
} else {
imp_callbacks++;
}
emit updatePlethy(plethy);
return idx;
buffer = buffer.mid(idx);
}
//int CMS50F37Loader::doLiveMode()
//{
// Q_ASSERT(oxirec != nullptr);
// int available = buffer.size();
// int idx = 0;
// QByteArray plethy;
// while (idx < available-5) {
// if (((unsigned char)buffer.at(idx) & 0x80) != 0x80) {
// idx++;
// continue;
// }
// int pwave=(unsigned char)buffer.at(idx + 1);
// int pbeat=(unsigned char)buffer.at(idx + 2);
// int pulse=((unsigned char)buffer.at(idx + 3) & 0x7f) | ((pbeat & 0x40) << 1);
// int spo2=(unsigned char)buffer.at(idx + 4) & 0x7f;
// oxirec->append(OxiRecord(pulse, spo2));
// plethy.append(pwave);
// idx += 5;
// }
// emit updatePlethy(plethy);
// return idx;
//}
void CMS50F37Loader::sendCommand(unsigned char c)
{
static unsigned char cmd[] = { 0x7d, 0x81, 0x00, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80 };
@ -248,6 +340,7 @@ void CMS50F37Loader::requestData() // Switch CMS50D+ device to record transmissi
void CMS50F37Loader::killTimers()
{
if (resetTimer.isActive()) resetTimer.stop();
}
void CMS50F37Loader::startImportTimeout()
@ -273,21 +366,14 @@ void CMS50F37Loader::resetImportTimeout()
if (!finished_import && (started_import && started_reading)) {
qDebug() << "Switching CMS50 back to live mode and finalizing import";
// Turn back on live streaming so the end of capture can be dealt with
resetTimer.stop();
resetDevice(); // Send Reset to CMS50D+
serial.flush();
QThread::msleep(200);
resetDevice(); // Send Reset to CMS50D+
serial.flush();
serial.clear();
//started_import = false;
// finished_import = true;
//m_streaming=false;
finished_import = true;
m_streaming = false;
emit importComplete(this);
//closeDevice();
//emit transferComplete();
//doImportComplete();
return;
}
qDebug() << "Should CMS50 resetImportTimeout reach here?";

View File

@ -62,14 +62,11 @@ protected:
bool readSpoRFile(QString path);
virtual void processBytes(QByteArray bytes);
int doImportMode();
int doLiveMode();
// int doLiveMode();
virtual void killTimers();
void sendCommand(unsigned char c);
QList<unsigned char> cmdQue;
// Switch device to live streaming mode
virtual void resetDevice();
@ -100,6 +97,8 @@ protected:
int m_itemCnt;
int m_itemTotal;
QDate imp_date;
QTime imp_time;
};

View File

@ -21,11 +21,13 @@ struct OxiRecord
{
quint8 pulse;
quint8 spo2;
OxiRecord():pulse(0), spo2(0) {}
OxiRecord(quint8 p, quint8 s): pulse(p), spo2(s) {}
OxiRecord(const OxiRecord & copy) { pulse = copy.pulse; spo2= copy.spo2; }
};
quint16 pl_inf;
OxiRecord():pulse(0), spo2(0),pl_inf(0) {}
OxiRecord(quint8 p, quint8 s): pulse(p), spo2(s) {}
OxiRecord(quint8 p, quint8 s, quint16 pi): pulse(p), spo2(s), pl_inf(pi) {}
OxiRecord(const OxiRecord & copy) { pulse = copy.pulse; spo2 = copy.spo2; pl_inf = copy.pl_inf; }
};
class SerialOximeter : public MachineLoader
{