/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- * vim: set ts=8 sts=4 et sw=4 tw=99: * * SleepLib Event Class Implementation * * Copyright (c) 2011-2014 Mark Watkins * * This file is subject to the terms and conditions of the GNU General Public * License. See the file COPYING in the main directory of the Linux * distribution for more details. */ #include #include "event.h" EventList::EventList(EventListType et,EventDataType gain, EventDataType offset, EventDataType min, EventDataType max,double rate,bool second_field) :m_type(et),m_gain(gain),m_offset(offset),m_min(min),m_max(max),m_rate(rate),m_second_field(second_field) { m_first=m_last=0; m_count=0; if (min==max) { // Update Min & Max unless forceably set here.. m_update_minmax=true; m_min2=m_min=999999999; m_max2=m_max=-999999999; } else { m_update_minmax=false; } m_data.reserve(2048); // Reserve a few to increase performace?? } EventList::~EventList() { } void EventList::clear() { m_min2=m_min=999999999; m_max2=m_max=-999999999; m_update_minmax=true; m_first=m_last=0; m_count=0; m_data.clear(); m_data2.clear(); m_time.clear(); } qint64 EventList::time(quint32 i) { if (m_type==EVL_Event) { return m_first+qint64(m_time[i]); } return m_first+qint64((EventDataType(i)*m_rate)); } EventDataType EventList::data(quint32 i) { return EventDataType(m_data[i])*m_gain; } EventDataType EventList::data2(quint32 i) { return EventDataType(m_data2[i]); } void EventList::AddEvent(qint64 time, EventStoreType data) { m_data.push_back(data); // Apply gain & offset EventDataType val=EventDataType(data)*m_gain; // ignoring m_offset if (m_update_minmax) { if (m_count==0) { m_max=m_min=val; } else { if (m_min>val) m_min=val; if (m_maxtime) { // Crud.. Update all the previous records // This really shouldn't happen. qint32 t=(m_first-time); for (quint32 i=0;idata2) m_min2=data2; if (m_max2val) m_min=val; if (m_maxtime) { // Crud.. Update all the previous records // This really shouldn't happen. qint32 t=(m_first-time); for (quint32 i=0;istart) { //qWarning() << "Attempted to add waveform with previous timestamp"; // return; // technically start should equal m_last+1 sample.. check this too. } if (m_last val) min=val; if (max < val) max=val; } m_min=min; m_max=max; } else { //register EventDataType val,gain=m_gain; for (sp=data; sp < ep; sp++) { *dp++=raw=*sp; //val=EventDataType(raw)*gain; } } } void EventList::AddWaveform(qint64 start, unsigned char * data, int recs, qint64 duration) { if (m_type!=EVL_Waveform) { qWarning() << "Attempted to add waveform data to non-waveform object"; return; } if (!m_rate) { qWarning() << "Attempted to add waveform without setting sample rate"; return; } // duration=recs*rate; qint64 last=start+duration; if (!m_first) { m_first=start; m_last=last; } if (m_last>start) { //qWarning() << "Attempted to add waveform with previous timestamp"; // return; // technically start should equal m_last+1 sample.. check this too. } if (m_lastval) m_min=val; if (m_maxstart) { //qWarning() << "Attempted to add waveform with previous timestamp"; //return; // technically start should equal m_last+1 sample.. check this too. } if (m_lastval) m_min=val; if (m_max