亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? jave-ppp.txt

?? 精密單點定位程序
?? TXT
?? 第 1 頁 / 共 5 頁
字號:
      if(tsec >= allBC[prn][mxrow].gBCjts()){ return mxrow; }  //*** last row

//*** increment until upper point passes the given time

      for(int i=1; i<=mxrow-1; ++i) {
         if(allBC[prn][i+1].gBCjts() >= tsec){
            if(Math.abs(tsec-allBC[prn][i  ].gBCjts())  < 
               Math.abs(tsec-allBC[prn][i+1].gBCjts()))  { return i; }
            else                                         { return i+1; }
         }
      }

//*** fell thru loop -- not allowed

      System.err.println("Loop prob in locBC() " + prn + "  " + tsec);
      System.exit(1);
      return -1;
   }
}
//************************************************************************
class BCstuf {

//*** broadcast orbit object

   private static final double gm    =  3.986005e14;
   private static final double we    =  7.2921151467e-5;        //*** rad/sec
   private static final double gpspi =  3.1415926535898e0;
   private static final double bigf  = -4.442807633e-10;

   private int    id;         //*  my id (just a serial number)
   private double jts;        //*  my time for lookup index
   private int    prn;        //*  prn id

//*** clock parameters

   private double t0c;     //*  clock corrector reference epoch            (s)
   private double af0;     //*  clock offset                               (s)
   private double af1;     //*  clock error rate                          (s/s)
   private double af2;     //*  clock error accelleration              (s/(s*s))

//*** kepler elements

   private double t0e;     //*  reference epoch of ephemeris             (sow)
   private double sqrta;   //*  square root of semimajor axis           sqrt(m)
   private double e;       //*  eccentricity
   private double eye0;    //*  inclination at ref. epoch                  (r)
   private double omg0;    //*  right ascension of asc. node at ref. epoch (r)
   private double w;       //*  argument of perigee                        (r)
   private double em0;     //*  mean anomaly at ref. epoch                 (r)

//*** perturbation parameters

   private double deln;    //*  mean motion difference from computed value (r/s)
   private double eyedot;  //*  rate of change of inclination              (r/s)
   private double omgdot;  //*  rate of change of right ascension          (r/s)

   private double cuc;     //*  cosine harmonic correction to arg. of lat. (r)
   private double cus;     //*  sine harmonic correction to arg. of lat.   (r)
   private double crc;     //*  cosine harmonic correction to radius       (m)
   private double crs;     //*  sine harmonic correction to radius         (m)
   private double cic;     //*  cosine harmonic correction to inclination  (r)
   private double cis;     //*  sine harmonic correction to inclination    (r)

//*** other data 

   private double iode;    //*  issue of data ephemeris
   private double l2cd;    //*  codes on l2 channel (binary, 01-p, 10-c/a)
   private double wkno;    //*  gps week # (to go with toe)               (wk)
   private double l2pd;    //*  l2 p data flag (binary, 0-norm, 1-set off)
   private double svac;    //*  URA index (converted)                      (m)
   private double svhl;    //*  sv health    (6 bits, 0-ok, 1-not)
   private double tgd;     //*  est. group delay   (tsv-tgd)               (s)
   private double iodc;    //*  issue of data clock
   private double tot;     //*  transmission time of message             (sow)

//*****
//***** methods
//*****

   public BCstuf(int myid)   {id=myid;}
   public int    getBC()    {return id;}
   public double gBCjts()   {return jts;}
   public String toString() {return "" + id;}

   public int    gBCprn()   {return prn;}
   public double gBCt0c()   {return t0c;}
   public double gBCt0e()   {return t0e;}
   public double gBCwkno()  {return wkno;}
   public double gBCsvac()  {return svac;}
   public double gBCsvhl()  {return svhl;}
   public double gBCtot()   {return tot;}

//*****
//***** load methods
//*****

   public void put0BC(String myString, int myid, Gtime tStuf) {

//*** load record (epoch and clock)
//*** y2k code fails after 2079

//*** clock parameters

      String subField;
      int     iyr,imo,idy,ihr,imn;
      double  sec,tsec;

      subField = myString.substring( 0,  2);
      prn      = Integer.parseInt(subField.trim());

      subField = myString.substring( 2,  5);
      iyr      = Integer.parseInt(subField.trim());
      if     (iyr <  80) {iyr=iyr+2000;}               //*** y2k
      else if(iyr <= 99) {iyr=iyr+1900;}               //*** fail 2080

      subField = myString.substring( 5,  8);
      imo      = Integer.parseInt(subField.trim());
      subField = myString.substring( 8, 11);
      idy      = Integer.parseInt(subField.trim());
      subField = myString.substring(11, 14);
      ihr      = Integer.parseInt(subField.trim());
      subField = myString.substring(14, 17);
      imn      = Integer.parseInt(subField.trim());
      subField = myString.substring(17, 22);
      sec      = Double.valueOf(subField.trim()).doubleValue();

//*** if first epoch, check to establish time offset

      if(myid <= 1){
         if(tStuf.getMjd0() <= -1){
            System.err.println("Time was set in nav file -- check obs file");
            tStuf.setjd0(iyr, imo, idy);
         }
      }

      jts = tStuf.civjts(iyr,imo,idy,ihr,imn,sec);   //*** also used for index
      t0c = tStuf.jtssow(jts);

      subField = myString.substring(22, 41).replace('D','e');
      af0      = Double.valueOf(subField.trim()).doubleValue();
      subField = myString.substring(41, 60).replace('D','e');
      af1      = Double.valueOf(subField.trim()).doubleValue();
      subField = myString.substring(60, 79).replace('D','e');
      af2      = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put1BC(String myString) {

//*** load record (BC Orbit 1)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
      iode     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(22, 41).replace('D','e');
      crs      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(41, 60).replace('D','e');
      deln     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(60, 79).replace('D','e');
      em0      = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put2BC(String myString) {

//*** load record (BC Orbit 2)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
      cuc      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(22, 41).replace('D','e');
      e        = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(41, 60).replace('D','e');
      cus      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(60, 79).replace('D','e');
      sqrta    = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put3BC(String myString) {

//*** load record (BC Orbit 3)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
      t0e      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(22, 41).replace('D','e');
      cic      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(41, 60).replace('D','e');
      omg0     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(60, 79).replace('D','e');
      cis      = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put4BC(String myString) {

//*** load record (BC Orbit 4)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
      eye0     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(22, 41).replace('D','e');
      crc      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(41, 60).replace('D','e');
      w        = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(60, 79).replace('D','e');
      omgdot   = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put5BC(String myString) {

//*** load record (BC Orbit 5)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
      eyedot   = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(22, 41).replace('D','e');
      l2cd     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(41, 60).replace('D','e');
      wkno     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(60, 79).replace('D','e');
      l2pd    = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put6BC(String myString) {

//*** load record (BC Orbit 6)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
//*** troublesome field in gait nav file
   try {
      svac     = Double.valueOf(subField.trim()).doubleValue();
   } 
   catch (NumberFormatException e) {
//****System.err.println("Reset acc. for " + subField.trim());
      svac = 384.0;
   }

      subField = myString.substring(22, 41).replace('D','e');
      svhl     = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(41, 60).replace('D','e');
      tgd      = Double.valueOf(subField.trim()).doubleValue();

      subField = myString.substring(60, 79).replace('D','e');
      iodc     = Double.valueOf(subField.trim()).doubleValue();
   }

   public void put7BC(String myString) {

//*** load record (BC Orbit 7)

      String subField;

      subField = myString.substring( 3, 22).replace('D','e');
      tot      = Double.valueOf(subField.trim()).doubleValue();
   }

//*****
//***** compute methods
//*****

   public PosT bcxyzt (double tsv, Modes myModes) {
      
//*** compute pos of broadcast orbit (BC) for a single time

//*** sense of the corrector (with relativity) is:   t=tsv-dt-dtr
//*** BC is in GPS system time (use clock corr, time in sec.of.week)

      double dt, dtr, bcclok;

//*** correct satellite time

      dt     = bcclok1(tsv);                       //*** icd-200 20.3.3.3.3.1
      dtr    = bcclok2(tsv,dt);
      bcclok = dt+dtr;

//*** icd-200 20.3.3.3.3.2  (not dual and not b-cast iono)

      if( (!myModes.isdFreq()) && (!myModes.isbIon())) bcclok = bcclok - tgd;

//*** compute broadcast position at corrected time

      return bcxyz(tsv-bcclok, bcclok, dtr);
   }

   public double bcclok1 (double t) {
      
//*** compute satellite clock correction (non-relativity term)
//*** sense of the corrector is:   t=tsv-dt

      double        dt;

      if( (t-t0c) > 302400.0 ) t=t-604800.0;        //*** handle week rollover
      if( (t-t0c) <-302400.0 ) t=t+604800.0;        //*** valid icd200

      dt=af0+af1*(t-t0c)+af2*(t-t0c)*(t-t0c);       //*** valid icd200
      return dt;
   }

   public double bcclok2 (double t, double dt) {
      
//*** compute satellite clock correction (relativity term)
//*** sense of the corrector is:   t=tsv-dt-dtr

      double dtr;       //*** relativity term
      double ek;

      if( (t-t0c) > 302400.0 ) t=t-604800.0;        //*** handle week rollover
      if( (t-t0c) <-302400.0 ) t=t+604800.0;        //*** valid icd200
      
//*** relativity term

      ek=eccano(t-dt);
      dtr=bigf*e*sqrta*Math.sin(ek);           //*** valid icd200
      return dtr;
   }

   public PosT bcxyz(double t, double bcclok, double dtr) {

//*** compute ECBF XYZ at time t from broadcast elements
//***               units: seconds, meters, radians
//*** note: t corrected for SV clock error, also passed in bcclok
//*** note: also passing relativitistic correction

      double a,en0,tk,en,emk,ek,sinek,cosek,f,u,cu2,su2,duk,drk,dik;
      double uk,rk,eyek,ceyek,xpk,ypk,omgk,comgk,somgk,xk,yk,zk;

      if( (t-t0e) > 302400.0 ) t=t-604800.0;            //*** handle week rollover
      if( (t-t0e) <-302400.0 ) t=t+604800.0;            //*** valid icd200

//*** mean motion

      a   = sqrta*sqrta;
      en0 = Math.sqrt(gm/(a*a*a));

//*** time since orbit reference epoch

      tk = t-t0e;

//*** corrected mean motion

      en = en0+deln;

//*** mean anomaly, M

      emk = em0+en*tk;

//*** solve kepler's equation for eccentric anomaly, E

      ek    = kepEQ(emk);
      sinek = Math.sin(ek);
      cosek = Math.cos(ek);

//*** true anomaly, f

      f = Math.atan2( Math.sqrt(1.0-e*e)*sinek, cosek-e);

//*** argument of latitude, u

      u   = f+w;
      cu2 = Math.cos(u+u);
      su2 = Math.sin(u+u);

//*** corrections to the arg. of lat., radius, and inclination

      duk = cuc*cu2+cus*su2;
      drk = crc*cu2+crs*su2;
      dik = cic*cu2+cis*su2;

//*** correct the arg. of lat., radius, and inclination

      uk    = u               + duk;
      rk    = a*(1.0-e*cosek) + drk;
      eyek  = eye0+eyedot*tk  + dik;
      ceyek = Math.cos(eyek);

//*** position in the orbital plane

      xpk = rk*Math.cos(uk);
      ypk = rk*Math.sin(uk);

//*** correct the longitude of the ascending node

      omgk  = omg0+(omgdot-we)*tk-we*t0e;
      comgk = Math.cos(omgk);
      somgk = Math.sin(omgk);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩久久久久久| 一级精品视频在线观看宜春院 | 亚洲成人动漫在线免费观看| 粉嫩久久99精品久久久久久夜| 4438x亚洲最大成人网| 亚洲视频小说图片| 成人av电影在线播放| 久久久久久亚洲综合影院红桃| 麻豆精品精品国产自在97香蕉| 成人性视频免费网站| 久久久久久97三级| 国内精品久久久久影院色| 精品国产三级a在线观看| 自拍偷拍亚洲欧美日韩| 国产综合成人久久大片91| 欧美成人综合网站| 麻豆成人av在线| 精品视频一区二区三区免费| 亚洲一区二区视频| 欧美视频一区二区三区四区| 亚洲午夜免费视频| 日本高清不卡在线观看| 亚洲综合成人网| 欧美日韩国产高清一区二区三区 | 欧美一区二区视频免费观看| 亚洲不卡av一区二区三区| 91麻豆高清视频| 亚洲男帅同性gay1069| 欧美色爱综合网| 日本不卡一区二区三区高清视频| 777奇米四色成人影色区| 日韩国产一区二| 欧美成人女星排名| 国产风韵犹存在线视精品| 国产精品久久久久精k8| 日本久久一区二区| 视频在线在亚洲| 久久噜噜亚洲综合| 成人黄色在线网站| 亚洲一区二区三区爽爽爽爽爽| 欧美日韩精品电影| 久久国产精品72免费观看| 国产午夜精品美女毛片视频| 99久久国产免费看| 男人的天堂亚洲一区| 久久久国产午夜精品| 国产精品资源网站| 自拍av一区二区三区| 欧美精品国产精品| 天堂蜜桃91精品| 久久人人超碰精品| 欧美在线不卡一区| 久久99深爱久久99精品| 最新成人av在线| 91精品国产综合久久精品app | 色婷婷久久久综合中文字幕 | 国产制服丝袜一区| 亚洲人成小说网站色在线| 91精品黄色片免费大全| 不卡的电影网站| 日本伊人色综合网| 一区在线观看免费| 欧美成人video| 高清不卡在线观看| 丝袜亚洲另类欧美| 最新国产の精品合集bt伙计| 精品国产免费人成电影在线观看四季| 久久精品国产精品青草| 亚洲色图欧洲色图| 欧美激情在线一区二区三区| 成人深夜在线观看| 麻豆91精品视频| 亚洲久本草在线中文字幕| 久久久久久久久久久久久久久99 | 日韩精品一区第一页| 久久一区二区三区四区| 欧美图片一区二区三区| 成人综合在线网站| 成人免费观看视频| 成人免费视频网站在线观看| 久久狠狠亚洲综合| 日本人妖一区二区| 免费在线观看成人| 日本特黄久久久高潮| 毛片av中文字幕一区二区| 日韩1区2区日韩1区2区| 日韩黄色在线观看| 三级欧美韩日大片在线看| 亚洲成av人片在线观看| 亚洲电影在线免费观看| 亚洲综合色自拍一区| 亚洲已满18点击进入久久| 洋洋成人永久网站入口| 亚洲自拍偷拍网站| 日本成人在线电影网| 麻豆视频一区二区| 激情综合五月婷婷| 国产一区二区主播在线| 国产精品1区2区| av电影天堂一区二区在线| 91丨九色丨尤物| 欧洲一区在线电影| 欧美一区二区日韩| 精品三级在线观看| 欧美激情一区在线观看| 一区二区视频在线| 亚洲成人av福利| 狠狠久久亚洲欧美| 波多野结衣精品在线| 91精彩视频在线| 日韩三级在线免费观看| 国产午夜精品久久久久久免费视| 中文字幕精品—区二区四季| 夜夜夜精品看看| 精品一区免费av| 99视频一区二区| 欧美视频中文字幕| 精品乱码亚洲一区二区不卡| 国产精品欧美一级免费| 亚洲一区二区在线免费看| 九九视频精品免费| 99久久99久久精品免费看蜜桃| 精品视频全国免费看| 久久久综合视频| 亚洲午夜免费福利视频| 国产在线播精品第三| 色综合天天性综合| 日韩一区二区在线观看| 国产精品国产精品国产专区不片| 亚洲高清视频的网址| 国产乱码精品一区二区三区忘忧草| 91在线播放网址| 日韩色在线观看| 一区二区三区蜜桃| 国产福利精品一区二区| 欧洲日韩一区二区三区| 国产网红主播福利一区二区| 亚洲综合免费观看高清完整版| 国产一区二区影院| 欧美精品一二三| 国产精品乱码妇女bbbb| 日本美女一区二区三区视频| 91小视频免费看| 久久综合色鬼综合色| 日日摸夜夜添夜夜添国产精品| 成人国产精品免费观看视频| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 久久久亚洲欧洲日产国码αv| 亚洲一区二区欧美日韩| 成人在线视频一区二区| 欧美sm极限捆绑bd| 同产精品九九九| 色狠狠综合天天综合综合| 欧美国产在线观看| 精品一区二区三区久久久| 精品视频免费看| 依依成人精品视频| proumb性欧美在线观看| 欧美精品一区二区三区蜜桃| 日本三级韩国三级欧美三级| 欧美日韩在线播放三区四区| 亚洲色图20p| 粉嫩av一区二区三区| 久久精品无码一区二区三区| 九色porny丨国产精品| 日韩欧美国产午夜精品| 五月婷婷久久综合| 678五月天丁香亚洲综合网| 夜夜爽夜夜爽精品视频| 欧美中文字幕一区| 亚洲欧美日韩小说| 色综合网站在线| 一区二区三区免费观看| 色狠狠桃花综合| 亚洲影视在线观看| 欧美艳星brazzers| 亚洲国产精品一区二区www在线| 色欧美88888久久久久久影院| 国产三级一区二区三区| 国产91露脸合集magnet| 日本一区二区视频在线| 国产98色在线|日韩| 国产精品拍天天在线| 91麻豆swag| 一区二区三区欧美| 色婷婷久久99综合精品jk白丝| 亚洲乱码国产乱码精品精的特点| 91丨九色丨尤物| 亚洲成人精品一区二区| 欧美日本乱大交xxxxx| 日韩电影免费一区| 91精品国产黑色紧身裤美女| 免费人成在线不卡| 久久婷婷成人综合色| 成人精品视频.| 亚洲男人的天堂在线aⅴ视频| 欧美在线你懂得| 久久精品av麻豆的观看方式| 久久精品免费在线观看| 99久久99久久久精品齐齐|