Changeset 17170 for trunk/FACT++/src


Ignore:
Timestamp:
09/17/13 18:41:04 (11 years ago)
Author:
tbretz
Message:
Implemented a new service providing bias patch wise temperatures; in addition the provided tempertures are filtered to remove faulty FSC reports.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/FACT++/src/fscctrl.cc

    r16961 r17170  
    1111#include "Console.h"
    1212#include "Converter.h"
     13#include "../externals/Interpolator2D.h"
    1314
    1415#include "tools.h"
     
    3435    ofstream fDumpStream;
    3536
     37
    3638protected:
     39    vector<pair<double,double>> fPositionsSensors;
     40    vector<pair<double,double>> fPositionsBias;
    3741
    3842    virtual void UpdateTemp(float, const vector<float> &)
     
    626630        fDump = b;
    627631    }
     632
     633    void SetPositionsSensors(const vector<pair<double,double>> &vec)
     634    {
     635        fPositionsSensors = vec;
     636    }
     637
     638    void SetPositionsBias(const vector<pair<double,double>> &vec)
     639    {
     640        fPositionsBias = vec;
     641    }
    628642};
    629643
     
    636650private:
    637651
     652    vector<double> fLastRms;
     653
    638654    DimDescribedService fDimTemp;
     655    DimDescribedService fDimTemp2;
    639656    DimDescribedService fDimHum;
    640657    DimDescribedService fDimVolt;
     
    650667    {
    651668        Update(fDimTemp, temp, time);
     669
     670        vector<double> T;
     671        vector<Interpolator2D::vec> xy;
     672
     673        T.reserve(31);
     674        xy.reserve(31);
     675
     676        double avg = 0;
     677        double rms = 0;
     678
     679        // Create a list of all valid sensors
     680        for (int i=0; i<31; i++)
     681            if (temp[i]!=0)
     682            {
     683                T.emplace_back(temp[i]);
     684                xy.emplace_back(fPositionsSensors[i].first, fPositionsSensors[i].second);
     685
     686                avg += temp[i];
     687                rms += temp[i]*temp[i];
     688            }
     689
     690        if (T.size()==0)
     691        {
     692            Warn("No valid sensor temperatures.");
     693            return;
     694        }
     695
     696        avg /= T.size();
     697        rms /= T.size();
     698        rms -= avg*avg;
     699        rms = rms<0 ? 0 : sqrt(rms - avg*avg);
     700
     701        // Clean broken reports
     702        const double cut_val = 0.015;
     703        const bool reject = rms>4 || (fabs(fLastRms[0]-fLastRms[1])<=cut_val && fabs(rms-fLastRms[0])>cut_val);
     704
     705        fLastRms[1] = fLastRms[0];
     706        fLastRms[0] = rms;
     707
     708        if (reject)
     709        {
     710            Warn("Suspicious temperature values rejecte for BIAS_TEMP.");
     711            return;
     712        }
     713
     714        // Create interpolator for the corresponding sensor positions
     715        Interpolator2D inter(xy);
     716
     717        // Calculate weights for the output positions
     718        if (!inter.SetOutputGrid(fPositionsBias))
     719        {
     720            Warn("Temperature values rejecte for BIAS_TEMP (calculation of weights failed).");
     721            return;
     722        }
     723
     724        // Interpolate the data
     725        T = inter.Interpolate(T);
     726
     727        // Update the Dim service with the interpolated positions
     728        Update(fDimTemp2, vector<float>(T.cbegin(), T.cend()), time);
    652729    }
    653730
     
    666743        Update(fDimCurrent, curr, time);
    667744    }
    668 
    669    
    670745
    671746public:
    672747    ConnectionDimFSC(ba::io_service& ioservice, MessageImp &imp) :
    673         ConnectionFSC(ioservice, imp),
     748        ConnectionFSC(ioservice, imp), fLastRms(2),
    674749        fDimTemp   ("FSC_CONTROL/TEMPERATURE", "F:1;F:31;F:8;F:8;F:4;F:4;F:4",
    675750                    "|t[s]:FSC uptime"
     
    680755                    "|T_back[deg C]:FTM backpanel temperatures FTM (top/bottom), FSC (top/bottom)"
    681756                    "|T_eth[deg C]:Ethernet switches temperatures top (front/back), bottom (f/b)"),
     757        fDimTemp2  ("FSC_CONTROL/BIAS_TEMP", "F:1;F:320",
     758                    "|t[s]:FSC uptime"
     759                    "|T[deg C]:Interpolated temperatures at bias patch positions"),
    682760        fDimHum    ("FSC_CONTROL/HUMIDITY", "F:1;F:4",
    683761                    "|t[s]:FSC uptime"
     
    709787                    "|FLP_I[A]:FLP - light pulser")
    710788    {
     789        fLastRms[0] = 1.5;
    711790    }
    712791
     
    824903    }
    825904
     905    vector<pair<double,double>> ReadVector(const string &filename) const
     906    {
     907        vector<pair<double,double>> vec;
     908
     909        ifstream fin(filename);
     910        while (1)
     911        {
     912            double x, y;
     913            fin >> x;
     914            fin >> y;
     915            if (!fin)
     916                break;
     917
     918            vec.emplace_back(x, y);
     919        }
     920
     921        return vec;
     922    }
     923
    826924    int EvalOptions(Configuration &conf)
    827925    {
    828926        fFSC.SetVerbose(!conf.Get<bool>("quiet"));
     927
     928        const string fname1 = conf.Get<string>("sesnor-pos-file");
     929        const auto v1 = ReadVector(fname1);
     930        if (v1.size() != 31)
     931        {
     932            Error("Reading sensor positions from "+fname1+"failed ("+to_string(v1.size())+")");
     933            return 1;
     934        }
     935
     936        const string fname2 = conf.Get<string>("patch-pos-file");
     937        const auto v2 = ReadVector(fname2);
     938        if (v2.size() != 320)
     939        {
     940            Error("Reading bias patch positions from "+fname2+"failed ("+to_string(v2.size())+")");
     941            return 1;
     942        }
     943
     944        fFSC.SetPositionsSensors(v1);
     945        fFSC.SetPositionsBias(v2);
    829946
    830947        SetEndpoint(conf.Get<string>("addr"));
     
    850967        ("no-dim",        po_bool(),  "Disable dim services")
    851968        ("addr,a",        var<string>("localhost:5000"),  "Network address of FSC")
     969        ("sensor-pos-file", var<string>()->required(),  "File with the positions of the 31 temperature sensors")
     970        ("patch-pos-file",  var<string>()->required(),  "File with the positions of the 320 bias patches")
    852971        ("quiet,q",       po_bool(true),  "Disable printing contents of all received messages (except dynamic data) in clear text.")
    853972        ;
     
    868987{
    869988    cout <<
    870         "The ftmctrl controls the FSC (FACT Slow Control) board.\n"
     989        "The fscctrl controls the FSC (FACT Slow Control) board.\n"
    871990        "\n"
    872991        "The default is that the program is started without user intercation. "
Note: See TracChangeset for help on using the changeset viewer.