Files
@ 5faf2cdfb6a5
Branch filter:
Location: tempo-plotter/src/demoreader.cpp - annotation
5faf2cdfb6a5
2.0 KiB
text/x-c++hdr
added new sample per second counter
fdf5f056db8f 42fdf0744adb fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f ceb94a4c22ec ceb94a4c22ec fdf5f056db8f fdf5f056db8f 8d33924610a0 8d33924610a0 8d33924610a0 8d33924610a0 42fdf0744adb 42fdf0744adb fdf5f056db8f fdf5f056db8f 42fdf0744adb fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f 42fdf0744adb fdf5f056db8f fdf5f056db8f fdf5f056db8f 42fdf0744adb fdf5f056db8f 42fdf0744adb fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f 42fdf0744adb 42fdf0744adb fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f fdf5f056db8f 42fdf0744adb 42fdf0744adb fdf5f056db8f fdf5f056db8f 42fdf0744adb fdf5f056db8f 42fdf0744adb fdf5f056db8f fdf5f056db8f | /*
Copyright © 2018 Hasan Yavuz Özderya
This file is part of serialplot.
serialplot 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 3 of the License, or
(at your option) any later version.
serialplot 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 serialplot. If not, see <http://www.gnu.org/licenses/>.
*/
#include <math.h>
#include "demoreader.h"
#ifndef M_PI
#define M_PI 3.14159265358979323846
#endif
DemoReader::DemoReader(QIODevice* device, QObject* parent) :
AbstractReader(device, parent)
{
paused = false;
_numChannels = 1;
count = 0;
timer.setInterval(100);
QObject::connect(&timer, &QTimer::timeout,
this, &DemoReader::demoTimerTimeout);
}
QWidget* DemoReader::settingsWidget()
{
return NULL;
}
void DemoReader::enable(bool enabled)
{
if (enabled)
{
timer.start();
}
else
{
timer.stop();
disconnectSinks();
}
}
unsigned DemoReader::numChannels() const
{
return _numChannels;
}
void DemoReader::setNumOfChannels(unsigned value)
{
_numChannels = value;
updateNumChannels();
}
void DemoReader::pause(bool enabled)
{
paused = enabled;
}
void DemoReader::demoTimerTimeout()
{
const double period = 100;
count++;
if (count >= 100) count = 0;
if (!paused)
{
SamplePack samples(1, _numChannels);
for (unsigned ci = 0; ci < _numChannels; ci++)
{
// we are calculating the fourier components of square wave
samples.data(ci)[0] = 4*sin(2*M_PI*double((ci+1)*count)/period)/((2*(ci+1))*M_PI);
}
feedOut(samples);
}
}
|