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

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

?? newran.cpp

?? D-ITG2.4源代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// newran.cpp -----------------------------------------------------------

// NEWRAN02B - 22 July 2002

#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();
}


//Real Constant::Next() { return value; }


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); }
  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区欧美国产| 欧美电影免费观看高清完整版在 | 国产喷白浆一区二区三区| 99久久免费精品| 久久精品国产亚洲5555| 一区二区三区免费观看| 久久久久国产一区二区三区四区| 国产一区二区三区精品欧美日韩一区二区三区 | av电影在线不卡| 青草国产精品久久久久久| 亚洲综合一区二区精品导航| 亚洲国产精品精华液2区45| 欧美精品在线观看播放| 在线观看视频一区| 国模无码大尺度一区二区三区| 国产精品欧美综合在线| 精品国产乱码久久久久久浪潮| 欧美三区在线观看| 欧美亚男人的天堂| 欧美性极品少妇| 日本二三区不卡| 在线日韩一区二区| 欧美日韩国产免费| 欧美精品粉嫩高潮一区二区| 在线观看不卡视频| 欧美精品在线观看播放| 日韩午夜小视频| 精品福利视频一区二区三区| 久久综合狠狠综合久久激情 | 久久久精品日韩欧美| 久久久久国产成人精品亚洲午夜| 国产午夜精品福利| 亚洲小少妇裸体bbw| 欧美国产精品v| 一区二区在线看| 蜜臀av一区二区三区| 丰满白嫩尤物一区二区| 日本精品一区二区三区高清| 51精品视频一区二区三区| 精品久久人人做人人爰| 中文字幕日韩一区| 日本免费在线视频不卡一不卡二| 国产在线一区二区综合免费视频| 国精产品一区一区三区mba桃花| 成人一区二区三区视频| 欧洲亚洲精品在线| 久久久亚洲精品一区二区三区| 亚洲欧洲制服丝袜| 国产成人免费在线观看不卡| 在线观看国产一区二区| 日本一区免费视频| 亚洲6080在线| 色综合久久久久| 久久精品欧美一区二区三区不卡 | 亚洲欧美精品午睡沙发| 久久9热精品视频| 欧美日韩一区二区三区在线看| 久久久久99精品一区| 日韩高清欧美激情| 欧美三级中文字| 亚洲欧美一区二区三区久本道91 | 色欧美片视频在线观看| 91精品国产美女浴室洗澡无遮挡| 555www色欧美视频| 又紧又大又爽精品一区二区| 波多野洁衣一区| 久久精品视频一区| 国产精品综合一区二区三区| 91精品国产91久久久久久最新毛片 | 日韩中文字幕一区二区三区| 色婷婷久久久亚洲一区二区三区| 亚洲国产精品成人综合| 国产成人亚洲精品青草天美| 91搞黄在线观看| 中文字幕成人在线观看| 国产精品一区二区视频| 国产亚洲欧美一级| 国产成人一区在线| 国产精品理论片在线观看| heyzo一本久久综合| 亚洲精品国产成人久久av盗摄| av欧美精品.com| 午夜精品久久久久久| 欧美一级高清大全免费观看| 精品亚洲免费视频| 一区二区三区四区在线播放| 欧美日韩三级一区二区| 九九热在线视频观看这里只有精品| 99在线精品视频| 亚洲欧洲中文日韩久久av乱码| 欧美三级蜜桃2在线观看| 美女久久久精品| 国产精品亲子乱子伦xxxx裸| 欧美写真视频网站| 极品少妇一区二区三区精品视频| 日本一区二区三区久久久久久久久不| 丁香婷婷综合色啪| 亚洲成年人影院| 国产精品传媒入口麻豆| 精品处破学生在线二十三| 色综合久久综合| 国产成人精品综合在线观看| 亚洲韩国精品一区| 中文av字幕一区| 久久午夜电影网| 91精品国产91综合久久蜜臀| av激情成人网| 中文字幕在线一区二区三区| 亚洲成人免费视频| 国产欧美一区二区精品性色超碰 | 日韩一区二区免费视频| 91丝袜美女网| 国产在线精品一区二区夜色 | 亚洲成a人v欧美综合天堂下载| 久久久久9999亚洲精品| 欧美videofree性高清杂交| 欧美日韩不卡一区| 欧美男生操女生| 欧美中文字幕一二三区视频| 99精品欧美一区二区三区综合在线| 奇米四色…亚洲| 国产精品福利影院| 自拍偷拍国产精品| 国产亚洲精品福利| 久久久精品一品道一区| 久久久久九九视频| 久久精品在这里| 国产精品第五页| 亚洲男人的天堂一区二区| 国产精品女人毛片| 亚洲欧美日韩小说| 亚洲成人av免费| 久久99久久久欧美国产| 国产精品一品视频| 9i在线看片成人免费| 欧美日韩一区 二区 三区 久久精品| 欧美丝袜自拍制服另类| 日韩欧美激情一区| 国产日韩精品久久久| 亚洲麻豆国产自偷在线| 亚洲一二三级电影| 99久久久久久| 亚洲精品乱码久久久久久 | www.亚洲人| 精品视频一区三区九区| 精品少妇一区二区三区免费观看| 久久久99精品免费观看不卡| 亚洲欧美自拍偷拍| 久久66热re国产| 色婷婷激情综合| 久久婷婷国产综合国色天香| 有码一区二区三区| 成人性视频免费网站| 7777精品伊人久久久大香线蕉的| 久久网站最新地址| 奇米一区二区三区| 91久久免费观看| 欧美高清在线一区二区| 久久www免费人成看片高清| 欧美亚洲综合网| 国产精品看片你懂得| 国产麻豆日韩欧美久久| 欧美一区二区三区婷婷月色| 亚洲乱码精品一二三四区日韩在线| 麻豆精品精品国产自在97香蕉| 在线观看视频一区二区 | 91免费版pro下载短视频| 精品播放一区二区| 日本网站在线观看一区二区三区| 91免费国产视频网站| 国产精品久久网站| 成人午夜电影久久影院| 欧美精彩视频一区二区三区| 国产在线视频不卡二| 国产欧美一区二区精品性| 国产精品一区二区在线观看不卡 | 日本va欧美va精品发布| 日韩欧美123| 国产精品羞羞答答xxdd| 国产色综合一区| 99免费精品在线观看| 亚洲色图20p| 欧美视频在线观看一区二区| 亚洲成人激情自拍| 日韩一区二区三区av| 捆绑调教一区二区三区| 欧美va在线播放| 不卡一区中文字幕| 偷窥少妇高潮呻吟av久久免费| 日韩一级片在线观看| 成人中文字幕电影| 亚洲第四色夜色| 26uuu亚洲综合色| 色天天综合色天天久久| 天堂va蜜桃一区二区三区| 精品国产精品网麻豆系列| 国产成都精品91一区二区三| 亚洲黄色录像片| 久久久一区二区三区| 91蝌蚪porny|