1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2025-01-22 23:17:03 +00:00

Removed namespace arma in PVT. Now Armadillo is called using arma::xxxx

git-svn-id: https://svn.code.sf.net/p/gnss-sdr/code/trunk@83 64b25241-fba3-4117-9849-534c7e92360d
This commit is contained in:
Javier Arribas 2011-11-28 10:52:52 +00:00
parent 40754e6256
commit 57f7a128a5
2 changed files with 27 additions and 27 deletions

View File

@ -42,7 +42,7 @@
#include "armadillo" #include "armadillo"
using namespace arma; //using namespace arma;
#include "gps_l1_ca_ls_pvt.h" #include "gps_l1_ca_ls_pvt.h"
@ -58,7 +58,7 @@ gps_l1_ca_ls_pvt::~gps_l1_ca_ls_pvt()
delete d_ephemeris; delete d_ephemeris;
} }
vec gps_l1_ca_ls_pvt::e_r_corr(double traveltime, vec X_sat) { arma::vec gps_l1_ca_ls_pvt::e_r_corr(double traveltime, arma::vec X_sat) {
/* /*
%E_R_CORR Returns rotated satellite ECEF coordinates due to Earth %E_R_CORR Returns rotated satellite ECEF coordinates due to Earth
%rotation during signal travel time %rotation during signal travel time
@ -80,7 +80,7 @@ vec gps_l1_ca_ls_pvt::e_r_corr(double traveltime, vec X_sat) {
omegatau = Omegae_dot * traveltime; omegatau = Omegae_dot * traveltime;
//--- Make a rotation matrix ----------------------------------------------- //--- Make a rotation matrix -----------------------------------------------
mat R3=zeros(3,3); arma::mat R3=arma::zeros(3,3);
R3(0, 0)= cos(omegatau); R3(0, 0)= cos(omegatau);
R3(0, 1)= sin(omegatau); R3(0, 1)= sin(omegatau);
R3(0, 2)= 0.0; R3(0, 2)= 0.0;
@ -91,12 +91,12 @@ vec gps_l1_ca_ls_pvt::e_r_corr(double traveltime, vec X_sat) {
R3(2, 1)= 0.0; R3(2, 1)= 0.0;
R3(2, 2)= 1; R3(2, 2)= 1;
//--- Do the rotation ------------------------------------------------------ //--- Do the rotation ------------------------------------------------------
vec X_sat_rot; arma::vec X_sat_rot;
X_sat_rot = R3 * X_sat; X_sat_rot = R3 * X_sat;
return X_sat_rot; return X_sat_rot;
} }
vec gps_l1_ca_ls_pvt::leastSquarePos(mat satpos, vec obs, mat w) { arma::vec gps_l1_ca_ls_pvt::leastSquarePos(arma::mat satpos, arma::vec obs, arma::mat w) {
//Function calculates the Least Square Solution. //Function calculates the Least Square Solution.
//pos= leastSquarePos(satpos, obs, w); //pos= leastSquarePos(satpos, obs, w);
@ -125,15 +125,15 @@ vec gps_l1_ca_ls_pvt::leastSquarePos(mat satpos, vec obs, mat w) {
//nmbOfSatellites = satpos.cols(); //ITPP //nmbOfSatellites = satpos.cols(); //ITPP
nmbOfSatellites = satpos.n_cols; //Armadillo nmbOfSatellites = satpos.n_cols; //Armadillo
vec pos = "0.0 0.0 0.0 0.0"; arma::vec pos = "0.0 0.0 0.0 0.0";
mat A; arma::mat A;
mat omc; arma::mat omc;
mat az; arma::mat az;
mat el; arma::mat el;
A=zeros(nmbOfSatellites,4); A=arma::zeros(nmbOfSatellites,4);
omc=zeros(nmbOfSatellites,1); omc=arma::zeros(nmbOfSatellites,1);
az=zeros(1,nmbOfSatellites); az=arma::zeros(1,nmbOfSatellites);
el=zeros(1,nmbOfSatellites); el=arma::zeros(1,nmbOfSatellites);
for (int i = 0; i < nmbOfSatellites; i++) { for (int i = 0; i < nmbOfSatellites; i++) {
for (int j = 0; j < 4; j++) { for (int j = 0; j < 4; j++) {
//A.set(i, j, 0.0); //ITPP //A.set(i, j, 0.0); //ITPP
@ -144,13 +144,13 @@ vec gps_l1_ca_ls_pvt::leastSquarePos(mat satpos, vec obs, mat w) {
} }
el = az; el = az;
mat X = satpos; arma::mat X = satpos;
vec Rot_X; arma::vec Rot_X;
double rho2; double rho2;
double traveltime; double traveltime;
double trop; double trop;
mat mat_tmp; arma::mat mat_tmp;
vec x; arma::vec x;
//=== Iteratively find receiver position =================================== //=== Iteratively find receiver position ===================================
for (int iter = 0; iter < nmbOfIterations; iter++) { for (int iter = 0; iter < nmbOfIterations; iter++) {
for (int i = 0; i < nmbOfSatellites; i++) { for (int i = 0; i < nmbOfSatellites; i++) {
@ -196,7 +196,7 @@ vec gps_l1_ca_ls_pvt::leastSquarePos(mat satpos, vec obs, mat w) {
//--- Find position update --------------------------------------------- //--- Find position update ---------------------------------------------
// x = ls_solve_od(w*A,w*omc); // ITPP // x = ls_solve_od(w*A,w*omc); // ITPP
x = solve(w*A,w*omc); // Armadillo x = arma::solve(w*A,w*omc); // Armadillo
//--- Apply position update -------------------------------------------- //--- Apply position update --------------------------------------------
pos = pos + x; pos = pos + x;
@ -214,9 +214,9 @@ void gps_l1_ca_ls_pvt::get_PVT(std::map<int,float> pseudoranges,double GPS_curre
//mat satpos=zeros(3,d_nchannels); //satellite positions matrix //mat satpos=zeros(3,d_nchannels); //satellite positions matrix
// Armadillo // Armadillo
mat W=eye(d_nchannels,d_nchannels); //channels weights matrix arma::mat W=arma::eye(d_nchannels,d_nchannels); //channels weights matrix
vec obs=zeros(d_nchannels); // pseudoranges observation vector arma::vec obs=arma::zeros(d_nchannels); // pseudoranges observation vector
mat satpos=zeros(3,d_nchannels); //satellite positions matrix arma::mat satpos=arma::zeros(3,d_nchannels); //satellite positions matrix
int valid_obs=0; //valid observations counter int valid_obs=0; //valid observations counter
for (int i=0; i<d_nchannels; i++) for (int i=0; i<d_nchannels; i++)
@ -252,7 +252,7 @@ void gps_l1_ca_ls_pvt::get_PVT(std::map<int,float> pseudoranges,double GPS_curre
std::cout<<"PVT: valid observations="<<valid_obs<<std::endl; std::cout<<"PVT: valid observations="<<valid_obs<<std::endl;
if (valid_obs>=4) if (valid_obs>=4)
{ {
vec mypos; arma::vec mypos;
mypos=leastSquarePos(satpos,obs,W); mypos=leastSquarePos(satpos,obs,W);
std::cout << "Position ("<<GPS_current_time<<") ECEF = " << mypos << std::endl; std::cout << "Position ("<<GPS_current_time<<") ECEF = " << mypos << std::endl;
cart2geo(mypos(0), mypos(1), mypos(2), 4); cart2geo(mypos(0), mypos(1), mypos(2), 4);

View File

@ -49,15 +49,15 @@
#include "armadillo" #include "armadillo"
using namespace arma; //using namespace arma;
//using namespace itpp; //using namespace itpp;
class gps_l1_ca_ls_pvt class gps_l1_ca_ls_pvt
{ {
private: private:
vec leastSquarePos(mat satpos, vec obs, mat w); arma::vec leastSquarePos(arma::mat satpos, arma::vec obs, arma::mat w);
vec e_r_corr(double traveltime, vec X_sat); arma::vec e_r_corr(double traveltime, arma::vec X_sat);
//void cart2geo(); //void cart2geo();
//void topocent(); //void topocent();
public: public: