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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? newran.cpp

?? 本程序用c++語(yǔ)言實(shí)現(xiàn)了wcdma系統(tǒng)當(dāng)中的信道預(yù)測(cè)算法
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
// newran.cpp -----------------------------------------------------------

// NEWRAN02

#define WANT_STREAM
#define WANT_MATH
#include "include.h"

#include "newran.h"
//#include "mother.h"

#ifdef use_namespace
namespace NEWRAN {
#endif

//********* classes which are used internally only **********************

//*********** chi-square-1 random number generator **********************

class ChiSq1 : public Normal              // generate non-central chi-square
					  // rv with 1 degree of freedom
{
   Real deltasq;                          // non-centrality parameter
   Real delta;

public:
   ChiSq1(Real);                          // non-centrality parameter
   ExtReal Mean() const { return 1.0+deltasq; }
   ExtReal Variance() const { return 2.0+4.0*deltasq; }
   Real Next();
};

//*********** Poisson random number generator, larger mu ****************

class Poisson1 : public AsymGen           // generate poisson rv, large mu
{
   Real mu, ln_mu;
public:
   Poisson1(Real);                        // constructor (Real=mean)
   Real Density(Real) const;              // Poisson density function
   Real Next() { return floor(AsymGen::Next()); }
   ExtReal Mean() const { return mu; }
   ExtReal Variance() const { return mu; }
};

//*********** Poisson random number generator, mu <= 10 ****************

class Poisson2 : public Random            // generate poisson rv, large mu
{
   DiscreteGen* dg;
public:
   Poisson2(Real);                        // constructor (Real=mean)
   ~Poisson2();
   Real Next() { return dg->Next(); }
   ExtReal Mean() const { return dg->Mean(); }
   ExtReal Variance() const { return dg->Variance(); }
};

//********** Gamma random number generator, alpha <= 1 *****************

class Gamma1 : public PosGen              // generate gamma rv
					  // shape parameter <= 1
{
   Real ln_gam, ralpha, alpha;
public:
   Gamma1(Real);                          // constructor (Real=shape)
   Real Density(Real) const;              // gamma density function
   Real Next();                           // carries out power transform
   ExtReal Mean() const { return alpha; }
   ExtReal Variance() const { return alpha; }
};

//********** Gamma random number generator, alpha > 1 ******************

class Gamma2 : public AsymGen             // generate gamma rv
					  // shape parameter > 1
{
   Real alpha, ln_gam;
public:
   Gamma2(Real);                          // constructor (Real=shape)
   Real Density(Real) const;              // gamma density function
   ExtReal Mean() const { return alpha; }
   ExtReal Variance() const { return alpha; }
};

//*********** Binomial random number generator, n > 40 *****************

class Binomial1 : public AsymGen           // generate binomial rv, larger n
{
   Real p, q, ln_p, ln_q, ln_n_fac; int n;
public:
   Binomial1(int nx, Real px);
   Real Density(Real) const;
   Real Next() { return floor(AsymGen::Next()); }
   ExtReal Mean() const { return p * n; }
   ExtReal Variance() const { return p * q * n; }
};

//******* Binomial random number generator, n < 40 or n*p <= 8 *************

class Binomial2 : public Random            // generate binomial rv, smaller n
{
   DiscreteGen* dg;
public:
   Binomial2(int nx, Real px);
   ~Binomial2();
   Real Next() { return dg->Next(); }
   ExtReal Mean() const { return dg->Mean(); }
   ExtReal Variance() const { return dg->Variance(); }
};

//************************ static variables ***************************

double Random::seed;
//unsigned long Random::iseed;                // for Mother
Real Random::Buffer[128];
Real Normal::Nxi;
Real* Normal::Nsx;
Real* Normal::Nsfx;
long Normal::count=0;

//**************************** utilities ******************************

inline Real square(Real x) { return x*x; }
inline ExtReal square(const ExtReal& x) { return x*x; }

static void ErrorNoSpace() { Throw(Bad_alloc("Newran: out of space")); }

//************************* end of definitions ************************


Real Random::Raw()                           // get new uniform random number
{
   // m = 2147483647 = 2^31 - 1; a = 16807;
   // 127773 = m div a; 2836 = m mod a
   long iseed = (long)seed;
   long hi = iseed / 127773L;                 // integer division
   long lo = iseed - hi * 127773L;            // modulo
   iseed = 16807 * lo - 2836 * hi;
   if (iseed <= 0) iseed += 2147483647L;
   seed = (double)iseed; return seed*4.656612875e-10;
}

Real Random::Density(Real) const
{ Throw(Logic_error("density function not defined")); return 0.0; }

#ifdef _MSC_VER
static void DoNothing(int) {}
#endif

Real Random::Next()                          // get new mixed random number
{
   if (!seed)
      Throw(Logic_error("Random number generator not initialised"));
   int i = (int)(Raw()*128);               // 0 <= i < 128
#ifdef _MSC_VER
   DoNothing(i); DoNothing(i);
#endif
   Real f = Buffer[i]; Buffer[i] = Raw();  // Microsoft release gets this wrong
   return f;

   // return Mother(&iseed);
}

double Random::Get()                  // get random number seed
{ return seed/2147483648L; }

void Random::Set(double s)            // set random number seed
                                      // s must be between 0 and 1
{
   if (s>=1.0 || s<=0.0)
      Throw(Logic_error("Newran: seed out of range"));
   //iseed = 2147483648L * s;         // for Mother
   seed = (long)(s*2147483648L);
   for (int i = 0; i<128; i++) Buffer[i] = Raw();
}


PosGen::PosGen()                             // Constructor
{
   #ifdef MONITOR
      cout << "constructing PosGen\n";
   #endif
   NotReady=true;
}

PosGen::~PosGen()
{
   if (!NotReady)
   {
      #ifdef MONITOR
	 cout << "freeing PosGen arrays\n";
      #endif
      delete [] sx; delete [] sfx;
   }
   #ifdef MONITOR
      cout << "destructing PosGen\n";
   #endif
}

void PosGen::Build(bool sym)                 // set up arrays
{
   #ifdef MONITOR
      cout << "building PosGen arrays\n";
   #endif
   int i;
   NotReady=false;
   sx=new Real[60]; sfx=new Real[60];
   if (!sx || !sfx) ErrorNoSpace();
   Real sxi=0.0; Real inc = sym ? 0.01 : 0.02;
   for (i=0; i<60; i++)
   {
      sx[i]=sxi; Real f1=Density(sxi); sfx[i]=f1;
      if (f1<=0.0) goto L20;
      sxi+=inc/f1;
   }
   Throw(Runtime_error("Newran: area too large"));
L20:
   if (i<50) Throw(Runtime_error("Newran: area too small"));
   xi = sym ? 2*i : i;
   return;
}

Real PosGen::Next()
{
   Real ak,y; int ir;
   if (NotReady) Build(false);
   do
   {
      Real r1=Random::Next();
      ir = (int)(r1*xi); Real sxi=sx[ir];
      ak=sxi+(sx[ir+1]-sxi)*Random::Next();
      y=sfx[ir]*Random::Next();
   }
   while ( y>=sfx[ir+1] && y>=Density(ak) );
   return ak;
}

Real SymGen::Next()
{
   Real s,ak,y; int ir;
   if (NotReady) Build(true);
   do
   {
      s=1.0;
      Real r1=Random::Next();
      if (r1>0.5) { s=-1.0; r1=1.0-r1; }
      ir = (int)(r1*xi); Real sxi=sx[ir];
      ak=sxi+(sx[ir+1]-sxi)*Random::Next();
      y=sfx[ir]*Random::Next();
   }
   while ( y>=sfx[ir+1] && y>=Density(ak) );
   return s*ak;
}

AsymGen::AsymGen(Real modex)                 // Constructor
{
   #ifdef MONITOR
      cout << "constructing AsymGen\n";
   #endif
   mode=modex; NotReady=true;
}

void AsymGen::Build()                        // set up arrays
{
   #ifdef MONITOR
      cout << "building AsymGen arrays\n";
   #endif
   int i;
   NotReady=false;
   sx=new Real[121]; sfx=new Real[121];
   if (!sx || !sfx)  ErrorNoSpace();
   Real sxi=mode;
   for (i=0; i<120; i++)
   {
      sx[i]=sxi; Real f1=Density(sxi); sfx[i]=f1;
      if (f1<=0.0) goto L20;
      sxi+=0.01/f1;
   }
   Throw(Runtime_error("Newran: area too large (a)"));
L20:
   ic=i-1; sx[120]=sxi; sfx[120]=0.0;
   sxi=mode;
   for (; i<120; i++)
   {
      sx[i]=sxi; Real f1=Density(sxi); sfx[i]=f1;
      if (f1<=0.0) goto L30;
      sxi-=0.01/f1;
   }
   Throw(Runtime_error("Newran: area too large (b)"));
L30:
   if (i<100)  Throw(Runtime_error("Newran: area too small"));
   xi=i;
   return;
}

Real AsymGen::Next()
{
   Real ak,y; int ir1;
   if (NotReady) Build();
   do
   {
      Real r1=Random::Next();
      int ir=(int)(r1*xi); Real sxi=sx[ir];
      ir1 = (ir==ic) ? 120 : ir+1;
      ak=sxi+(sx[ir1]-sxi)*Random::Next();
      y=sfx[ir]*Random::Next();
   }
   while ( y>=sfx[ir1] && y>=Density(ak) );
   return ak;
}

AsymGen::~AsymGen()
{
   if (!NotReady)
   {
      #ifdef MONITOR
	 cout << "freeing AsymGen arrays\n";
      #endif
      delete [] sx; delete [] sfx;
   }
   #ifdef MONITOR
      cout << "destructing AsymGen\n";
   #endif
}

PosGenX::PosGenX(PDF fx) { f=fx; }

SymGenX::SymGenX(PDF fx) { f=fx; }

AsymGenX::AsymGenX(PDF fx, Real mx) : AsymGen(mx) { f=fx; }


Normal::Normal()
{
   if (count) { NotReady=false; xi=Nxi; sx=Nsx; sfx=Nsfx; }
   else { Build(true); Nxi=xi; Nsx=sx; Nsfx=sfx; }
   count++;
}

Normal::~Normal()
{
   count--;
   if (count) NotReady=true;                     // disable freeing arrays
}

Real Normal::Density(Real x) const               // normal density
{ return (fabs(x)>8.0) ? 0 : 0.398942280 * exp(-x*x / 2); }

ChiSq1::ChiSq1(Real d) : Normal()                // chisquare with 1 df
{ deltasq=d; delta=sqrt(d); }

Real ChiSq1::Next()
{ Real z=Normal::Next()+delta; return z*z; }

ChiSq::ChiSq(int df, Real noncen)
{
  if (df<=0 || noncen<0.0) Throw(Logic_error("Newran: illegal parameters"));
  else if (df==1) { version=0; c1=new ChiSq1(noncen); }
  else if (noncen==0.0)
  {
     if (df==2) { version=1; c1=new Exponential(); }
     else { version=2; c1=new Gamma2(0.5*df); }
  }
  else if (df==2) { version=3; c1=new ChiSq1(noncen/2.0); }
  else if (df==3) { version=4; c1=new Exponential(); c2=new ChiSq1(noncen); }
  else { version=5; c1=new Gamma2(0.5*(df-1)); c2=new ChiSq1(noncen); }
  if (!c1 || (version>3 && !c2)) ErrorNoSpace();
  mean=df+noncen; var=2*df+4.0*noncen;
}

ChiSq::~ChiSq() { delete c1; if (version>3) delete c2; }

Real ChiSq::Next()
{
   switch(version)
   {
   case 0: return c1->Next();
   case 1: case 2: return c1->Next()*2.0;
   case 3: return c1->Next() + c1->Next();
   case 4: case 5: Real s1 = c1->Next()*2.0; Real s2 = c2->Next();
	   return s1 + s2; // this is to make it work with Microsoft VC5
   }
   return 0;
}

Pareto::Pareto(Real shape) : Shape(shape)
{
   if (Shape <= 0) Throw(Logic_error("Newran: illegal parameter"));
   RS = -1.0 / Shape;
}

Real Pareto::Next()
{ return pow(Random::Next(), RS); }

ExtReal Pareto::Mean() const
{
   if (Shape > 1) return Shape/(Shape-1.0);
   else return PlusInfinity;
}

ExtReal Pareto::Variance() const
{
   if (Shape > 2) return Shape/(square(Shape-1.0))/(Shape-2.0);
   else return PlusInfinity;
}

Real Cauchy::Density(Real x) const               // Cauchy density function
{ return (fabs(x)>1.0e15) ? 0 : 0.31830988618 / (1.0+x*x); }

Poisson1::Poisson1(Real mux) : AsymGen(mux)      // Constructor
{ mu=mux; ln_mu=log(mu); }

Real Poisson1::Density(Real x) const             // Poisson density function
{
   if (x < 0.0) return 0.0;
   double ix = floor(x);                         // use integer part
   double l = ln_mu * ix - mu - ln_gamma(1.0 + ix);
   return  (l < -40.0) ? 0.0 : exp(l);
}

Binomial1::Binomial1(int nx, Real px)
   : AsymGen((nx + 1) * px), p(px), q(1.0 - px), n(nx)
      { ln_p = log(p); ln_q = log(q); ln_n_fac = ln_gamma(n+1); }

Real Binomial1::Density(Real x) const            // Binomial density function
{
   double ix = floor(x);                         // use integer part
   if (ix < 0.0 || ix > n) return 0.0;
   double l = ln_n_fac - ln_gamma(ix+1) - ln_gamma(n-ix+1)
      + ix * ln_p + (n-ix) * ln_q;
   return  (l < -40.0) ? 0.0 : exp(l);
}

Poisson2::Poisson2(Real mux)
{
   Real probs[40];
   probs[0]=exp(-mux);
   for (int i=1; i<40; i++) probs[i]=probs[i-1]*mux/i;
   dg=new DiscreteGen(40,probs);
   if (!dg) ErrorNoSpace();
}

Poisson2::~Poisson2() { delete dg; }

Binomial2::Binomial2(int nx, Real px)
{
   Real qx = 1.0 - px;
   Real probs[40];
   int k = (int)(nx * px);
   probs[k] = exp(ln_gamma(nx+1) - ln_gamma(k+1) - ln_gamma(nx-k+1)
      + k * log(px) + (nx-k) * log(qx));
   int i;
   int m = (nx >= 40) ? 39 : nx;
   for (i=k+1; i<=m; i++) probs[i]=probs[i-1] * px * (nx-i+1) / qx / i;
   for (i=k-1; i>=0; i--) probs[i]=probs[i+1] * qx * (i+1) / px / (nx-i);
   dg = new DiscreteGen(m + 1, probs);
   if (!dg) ErrorNoSpace();
}

Binomial2::~Binomial2() { delete dg; }

Real Exponential::Density(Real x) const          // Negative exponential
{ return  (x > 40.0 || x < 0.0) ? 0.0 : exp(-x); }

Poisson::Poisson(Real mu)
{

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www.亚洲在线| 欧美日韩国产小视频| 亚洲一线二线三线久久久| 日韩一区二区精品在线观看| 成人国产精品免费| 蜜臀av一区二区在线观看| 国产精品剧情在线亚洲| 日韩亚洲欧美在线观看| 一本大道av一区二区在线播放| 久久99国产精品久久99果冻传媒| 亚洲精品国产无天堂网2021 | 日韩三级视频中文字幕| av不卡一区二区三区| 久久99久久久久| 五月天亚洲精品| 亚洲欧美视频在线观看| 国产亚洲va综合人人澡精品| 日韩欧美自拍偷拍| 欧美日韩国产区一| 91视视频在线直接观看在线看网页在线看| 久久精品国产亚洲aⅴ| 亚洲国产视频a| 亚洲欧美日韩成人高清在线一区| 国产午夜精品在线观看| 欧美大片国产精品| 欧美一级专区免费大片| 欧美日韩高清在线| 91成人网在线| 99免费精品在线| 国产 欧美在线| 国产精品自拍一区| 国模冰冰炮一区二区| 免费成人性网站| 日韩精品国产精品| 亚洲大片在线观看| 亚洲第一会所有码转帖| 亚洲午夜视频在线| 亚洲主播在线观看| 一区二区三区波多野结衣在线观看| 亚洲欧洲美洲综合色网| 国产精品美女久久久久av爽李琼| 久久久99久久精品欧美| 久久蜜臀精品av| 久久久久久久综合| 国产性做久久久久久| 久久久精品国产免大香伊| 欧美精品一区二区三区四区| 26uuu亚洲| 国产日韩三级在线| 欧美激情一区二区三区四区 | 欧美精品一区二| 亚洲视频一二三| 综合久久一区二区三区| 日韩理论片一区二区| 亚洲天堂成人在线观看| 亚洲影院久久精品| 香蕉久久夜色精品国产使用方法| 日日摸夜夜添夜夜添精品视频| 亚洲妇女屁股眼交7| 日韩专区在线视频| 麻豆成人免费电影| 丰满少妇久久久久久久 | 欧美主播一区二区三区| 欧美日韩国产中文| 日韩精品一区二区三区视频播放| 久久夜色精品国产噜噜av| 国产片一区二区三区| 综合在线观看色| 亚洲电影一级黄| 久久国内精品自在自线400部| 久久成人羞羞网站| 国产一区二区三区黄视频 | 天天综合色天天综合| 久久av中文字幕片| 成人av在线资源| 欧美色男人天堂| 欧美成人精品高清在线播放| 精品无人区卡一卡二卡三乱码免费卡 | 国产喷白浆一区二区三区| 1区2区3区精品视频| 亚洲高清三级视频| 国产在线一区观看| 色猫猫国产区一区二在线视频| 欧美日韩aaaaa| 2021中文字幕一区亚洲| 亚洲男同性视频| 蜜臀av国产精品久久久久| 国产成人免费视频网站| 91国偷自产一区二区三区观看 | 自拍偷自拍亚洲精品播放| 三级不卡在线观看| 成人永久免费视频| 欧美美女bb生活片| 国产三级精品视频| 婷婷久久综合九色综合绿巨人 | 在线播放一区二区三区| 国产人妖乱国产精品人妖| 亚洲一二三四在线| 丰满少妇在线播放bd日韩电影| 欧美最猛性xxxxx直播| 久久久久亚洲蜜桃| 午夜欧美在线一二页| jlzzjlzz亚洲女人18| 日韩精品一区二| 亚洲一区在线视频| 成人性视频免费网站| 7777精品伊人久久久大香线蕉完整版 | 亚洲综合免费观看高清在线观看| 国产乱码字幕精品高清av| 欧美日韩在线播| 国产精品久久久久久亚洲毛片| 日本免费在线视频不卡一不卡二| 不卡区在线中文字幕| www欧美成人18+| 日韩精品免费视频人成| 色综合网站在线| 国产欧美一区二区三区在线看蜜臀 | 日本不卡一区二区三区| 色婷婷国产精品| 国产精品丝袜在线| 国产在线不卡一区| 91麻豆精品国产91| 亚洲一区二区在线免费观看视频 | 久久99热狠狠色一区二区| 欧美日韩午夜在线| 亚洲另类在线视频| 99re热视频精品| 国产精品卡一卡二| 丁香婷婷深情五月亚洲| 久久蜜桃一区二区| 国产在线不卡一区| 精品国产三级电影在线观看| 日产欧产美韩系列久久99| 在线精品观看国产| 一区二区三区在线免费播放| 成人97人人超碰人人99| 国产视频一区二区在线| 国产一区二区在线观看免费| 日韩精品一区二区三区视频在线观看 | 精品精品国产高清a毛片牛牛| 首页亚洲欧美制服丝腿| 欧美日韩另类国产亚洲欧美一级| 亚洲一区二区三区中文字幕在线| 色哟哟一区二区在线观看 | 国产欧美日韩一区二区三区在线观看| 韩国欧美国产一区| 久久先锋影音av鲁色资源| 国产在线视频一区二区三区| 欧美精品一区二区三区蜜桃 | 国产精品综合在线视频| 久久久亚洲高清| 懂色av一区二区三区免费看| 国产精品久久午夜夜伦鲁鲁| www.综合网.com| 一区二区高清视频在线观看| 在线观看日韩精品| 天堂精品中文字幕在线| 欧美一区二区在线免费观看| 捆绑调教一区二区三区| 久久久不卡网国产精品一区| 成人国产精品免费观看| 亚洲免费毛片网站| 欧美美女喷水视频| 精品无人码麻豆乱码1区2区 | 91精品国产日韩91久久久久久| 奇米精品一区二区三区在线观看一| 欧美大尺度电影在线| 国产美女av一区二区三区| 国产精品视频一二三区| 91国偷自产一区二区开放时间 | 在线观看91精品国产入口| 日韩电影一区二区三区| 久久亚洲二区三区| 色综合天天狠狠| 日本91福利区| 国产精品久久久久久久裸模| 97se亚洲国产综合自在线观| 五月综合激情婷婷六月色窝| 久久嫩草精品久久久精品一| 91丨porny丨国产| 蜜桃av一区二区三区电影| 中文在线免费一区三区高中清不卡| 91黄视频在线| 国产一区二区三区免费观看| 亚洲美女视频一区| 日韩欧美综合一区| 91污片在线观看| 麻豆精品国产91久久久久久| |精品福利一区二区三区| 777xxx欧美| 97精品国产97久久久久久久久久久久| 天堂成人国产精品一区| 国产精品久久毛片av大全日韩| 91精品国产一区二区三区蜜臀 | 日韩欧美精品在线| av不卡免费在线观看| 另类小说欧美激情| 亚洲精品中文在线观看| 亚洲精品在线免费观看视频| 色综合久久久久网|