OpenCores
URL https://opencores.org/ocsvn/modular_oscilloscope/modular_oscilloscope/trunk

Subversion Repositories modular_oscilloscope

[/] [modular_oscilloscope/] [trunk/] [sw/] [src/] [rviboardtools.cpp] - Rev 60

Compare with Previous | Blame | View Log

#include <cmath>
#include <QTimer>
#include <QString>
#include <QColorDialog>
#include <QInputDialog>
#include <qwt_counter.h>
#include "rviboardtools.h"
#include "ui_rviboardtools.h"
 
// temp
#include <QDir>
 
 
class Suffixer
{
public:
    Suffixer(double number = 0.0)
    {
        setNumber(number);
    }
 
    void setNumber(double number)
    {
        number = qAbs(number);
        if (number < 1e-9)
        {
            multiplier = 1e9;
            suffix = QString("p");
        }
        else if (number < 1e-6)
        {
            multiplier = 1e6;
            suffix = QString("n");
        }
        else if (number < 1e-3)
        {
            multiplier = 1e6;
            suffix = QString("u");
        }
        else if (number < 1.0)
        {
            multiplier = 1e3;
            suffix = QString("m");
        }
        else
        {
            multiplier = 1.0;
            suffix = QString("");
        }
    }
 
    double multiplier;
    QString suffix;
};
 
 
RVIBoardTools::RVIBoardTools(QWidget *parent)
    : QWidget(parent),
    ui(new Ui::RVIBoardTools)
{
    ui->setupUi(this);
 
    slidersTimer = new QTimer(this);
    slidersTimer->setInterval(550);
 
    dataTimer = new QTimer(this);
    dataTimer->setInterval(30);   // plot update time
 
    dataAVec = new QVector<double>;
    dataBVec = new QVector<double>;
    timeVec = new QVector<double>;
    board = new RVICommThread(this);
 
 
    // Timer for sliders
    connect(slidersTimer, SIGNAL(timeout()),this, SLOT(updateSlidersValues()));
 
    connect(ui->timeZoomSlider , SIGNAL(sliderPressed()), slidersTimer , SLOT(start()));
    connect(ui->timeZoomSlider, SIGNAL(sliderReleased()), slidersTimer, SLOT(stop()));
    connect(ui->timePosSlider , SIGNAL(sliderPressed()), slidersTimer , SLOT(start()));
    connect(ui->timePosSlider, SIGNAL(sliderReleased()), slidersTimer, SLOT(stop()));
 
    connect(ui->channelAZoomSlider , SIGNAL(sliderPressed()), slidersTimer , SLOT(start()));
    connect(ui->channelAZoomSlider, SIGNAL(sliderReleased()), slidersTimer, SLOT(stop()));
    connect(ui->channelAPosSlider, SIGNAL(sliderPressed()), slidersTimer , SLOT(start()));
    connect(ui->channelAPosSlider, SIGNAL(sliderReleased()), slidersTimer, SLOT(stop()));
 
    connect(ui->channelBZoomSlider , SIGNAL(sliderPressed()), slidersTimer , SLOT(start()));
    connect(ui->channelBZoomSlider, SIGNAL(sliderReleased()), slidersTimer, SLOT(stop()));
    connect(ui->channelBPosSlider, SIGNAL(sliderPressed()), slidersTimer , SLOT(start()));
    connect(ui->channelBPosSlider, SIGNAL(sliderReleased()), slidersTimer, SLOT(stop()));
 
    // Board connections
    //connect(board, SIGNAL(chANewData(int )), this, SLOT(chAAppData(int)) );
    //connect(board, SIGNAL(chBNewData(int )), this, SLOT(chBAppData(int)));
    //connect(board, SIGNAL(finished()),this,SLOT(uncheckRunButtons()));
    //connect(board, SIGNAL(endOfBuffer()), this, SLOT(showResults()),Qt::DirectConnection);
    connect(board, SIGNAL(statusMessage(QString)), this, SLOT(sendStatusMessage(QString)));
    connect(this, SIGNAL(stopAcquistion()), board, SLOT(stopAcquistion()), Qt::DirectConnection);
    // Timer for board
    connect(dataTimer, SIGNAL(timeout()), this, SLOT(showResults()), Qt::DirectConnection);
 
 
}
 
RVIBoardTools::~RVIBoardTools()
{
    delete ui;
}
 
 
void RVIBoardTools::setDefaultValues()
{
    // Fill trigger combo
    fillTriggerCombo();
 
    // Fill trigger Slope
    ui->trigSlopeCombo->addItem(QIcon(":/images/rising.png"),"Rising");
    ui->trigSlopeCombo->addItem(QIcon(":/images/falling.png"),"Falling");
 
 
    // Set Max-Min values
    ui->bufferSpinBox->setMaximum(MAX_BUFF_SIZE);
    ui->bufferSpinBox->setMinimum(MIN_BUFF_SIZE);
 
 
 
 
    fillSampleTimeCombo();
 
    // Data
    chAOffset = 0;
    chBOffset = 0;
 
    confTScal = 1023;
    confTScalEn = 1;
 
    paused = false;
 
    ui->bufferSpinBox->setValue(1000);
    setVoltMultipliers();
    updateTimeVec();
 
 
    // Signals
    emit timeChangeLimits(timeVec->first(), timeVec->last());
    emit channelAColorChanged( ui->channelAColorButton->palette().button().color());
    emit channelBColorChanged( ui->channelBColorButton->palette().button().color());
 
}
 
 
void RVIBoardTools::stop()
{
    if (!ui->runButton->isChecked())
    {
        dataTimer->stop();
        statusChanged("stop timer");
    }
   emit stopAcquistion();
   //board->terminate();
}
 
void RVIBoardTools::setPaused(const bool &on)
{
    paused = on;
    setEnabled(!on);
    if (on)
        emit statusChanged(tr("Paused"));
}
 
void RVIBoardTools::startAcquisition(const bool &continuous)
{
    bool ok;
 
//    if (board->isRunning())
//    {
//        //while (!board->isFinished())
//       // {
//            repaint();
//            stop();
//            board->quit();
//        //}
//    }
 
    emit timeChangeLimits(timeVec->first(), timeVec->last());
 
    board->setAddress(ui->addressBox->currentText().toShort(&ok, 16));
    board->setContinuous(continuous);
    board->setTrigger(ui->trigBox->isChecked(),
                     ui->trigSlopeCombo->currentText() == "Falling",
                     ui->trigSouceCombo->currentText() == "A",
                     ui->trigLevelSpinBox->value()* 1023/100,
                     ui->trigOffsetSpinBox->value());
    board->setChannels(ui->channelABox->isChecked(),
                      ui->channelBBox->isChecked());
    board->setBuffer(ui->bufferSpinBox->value());
    board->setTimeScaler(ui->sampleTimeCombo->currentIndex() > 0,
                        ui->sampleTimeCombo->currentIndex() - 1);
 
    board->start(QThread::LowestPriority);
 
    if (!dataTimer->isActive())
        dataTimer->start();
 
    disconnect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
 
}
 
 
void RVIBoardTools::showResults()
{
    if (!paused)
    {
        if ( ui->quickUpdateCheck->isChecked() || board->isBufferFull()  )
        {
            if (ui->channelABox->isChecked())
            {
                dataAVec->clear();
                data = board->getChannelData(0);
                if (data.size() > 5)
                {
                    for (int i = 0; i < data.size(); i++)
                        dataAVec->append((data.at(i) - 512)* chAVoltMultiplier + chAOffset);
                    emit channelAData(*timeVec, *dataAVec);
                }
            }
            if (ui->channelBBox->isChecked())
            {
                dataBVec->clear();
                data = board->getChannelData(1);
                if (data.size() > 5)
                {
                    for (int i = 0; i < data.size(); i++)
                        dataBVec->append((data.at(i) - 512) * chBVoltMultiplier + chBOffset);
                    emit channelBData(*timeVec, *dataBVec);
                }
            }
        }
    }
}
 
 
void RVIBoardTools::sendStatusMessage(const QString &status)
{
    emit statusChanged(status);
}
 
 
 
void RVIBoardTools::updateTimeVec()
{
    double deltaTime;
    deltaTime = pow(2.0,ui->sampleTimeCombo->currentIndex()) / board->getADCSampleRate();
 
    int size;
    size = ui->bufferSpinBox->value();
    if (ui->channelABox->isChecked() && ui->channelBBox->isChecked())
        size = size/2;
 
    timeVec->clear();
    timeVec->append(deltaTime * ui->trigOffsetSpinBox->value());
    for (int i = 1; i < size; i++)
        timeVec->append(timeVec->at(i-1) + deltaTime);
    //statusChanged(tr("Primero %1 y segundo %2").arg(timeVec->first()).arg(timeVec->last()));
}
 
void RVIBoardTools::setVoltMultipliers()
{
    if (!(ui->channelAZBtn->isChecked()))
    {
        if (ui->chASpan2VRadio->isChecked())
            chAVoltMultiplier = 2.0/1024;
        else
            chAVoltMultiplier = 1.0/1024;
    }
    else
        chAVoltMultiplier = 0.0;
 
    if (!(ui->channelBZBtn->isChecked()))
    {
        if (ui->chBSpan2VRadio->isChecked())
            chBVoltMultiplier = 2.0/1024;
        else
            chBVoltMultiplier = 1.0/1024;
    }
    else
        chBVoltMultiplier = 0.0;
}
 
 
void RVIBoardTools::uncheckRunButtons()
{
    ui->runButton->setChecked(false);
    ui->singleButton->setChecked(false);
}
 
 
QVector<double> RVIBoardTools::getData(RVIBoardTools::VariableType var)
{
    switch(var)
    {
        case RVIBoardTools::ChannelA:
            return *dataAVec;
            break;
 
        case RVIBoardTools::ChannelB:
            return *dataBVec;
            break;
 
        default:
            return *timeVec;
            break;
    }
 
}
 
 
///////////////////////////////////////////////////////////////////////
// Trigger
 
void RVIBoardTools::on_trigLevelSlider_valueChanged(int value)
{
    double d_value;
    if (ui->trigSouceCombo->currentText() == "B")
    {
        if (ui->chBSpan2VRadio->isChecked())
            d_value = (value - 50) * 2.0/50;
        else
            d_value = (value - 50) * 1.0/50;
    }
    else
    {
        if (ui->chASpan2VRadio->isChecked())
            d_value = (value - 50) * 2.0/50;
        else
            d_value = (value - 50) * 1.0/50;
    }
   emit changeTriggerValue(d_value);
 
}
 
 
void RVIBoardTools::on_trigLineCheck_toggled(bool checked)
{
    emit showTriggerLine(checked, ui->trigSouceCombo->currentIndex());
}
 
 
void RVIBoardTools::on_trigSouceCombo_currentIndexChanged(int index)
{
    emit showTriggerLine(ui->trigLineCheck->isChecked(), index);
        if (board->isRunning())
    {
        stop();
        connect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
    }
 
}
 
void RVIBoardTools::fillTriggerCombo()
{
    ui->trigSouceCombo->clear();
    if (ui->channelABox->isChecked() == true)
    {
        ui->trigSouceCombo->addItem("A");
    }
    if (ui->channelBBox->isChecked() == true)
    {
        ui->trigSouceCombo->addItem("B");
    }
}
 
 
////////////////////////////
// Channel A
void RVIBoardTools::on_channelABox_toggled(bool set)
{
    emit channelAEnabled(set);
}
 
 
void RVIBoardTools::on_channelAColorButton_clicked()
{
    QColorDialog *colorChooser = new QColorDialog();
    QColor color = colorChooser->getColor(ui->channelAColorButton->palette().button().color());
    ui->channelAColorButton->setPalette(color);
    emit channelAColorChanged( color);
}
 
 
void RVIBoardTools::setChannelADiv(double div)
{
    Suffixer mod(div);
    ui->channelAZoomSpinBox->setValue(div * mod.multiplier);
    ui->channelAZoomSpinBox->setSuffix(" " + mod.suffix + tr("V/Div"));
}
 
 
void RVIBoardTools::on_channelAZoomSlider_valueChanged(int value)
{
    if (value != 0 )
    {
        ui->channelAAutoButton->setChecked(false);
        emit channelAChangeDiv(value);
 
        if (!slidersTimer->isActive())
        {
            ui->channelAZoomSlider->setValue(0);
        }
    }
}
 
 
void RVIBoardTools::on_channelAZoomSlider_sliderReleased()
{
    ui->channelAZoomSlider->setValue(0);
}
 
 
void RVIBoardTools::on_channelAAutoButton_toggled(bool checked)
{
    if (checked)
    {
        emit channelAChangeDiv(0);
    }
    else
    {
        emit channelAChangeDiv(-1);
    }
}
 
 
void RVIBoardTools::on_channelAPosSlider_valueChanged(int value)
{
    if (value != 0 )
    {
        emit channelAMove(value);
 
        if (!slidersTimer->isActive())
        {
            ui->channelAPosSlider->setValue(0);
        }
    }
}
 
void RVIBoardTools::on_channelAPosSlider_sliderReleased()
{
    ui->channelAPosSlider->setValue(0);
}
 
 
void RVIBoardTools::on_channelAResetButton_pressed()
{
    emit channelAResetPos();
}
 
 
////////////////////////////
// Channel B
void RVIBoardTools::on_channelBBox_toggled(bool set)
{
    emit channelBEnabled(set);
}
 
 
void RVIBoardTools::on_channelBColorButton_clicked()
{
    QColorDialog *colorChooser = new QColorDialog();
    QColor color = colorChooser->getColor(ui->channelBColorButton->palette().button().color());
    ui->channelBColorButton->setPalette(color);
    emit channelBColorChanged( color);
}
 
 
void RVIBoardTools::setChannelBDiv(double div)
{
    Suffixer mod(div);
    ui->channelBZoomSpinBox->setValue(div * mod.multiplier);
    ui->channelBZoomSpinBox->setSuffix(" " + mod.suffix + tr("V/Div"));
}
 
 
void RVIBoardTools::on_channelBZoomSlider_valueChanged(int value)
{
    if (value != 0 )
    {
        ui->channelBAutoButton->setChecked(false);
        emit channelBChangeDiv(value);
 
        if (!slidersTimer->isActive())
        {
            ui->channelBZoomSlider->setValue(0);
        }
    }
}
 
 
void RVIBoardTools::on_channelBZoomSlider_sliderReleased()
{
    ui->channelBPosSlider->setValue(0);
}
 
 
void RVIBoardTools::on_channelBAutoButton_toggled(bool checked)
{
    if (checked)
    {
        emit channelBChangeDiv(0);
    }
    else
    {
        emit channelBChangeDiv(-1);
    }
}
 
 
void RVIBoardTools::on_channelBPosSlider_valueChanged(int value)
{
    if (value != 0 )
    {
        emit channelBMove(value);
 
        if (!slidersTimer->isActive())
        {
            ui->channelBPosSlider->setValue(0);
        }
    }
}
 
void RVIBoardTools::on_channelBPosSlider_sliderReleased()
{
    ui->channelBPosSlider->setValue(0);
}
 
 
void RVIBoardTools::on_channelBResetButton_pressed()
{
    emit channelBResetPos();
}
 
 
 
////////////////////////////
// Time
 
void RVIBoardTools::on_timeZoomSlider_valueChanged(int value)
{
    if (value != 0 )
    {
        ui->timeAutoButton->setChecked(false);
        emit timeChangeDiv(value);
 
        if (!slidersTimer->isActive())
        {
            ui->timeZoomSlider->setValue(0);
        }
    }
}
 
 
void RVIBoardTools::on_timeAutoButton_toggled(bool checked)
{
    if (checked)
    {
        emit channelAChangeDiv(0);
    }
    else
    {
        emit channelAChangeDiv(-1);
    }
}
 
 
void RVIBoardTools::setTimeDiv(double div)
{
    Suffixer mod(div);
    ui->timeZoomSpinBox->setValue(div * mod.multiplier);
    ui->timeZoomSpinBox->setSuffix(" " + mod.suffix + tr("s/Div"));
}
 
 
void RVIBoardTools::on_bufferSpinBox_valueChanged(int value)
{
    ui->trigOffsetSlider->setMaximum(value - 1);
    ui->trigOffsetSpinBox->setMaximum(value - 1);
    ui->trigOffsetSlider->setMinimum(-value);
    ui->trigOffsetSpinBox->setMinimum(-value);
    ui->trigOffsetSpinBox->setValue(0);
 
        if (board->isRunning())
    {
        stop();
        connect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
    }
 
}
 
 
void RVIBoardTools::on_timeZoomSlider_sliderReleased()
{
    ui->timeZoomSlider->setValue(0);
}
 
 
void RVIBoardTools::on_timePosSlider_sliderReleased()
{
    ui->timePosSlider->setValue(0);
}
 
 
void RVIBoardTools::on_timePosSlider_valueChanged(int value)
{
    if (value != 0 )
    {
        emit timeMove(value);
 
        if (!slidersTimer->isActive())
        {
            ui->timePosSlider->setValue(0);
        }
    }
}
 
void RVIBoardTools::fillSampleTimeCombo()
{
    double value;
    double freq = board->getADCSampleRate();
    for (int i = 0; i <= pow(2.0,SCALE_BITS); i++)
    {
        value = pow(2.0,i)/freq;
        if( value < 1e-3 )
            ui->sampleTimeCombo->addItem(QString("%L1 ns").arg(value*1e6));
        else if(value < 1)
            ui->sampleTimeCombo->addItem(QString("%L1 ms").arg(value*1e3));
        else
            ui->sampleTimeCombo->addItem(QString("%L1 s").arg(value));
    }
}
////////////////////////////
// Common
 
void  RVIBoardTools::updateSlidersValues()
{
    on_channelAZoomSlider_valueChanged(ui->channelAZoomSlider->value());
    on_channelAPosSlider_valueChanged(ui->channelAPosSlider->value());
    on_channelBZoomSlider_valueChanged(ui->channelAZoomSlider->value());
    on_channelBPosSlider_valueChanged(ui->channelAPosSlider->value());
    on_timeZoomSlider_valueChanged(ui->timeZoomSlider->value());
    on_timePosSlider_valueChanged(ui->timePosSlider->value());
}
 
 
 
void RVIBoardTools::on_runButton_toggled(bool checked)
{
    if (checked == true)
    {
        ui->runButton->setText(tr("Stop"));
        ui->singleButton->setEnabled(false);
        startAcquisition(true); // start continuous
    }
    else
    {
        ui->runButton->setText(tr("Start"));
        ui->singleButton->setEnabled(true);
        stop();
    }
}
 
 
void RVIBoardTools::on_singleButton_toggled(bool checked)
{
    if (checked == true)
    {
        ui->singleButton->setText(tr("Stop"));
        ui->runButton->setEnabled(false);
        startAcquisition(false); // start single
    }
    else
    {
        ui->singleButton->setText(tr("Single"));
        ui->runButton->setEnabled(true);
        stop();
    }
}
 
 
 
 
void RVIBoardTools::on_adcSampleButton_clicked()
{
     bool ok;
     QStringList items;
     int index;
 
    for (int i = 1; i <= pow(2.0, ADC_PS_BITS); i++)
    {
        items << tr("%1 Hz").arg(BASE_SAMPLE_RATE/i);
    }
 
     QString text = QInputDialog::getItem(this, tr("Set ADC sample rate"),
                                          tr("Sample rate:"), items, 0, false, &ok);
 
    index = items.indexOf(text);
    board->setAddress(ui->addressBox->currentText().toShort(&ok, 16));
    board->setADCPreScale(index);
    board->configADC();
    fillSampleTimeCombo();
 
}
 
 
 
void RVIBoardTools::on_trigSlopeCombo_currentIndexChanged(int index)
{
    if (board->isRunning())
    {
        stop();
        connect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
    }
}
 
void RVIBoardTools::on_trigOffsetSpinBox_valueChanged(int )
{
    if (board->isRunning())
    {
        stop();
        connect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
    }
}
 
void RVIBoardTools::on_trigLevelSpinBox_valueChanged(int )
{
    if (board->isRunning())
    {
        stop();
        connect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
    }
}
 
void RVIBoardTools::on_sampleTimeCombo_currentIndexChanged(int index)
{   
    if (board->isRunning())
    {
        stop();
        connect(board, SIGNAL(finished()),this,SLOT(startAcquisition()));
    }
}
 
void RVIBoardTools::on_trigBox_toggled(bool )
{
 
}
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.