Changeset 1308 for trunk/src


Ignore:
Timestamp:
12/14/06 11:17:33 (18 years ago)
Author:
mar637
Message:

re-enabled the scantable binary operators

Location:
trunk/src
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/STMath.cpp

    r1259 r1308  
    281281                                              bool tsys )
    282282{
    283   // modes are "ADD" and "MUL"
    284283  CountedPtr< Scantable > out = getScantable(in, false);
    285284  Table& tab = out->table();
     
    291290    specCol.get(i, spec);
    292291    tsysCol.get(i, ts);
    293     if (mode == "MUL") {
     292    if (mode == "MUL" || mode == "DIV") {
     293      if (mode == "DIV") val = 1.0/val;
    294294      spec *= val;
    295295      specCol.put(i, spec);
     
    298298        tsysCol.put(i, ts);
    299299      }
    300     } else if ( mode == "ADD" ) {
     300    } else if ( mode == "ADD"  || mode == "SUB") {
     301      if (mode == "SUB") val *= -1.0;
    301302      spec += val;
    302303      specCol.put(i, spec);
     
    309310  return out;
    310311}
     312
     313CountedPtr<Scantable> STMath::binaryOperate(const CountedPtr<Scantable>& left,
     314                                            const CountedPtr<Scantable>& right,
     315                                            const std::string& mode)
     316{
     317  bool insitu = insitu_;
     318  if ( ! left->conformant(*right) ) {
     319    throw(AipsError("'left' and 'right' scantables are not conformant."));
     320  }
     321  setInsitu(false);
     322  CountedPtr< Scantable > out = getScantable(left, false);
     323  setInsitu(insitu);
     324  Table& tout = out->table();
     325  Block<String> coln(5);
     326  coln[0] = "SCANNO";  coln[1] = "CYCLENO";  coln[2] = "BEAMNO";
     327  coln[3] = "IFNO";  coln[4] = "POLNO";
     328  Table tmpl = tout.sort(coln);
     329  Table tmpr = right->table().sort(coln);
     330  ArrayColumn<Float> lspecCol(tmpl,"SPECTRA");
     331  ROArrayColumn<Float> rspecCol(tmpr,"SPECTRA");
     332  ArrayColumn<uChar> lflagCol(tmpl,"FLAGTRA");
     333  ROArrayColumn<uChar> rflagCol(tmpr,"FLAGTRA");
     334
     335  for (uInt i=0; i<tout.nrow(); ++i) {
     336    Vector<Float> lspecvec, rspecvec;
     337    Vector<uChar> lflagvec, rflagvec;
     338    lspecvec = lspecCol(i);    rspecvec = rspecCol(i);
     339    lflagvec = lflagCol(i);    rflagvec = rflagCol(i);
     340    MaskedArray<Float> mleft = maskedArray(lspecvec, lflagvec);
     341    MaskedArray<Float> mright = maskedArray(rspecvec, rflagvec);
     342    if (mode == "ADD") {
     343      mleft += mright;
     344    } else if ( mode == "SUB") {
     345      mleft -= mright;
     346    } else if ( mode == "MUL") {
     347      mleft *= mright;
     348    } else if ( mode == "DIV") {
     349      mleft /= mright;
     350    } else {
     351      throw(AipsError("Illegal binary operator"));
     352    }
     353    lspecCol.put(i, mleft.getArray());
     354  }
     355  return out;
     356}
     357
     358
    311359
    312360MaskedArray<Float> STMath::maskedArray( const Vector<Float>& s,
  • trunk/src/STMath.h

    r1295 r1308  
    119119                  const std::string& mode, bool tsys=false );
    120120
     121  casa::CountedPtr<Scantable>
     122    binaryOperate( const casa::CountedPtr<Scantable>& left,
     123                   const casa::CountedPtr<Scantable>& right,
     124                   const std::string& mode);
     125
    121126  casa::CountedPtr<Scantable> autoQuotient(const casa::CountedPtr<Scantable>& in,
    122127                                           const std::string& mode = "NEAREST",
  • trunk/src/STMathWrapper.h

    r1200 r1308  
    7272                  const std::string& mode, bool tsys=false )
    7373  { return ScantableWrapper(STMath::unaryOperate(in.getCP(), val, mode, tsys)); }
     74
     75  ScantableWrapper binaryOperate( const ScantableWrapper& left,
     76                                  const ScantableWrapper& right,
     77                                  const std::string& mode)
     78  { return ScantableWrapper( STMath::binaryOperate( left.getCP(), right.getCP(),
     79                                                    mode ) ); }
     80
    7481
    7582  ScantableWrapper autoQuotient( const ScantableWrapper& in,
  • trunk/src/python_STMath.cpp

    r1192 r1308  
    4949        .def("_averagebeams", &STMathWrapper::averageBeams)
    5050        .def("_unaryop", &STMathWrapper::unaryOperate)
     51        .def("_binaryop", &STMathWrapper::binaryOperate)
    5152        .def("_auto_quotient", &STMathWrapper::autoQuotient)
    5253        .def("_quotient", &STMathWrapper::quotient)
Note: See TracChangeset for help on using the changeset viewer.