Index: trunk/BNC/bncmodel.cpp
===================================================================
--- trunk/BNC/bncmodel.cpp	(revision 2779)
+++ trunk/BNC/bncmodel.cpp	(revision 2780)
@@ -57,7 +57,13 @@
 const double   MINELE_GPS       = 10.0 * M_PI / 180.0;
 const double   MINELE_GLO       = 10.0 * M_PI / 180.0;
+const double   MINELE_GAL       = 10.0 * M_PI / 180.0;
 const double   MAXRES_CODE_GPS  = 10.0;
 const double   MAXRES_PHASE_GPS = 0.10;
 const double   MAXRES_PHASE_GLO = 0.05;
+const double   MAXRES_CODE_GAL  = 9999.0;
+const double   MAXRES_PHASE_GAL = 9999.10;
+
+const double   _sigP3_gal = 9999.0;
+const double   _sigL3_gal = 9999.0;
 
 // Constructor
@@ -195,4 +201,6 @@
     _useGlonass = false;
   }
+
+  _useGalileo = true; // TODO
 
   int nextPar = 0;
@@ -332,4 +340,28 @@
       delete satData;
       iGlo.remove();
+    }
+  }
+
+  QMutableMapIterator<QString, t_satData*> iGal(epoData->satDataGal);
+  while (iGal.hasNext()) {
+    iGal.next();
+    QString    prn     = iGal.key();
+    t_satData* satData = iGal.value();
+
+    ColumnVector rr = satData->xx - _xcBanc.Rows(1,3);
+    double       rho = rr.norm_Frobenius();
+
+    double neu[3];
+    xyz2neu(_ellBanc.data(), rr.data(), neu);
+
+    satData->eleSat = acos( sqrt(neu[0]*neu[0] + neu[1]*neu[1]) / rho );
+    if (neu[2] < 0) {
+      satData->eleSat *= -1.0;
+    }
+    satData->azSat  = atan2(neu[1], neu[0]);
+
+    if (satData->eleSat < MINELE_GAL) {
+      delete satData;
+      iGal.remove();
     }
   }
@@ -514,5 +546,6 @@
       if (par->type == bncParam::AMB_L3) {
         if (epoData->satDataGPS.find(par->prn) == epoData->satDataGPS.end() &&
-            epoData->satDataGlo.find(par->prn) == epoData->satDataGlo.end() ) {
+            epoData->satDataGlo.find(par->prn) == epoData->satDataGlo.end() && 
+            epoData->satDataGal.find(par->prn) == epoData->satDataGal.end() ) {
           removed = true;
           delete par;
@@ -567,4 +600,24 @@
       }
     }
+
+    QMapIterator<QString, t_satData*> iGal(epoData->satDataGal);
+    while (iGal.hasNext()) {
+      iGal.next();
+      QString prn        = iGal.key();
+      t_satData* satData = iGal.value();
+      bool    found = false;
+      for (int iPar = 1; iPar <= _params.size(); iPar++) {
+        if (_params[iPar-1]->type == bncParam::AMB_L3 && 
+            _params[iPar-1]->prn == prn) {
+          found = true;
+          break;
+        }
+      }
+      if (!found) {
+        bncParam* par = new bncParam(bncParam::AMB_L3, _params.size()+1, prn);
+        _params.push_back(par);
+        par->xx = satData->L3 - cmpValue(satData, true);
+      }
+    }
     
     int nPar = _params.size();
@@ -631,8 +684,8 @@
     unsigned nObs = 0;
     if (_usePhase) {
-      nObs = 2 * epoData->sizeGPS() + epoData->sizeGlo();
+      nObs = 2 * (epoData->sizeGPS() + epoData->sizeGal()) + epoData->sizeGlo();
     }
     else {
-      nObs = epoData->sizeGPS();  // Glonass pseudoranges are not used
+      nObs = epoData->sizeGPS() + epoData->sizeGal(); // Glonass code not used
     }
     
@@ -700,4 +753,33 @@
     }
 
+    // Galileo code and (optionally) phase observations
+    // ------------------------------------------------
+    QMapIterator<QString, t_satData*> itGal(epoData->satDataGal);
+    while (itGal.hasNext()) {
+      ++iObs;
+      itGal.next();
+      QString    prn     = itGal.key();
+      t_satData* satData = itGal.value();
+    
+      ll(iObs)      = satData->P3 - cmpValue(satData, false);
+      PP(iObs,iObs) = 1.0 / (_sigP3_gal * _sigP3_gal);
+      for (int iPar = 1; iPar <= _params.size(); iPar++) {
+        AA(iObs, iPar) = _params[iPar-1]->partial(satData, false);
+      }
+    
+      if (_usePhase) {
+        ++iObs;
+        ll(iObs)      = satData->L3 - cmpValue(satData, true);
+        PP(iObs,iObs) = 1.0 / (_sigL3_gal * _sigL3_gal);
+        for (int iPar = 1; iPar <= _params.size(); iPar++) {
+          if (_params[iPar-1]->type == bncParam::AMB_L3 &&
+              _params[iPar-1]->prn  == prn) {
+            ll(iObs) -= _params[iPar-1]->xx;
+          } 
+          AA(iObs, iPar) = _params[iPar-1]->partial(satData, true);
+        }
+      }
+    }
+
     // Compute Filter Update
     // ---------------------
@@ -713,4 +795,6 @@
     ColumnVector vv_phase(epoData->sizeGPS());
     ColumnVector vv_glo(epoData->sizeGlo());
+    ColumnVector vv_gal_code(epoData->sizeGal());
+    ColumnVector vv_gal_phase(epoData->sizeGal());
 
     for (unsigned iobs = 1; iobs <= epoData->sizeGPS(); ++iobs) {
@@ -728,4 +812,15 @@
       }
     }
+    if (_useGalileo) {
+      for (unsigned iobs = 1; iobs <= epoData->sizeGal(); ++iobs) {
+        if (_usePhase) {
+          vv_gal_code(iobs)  = vv(2*iobs-1);
+          vv_gal_phase(iobs) = vv(2*iobs);
+        }
+        else {
+          vv_gal_code(iobs)  = vv(iobs);
+        }
+      }
+    }
 
     strA   << "residuals code  " << setw(8) << setprecision(3) << vv_code.t(); 
@@ -736,8 +831,14 @@
       strA << "residuals glo   " << setw(8) << setprecision(3) << vv_glo.t();
     }
+    if (_useGalileo) {
+      strA   << "res Galileo P " << setw(8) << setprecision(3) << vv_gal_code.t(); 
+      if (_usePhase) {
+        strA << "res Galileo C " << setw(8) << setprecision(3) << vv_gal_phase.t();
+      }
+    }
     _log += strA.str().c_str();
 
   } while (outlierDetection(QQsav, vv, epoData->satDataGPS, 
-                            epoData->satDataGlo) != 0);
+                            epoData->satDataGlo, epoData->satDataGal) != 0);
 
   // Remember the Epoch-specific Results for the computation of means
@@ -974,12 +1075,17 @@
                                const ColumnVector& vv,
                                QMap<QString, t_satData*>& satDataGPS,
-                               QMap<QString, t_satData*>& satDataGlo) {
+                               QMap<QString, t_satData*>& satDataGlo,
+                               QMap<QString, t_satData*>& satDataGal) {
 
   double vvMaxCodeGPS  = 0.0;
   double vvMaxPhaseGPS = 0.0;
   double vvMaxPhaseGlo = 0.0;
+  double vvMaxCodeGal  = 0.0;
+  double vvMaxPhaseGal = 0.0;
   QMutableMapIterator<QString, t_satData*> itMaxCodeGPS(satDataGPS);
   QMutableMapIterator<QString, t_satData*> itMaxPhaseGPS(satDataGPS);
   QMutableMapIterator<QString, t_satData*> itMaxPhaseGlo(satDataGlo);
+  QMutableMapIterator<QString, t_satData*> itMaxCodeGal(satDataGPS);
+  QMutableMapIterator<QString, t_satData*> itMaxPhaseGal(satDataGPS);
 
   int ii = 0;
@@ -1020,4 +1126,25 @@
   }
 
+  // Galileo code and (optionally) phase residuals
+  // ---------------------------------------------
+  QMutableMapIterator<QString, t_satData*> itGal(satDataGal);
+  while (itGal.hasNext()) {
+    itGal.next();
+    ++ii;
+
+    if (vvMaxCodeGal == 0.0 || fabs(vv(ii)) > vvMaxCodeGal) {
+      vvMaxCodeGal    = fabs(vv(ii));
+      itMaxCodeGal = itGal;
+    }
+
+    if (_usePhase) {
+      ++ii;
+      if (vvMaxPhaseGal == 0.0 || fabs(vv(ii)) > vvMaxPhaseGal) {
+        vvMaxPhaseGal    = fabs(vv(ii));
+        itMaxPhaseGal = itGal;
+      }
+    }
+  }
+ 
   if (vvMaxPhaseGlo > MAXRES_PHASE_GLO) {
     QString    prn     = itMaxPhaseGlo.key();
@@ -1054,4 +1181,29 @@
     _log += "Outlier Phase " + prn.toAscii() + " " 
           + QByteArray::number(vvMaxPhaseGPS, 'f', 3)  + "\n";
+
+    return 1;
+  }
+
+  else if (vvMaxCodeGal > MAXRES_CODE_GAL) {
+    QString    prn     = itMaxCodeGal.key();
+    t_satData* satData = itMaxCodeGal.value();
+    delete satData;
+    itMaxCodeGal.remove();
+    _QQ = QQsav;
+
+    _log += "Outlier Code " + prn.toAscii() + " " 
+            + QByteArray::number(vvMaxCodeGal, 'f', 3) + "\n";
+
+    return 1;
+  }
+  else if (vvMaxPhaseGal > MAXRES_PHASE_GAL) {
+    QString    prn     = itMaxPhaseGal.key();
+    t_satData* satData = itMaxPhaseGal.value();
+    delete satData;
+    itMaxPhaseGal.remove();
+    _QQ = QQsav;
+
+    _log += "Outlier Phase " + prn.toAscii() + " " 
+          + QByteArray::number(vvMaxPhaseGal, 'f', 3)  + "\n";
 
     return 1;
Index: trunk/BNC/bncmodel.h
===================================================================
--- trunk/BNC/bncmodel.h	(revision 2779)
+++ trunk/BNC/bncmodel.h	(revision 2780)
@@ -85,5 +85,6 @@
                           const ColumnVector& vv,
                           QMap<QString, t_satData*>& satDataGPS,
-                          QMap<QString, t_satData*>& satDataGlo);
+                          QMap<QString, t_satData*>& satDataGlo,
+                          QMap<QString, t_satData*>& satDataGal);
   void writeNMEAstr(const QString& nmStr);
 
@@ -120,4 +121,5 @@
   QTextStream*          _nmeaStream;
   bool                  _useGlonass;
+  bool                  _useGalileo;
   QMap<QString, double> _windUpTime;
   QMap<QString, double> _windUpSum;
