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

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

?? rt_rand.c~

?? 雷達(dá)工具箱
?? C~
字號(hào):
/* The internal random generators need to be converted to double precision... */#include "math.h"#include "matrix.h"#include "mex.h"#include "string.h"#include <stdlib.h>#include <stdio.h>#include "cdflib.h"#define USAGE "\n P = RT_ran(pdftype,seed1,seed2,param1,param2...,{mrows,ncols})\n A mex interface for the RANDLIB libraries by Glen Davidson.\n P is a random variate from distribution PDFTYPE with parameters param* \n THE SEEDs SHOULD BE PASSED AS rand FROM Matlab \n see randlib.c.fdoc for usage. \n PDFTYPE = [1..10] as beta(1), binomial(2), chisquare(3), \n non-central chisquare(4), F(5), non-central F(6), gamma(7), negative binomial(8), normal(9), poisson(10). \n If the parameters are not all scalar, the common size will be returned, else use MROWS and NCOLS.\n use RT_ran(pdftype) to display required parameters.\n\n NOTE THE VARIATES ARE SINGLE PRECISION (CONVERTED FROM A C float)"#define BETAdist 1#define BINOMIALdist 2#define CHISQUAREdist 3/* non-central chisquare */#define NCCHISQUAREdist 4/* non-central F distribution */#define Fdist 5#define NCFdist 6#define GAMMAdist 7/* negative binomial */#define NEGBINOMIALdist 8#define NORMALdist 9#define POISSONdist 10void mexFunction( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[] ){  double p;			/* outputs from core routines */  double *p_outputPtr = NULL; /* pointer to outputs */  int nel, mrows, ncols, pdftype = 0;  int mrows_input, mrows_output; /* matrix output from scalar parameters */  int nel_check_mrows, nec_check_ncols; /* matrix output from scalar parameters */  int nel_check, mrows_check, ncols_check;  int rloop, tloop;  long seed1_long, seed2_long;	/* RNG needs LONG seed initialiser */  double seed1_double, seed2_double; /* rand passed from Matlab */  int NCDF=10;			/* total of 10 pdfs in the package */  /* following is number of params for each distribution, but indexed from 1 so NparamsPtr[0] invalid */  int NparamsPtr[] = {-1, 2, 2, 1, 2, 2, 3, 2, 2, 2, 1};  /* following is number of elements within each parameter to allow matrix inputs, 10 allocated for future use */  int NelementsPtr[10];  /* pointer to the actual elements */  double *elementsPtrPtr[10];  /* FOLLOWING USES FLOAT FOR THE SINGLE-PRECISION RANDOM NUMBER LIBRARY */  /* array space to pass to a single routine */  float param_passPtr[10];  long binparam;		/* binomial & negative binomial require a long input */   if (nrhs < 1) {		/* minimum number of 1 inputs */    mexPrintf("\n Incorrect number of input arguments");    mexErrMsgTxt(USAGE);  }  if (nlhs > 1) {    mexPrintf("\n Incorrect number of output arguments");    mexErrMsgTxt(USAGE);  }  nel_check = mxGetNumberOfElements(prhs[0]);  if (nel_check == 1) {    pdftype = (int)mxGetScalar(prhs[0]);  } else {    mexPrintf("\n PDFTYPE should be a scalar for the particular cdf");    mexErrMsgTxt(USAGE);  }  if ( (pdftype < 1) || (pdftype > NPDF)) {    mexPrintf("\n PDFTYPE should range from 1 to %d",NPDF);    mexErrMsgTxt(USAGE);  }  /* check for correct number of inputs (subtracting 1 for the pdftype input and 2 for the seeds)*/  if ( (nrhs-3) == NparamsPtr[pdftype] ) {/* no mrows or ncols */    do_mrows_ncols = 0;  } elseif ( (nrhs-5) == NparamsPtr[pdftype] ) { /* mrows and ncols input */    do_mrows_ncols = 1;    nel_check_mrows = mxGetNumberOfElements(prhs[nrhs-2]);    nel_check_ncols = mxGetNumberOfElements(prhs[nrhs-1]);    if ( (nel_check_mrows != 1) || (nel_check_ncols != 1) ) {      mexPrintf("\n Need scalar inputs for MROWS and NCOLS");      mexErrMsgTxt(USAGE);    }    mrows_input = (int)mxGetScalar(prhs[nrhs-2]);    ncols_input = (int)mxGetScalar(prhs[nrhs-1]);    if ( (mrows_input < 1) || (ncols_input < 1) ) {      mexPrintf("\n Need scalar inputs > 0 for MROWS and NCOLS");      mexErrMsgTxt(USAGE);    }  } else {    switch(pdftype) {    case BETAdist: mexPrintf("\n Need A and B for BETA distribution");break;    case BINOMIALdist: mexPrintf("\n Need XN, and PR for BINOMIAL distribution");break;    case CHISQUAREdist: mexPrintf("\n Need DF for CHISQUARE distribution");break;    case NCCHISQUAREdist: mexPrintf("\n Need DF and PNONC for NON CENTRAL CHISQUARE distribution");break;    case Fdist: mexPrintf("\n Need DFN and DFD for F distribution");break;    case NCFdist: mexPrintf("\n Need DFN, DFD and PNONC for NON CENTRAL F distribution");break;    case GAMMAdist: mexPrintf("\n Need SHAPE and SCALE for GAMMA distribution");break;    case NEGBINOMIALdist: mexPrintf("\n Need XN and PR for NEGATIVE BINOMIAL distribution");break;    case NORMALdist: mexPrintf("\n Need MEAN, and SD for NORMAL distribution");break;    case POISSONdist: mexPrintf("\n Need XLAM for POISSON distribution");break;    default: mexErrMsgTxt("\n Case not implemented");    }    mexPrintf("\n with optional MROW and NCOL input");    mexErrMsgTxt(USAGE);  }  nel_check = mxGetNumberOfElements(prhs[1]); /* seed1 */  if (nel_check == 1) {    seed1_double = mxGetScalar(prhs[1]);    if ( (seed1_double <= 0.0) | (seed1_double >= 1.0) ) {      mexPrintf("\n SEED1 should be a rand output from 0.0 < SEED1 < 1.0");      mexErrMsgTxt(USAGE);    }  } else {    mexPrintf("\n SEED1 should be a scalar 0.0 < SEED1 < 1.0 ");    mexErrMsgTxt(USAGE);  }  nel_check = mxGetNumberOfElements(prhs[2]); /* seed2 */  if (nel_check == 1) {    seed2_double = mxGetScalar(prhs[2]);    if ( (seed2_double <= 0.0) | (seed2_double >= 1.0) ) {      mexPrintf("\n SEED2 should be a rand output from 0.0 < SEED2 < 1.0");      mexErrMsgTxt(USAGE);    }  } else {    mexPrintf("\n SEED2 should be a scalar 0.0 < SEED2 < 1.0 ");    mexErrMsgTxt(USAGE);  }    /* very laborious test to determine if input sizes are valid,     this means they should be scalars or the size of mrows_out, ncols_out */  nel = 1;		/* assumed number of output elements */  mrows = 1;		/* assumed rows of output elements */  ncols = 1;		/* assumed columns of output elements */    for (tloop = 1; tloop <= NparamsPtr[pdftype]; tloop++) { /* [pdftype,seed1,seed2,1,2,3..N,{mrows,ncols}] */    nel_check = mxGetNumberOfElements(prhs[tloop+2]); /* tloop+2 skips pdftype, seed1 and seed2 */    if (nel_check == 0) {      mexPrintf("\n Can't process parameters passed as []");      mexErrMsgTxt(USAGE);    }    NelementsPtr[tloop] = nel_check; /* store number of elements */    elementsPtrPtr[tloop] = mxGetPr(prhs[tloop+2]); /* and actual element pointer reference */    if (nel_check > 1) {		/* is this input a matrix */      if (nel > 1) {		/* is there already a matrix input */	mrows_check = mxGetM(prhs[tloop+2]); /* tloop+2 skips pdftype, seed1 and seed2 */	ncols_check = mxGetN(prhs[tloop+2]); /* tloop+2 skips pdftype, seed1 and seed2 */	if ( (mrows_check != mrows) || (ncols_check != ncols) ) {	  mexPrintf("\n Input sizes are invalid");	  mexErrMsgTxt(USAGE);	}      } else {			/* this is the first matrix input */	nel = mxGetNumberOfElements(prhs[tloop+2]); /* tloop+2 skips pdftype, seed1 and seed2 */	mrows = mxGetM(prhs[tloop+2]); /* tloop+2 skips pdftype, seed1 and seed2 */	ncols = mxGetN(prhs[tloop+2]); /* tloop+2 skips pdftype, seed1 and seed2 */      }    }  }  /* Only if all the parameters are scalar and an mrows_input and ncols_input is present, can     a matrix of similarly distributed variates be output */  if (do_mrows_ncols == 1) {	/* mrows_input and ncols_input */    if ( (mrows == 1) && (ncols == 1) ) { /* scalar parameters */      mrows = mrows_input;      ncols = ncols_input;      nel = mrows_input * ncols_input;    } else {      mexPrintf("\n Parameters must be scalar for a matric MROWS x NCOLS output");      mexErrMsgTxt(USAGE);    }  }      				/* create output (p) */  plhs[0] = mxCreateDoubleMatrix(mrows, ncols, mxREAL);  p_outputPtr = mxGetPr(plhs[0]);  /* Note problem with all this is that it's single precision... param_passPtr modified for this */  /* Initialise random number generator: From Basegen.c.doc in randlib*/  /* The state of a generator  is determined by two  integers called seeds.     The seeds can be  initialized  by the  user; the initial values of the     first must lie between 1 and 2,147,483,562, that of the second between     1 and 2,147,483,398.  Each time a number is generated,  the  values of     the seeds changes.  */  seed1_long = (long)(seed1_double * 1073741824 + 1);	/* a seed of 1..2^30 is large enough */  seed2_long = (long)(seed2_double * 1073741824 + 1);	/* a seed of 1..2^30 is large enough */  setall( seed1_long, seed2_long );  for (rloop=0; rloop < nel; rloop++) {    for (tloop=1; tloop <= NparamsPtr[pdftype]; tloop++) {      if (NelementsPtr[tloop] == 1) { /* if only one element input, always pass this */	param_passPtr[tloop] = (float)elementsPtrPtr[tloop][0];      } else {			/* else pass the array over the loop */	param_passPtr[tloop] = (float)elementsPtrPtr[tloop][rloop];      }    } /* finished forming inputs */    switch (pdftype) {    case BETAdist:      p = (double)genbet(&(param_passPtr[1]), &param_passPtr[2]); break;    case BINOMIALdist:      binparam = (long)param_passPtr[1]; /* need to pass a long integer */      p = (double)ignbin(&binparam, &param_passPtr[2]); break;    case CHISQUAREdist:      p = (double)genchi(&(param_passPtr[1])); break;    case NCCHISQUAREdist:      p = (double)gennch(&(param_passPtr[1]), &param_passPtr[2]); break;    case Fdist:      p = (double)genf(&(param_passPtr[1]), &param_passPtr[2]); break;    case NCFdist:      p = (double)genbet(&(param_passPtr[1]), &param_passPtr[2], &param_passPtr[3]); break;    case GAMMAdist:       p = (double)gengam(&(param_passPtr[1]), &param_passPtr[2]); break;    case NEGBINOMIALdist:       binparam = (long)param_passPtr[1]; /* need to pass a long integer */      p = (double)ignnbn(&binparam, &param_passPtr[2]); break;    case NORMALdist:       p = (double)gennor(&(param_passPtr[1]), &param_passPtr[2]); break;    case POISSONdist:       p = (double)ignpoi(&(param_passPtr[1])); break;    default: mexErrMsgTxt("\n Case not implemented");    }    if (status != 0) {		/* invalid status needs to set NaN */      p = mxGetNaN();      q = mxGetNaN();    }    p_outputPtr[rloop] = p;    if (do_qcomplement) q_outputPtr[rloop] = q;    if (do_bound) bound_outputPtr[rloop] = bound;    if (do_status) status_outputPtr[rloop] = (double)status;  }}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品国产麻豆不卡| 成人在线综合网| 久久婷婷国产综合精品青草| 99久久99久久免费精品蜜臀| 美女久久久精品| 亚洲女人****多毛耸耸8| 欧美大尺度电影在线| 日本韩国一区二区三区| 国产91丝袜在线播放0| 日韩极品在线观看| 一区二区三区欧美| 国产精品人人做人人爽人人添| 欧美一区二区三区免费在线看| www.成人网.com| 国产曰批免费观看久久久| 日韩精品成人一区二区在线| 一区二区三区资源| 国产精品国产精品国产专区不蜜| 日韩免费视频线观看| 欧美日韩在线播放| 欧美在线不卡视频| 欧美性极品少妇| 国产 欧美在线| 国产成人午夜片在线观看高清观看| 蜜乳av一区二区| 日韩在线一区二区三区| 亚洲成在线观看| 亚洲高清视频的网址| 亚洲制服丝袜av| 亚洲国产精品一区二区www在线| 亚洲精品视频在线| 亚洲欧洲中文日韩久久av乱码| 亚洲欧洲精品一区二区精品久久久| 久久久久久免费网| 国产日韩三级在线| 欧美国产精品v| 日本一区二区成人在线| 中文字幕第一区二区| 国产日韩av一区| 中文字幕永久在线不卡| 中文字幕视频一区二区三区久| 国产精品福利电影一区二区三区四区| 国产日韩欧美一区二区三区乱码 | 欧美日韩不卡在线| 在线视频亚洲一区| 欧美日韩1区2区| 3d动漫精品啪啪1区2区免费| 欧美一级精品大片| 欧美成人乱码一区二区三区| 精品国产免费视频| 久久精品视频免费| 亚洲欧洲国产日本综合| 亚洲精品成人a在线观看| 亚洲图片一区二区| 欧美aaaaa成人免费观看视频| 免费看日韩精品| 国产一区免费电影| 91亚洲精品久久久蜜桃网站 | 亚洲精品国产无天堂网2021| 一区二区三区中文免费| 亚洲午夜激情av| 人人精品人人爱| 国产精品综合网| 一本到不卡精品视频在线观看| 欧美精品 国产精品| 欧美精品自拍偷拍动漫精品| 精品国产欧美一区二区| 亚洲欧洲另类国产综合| 亚洲成人久久影院| 狠狠v欧美v日韩v亚洲ⅴ| 99久久精品免费观看| 日本黄色一区二区| 欧美成人午夜电影| 中文字幕在线观看不卡| 五月综合激情婷婷六月色窝| 国产一区二区三区四区在线观看| 99久久国产综合精品女不卡| 欧美一区二区三区视频| 国产欧美久久久精品影院| 亚洲国产精品一区二区www在线| 精品中文字幕一区二区小辣椒| 成人激情图片网| 欧美久久婷婷综合色| 国产日产欧美一区二区三区| 亚洲成人福利片| 国产精品亚洲一区二区三区妖精| 色婷婷综合五月| 久久久久久久久久久久电影| 亚洲综合久久久| 国产精品一级片在线观看| 欧美三级在线看| 中文字幕不卡在线| 免费成人av在线播放| 91蜜桃在线观看| 亚洲精品在线网站| 亚洲大尺度视频在线观看| 成人免费视频视频在线观看免费| 制服丝袜在线91| 成人免费小视频| 国产一区二区视频在线| 8x8x8国产精品| 亚洲激情av在线| 国产盗摄视频一区二区三区| 日韩情涩欧美日韩视频| 一区二区久久久久| www.亚洲激情.com| 久久综合五月天婷婷伊人| 午夜精品久久久久久久久久| 91香蕉视频mp4| 国产日韩影视精品| 激情小说欧美图片| 日韩色在线观看| 亚洲成年人网站在线观看| 99久久久久免费精品国产 | 最新欧美精品一区二区三区| 久久91精品久久久久久秒播| 欧美日韩一区二区三区高清| 亚洲免费成人av| 成人av在线资源| 国产日韩av一区二区| 国产精品69久久久久水密桃 | 亚洲精品视频免费观看| 高清日韩电视剧大全免费| 精品国产1区二区| 日本最新不卡在线| 日韩一区二区免费视频| 午夜成人在线视频| 欧美一区二区在线视频| 亚洲chinese男男1069| 在线视频观看一区| 亚洲一区二区三区四区在线| 欧美在线三级电影| 亚洲一区二区在线免费观看视频| 97久久超碰国产精品电影| 国产精品国产三级国产普通话蜜臀 | 日韩一级黄色片| 日韩av午夜在线观看| 91麻豆精品91久久久久同性| 午夜影视日本亚洲欧洲精品| 欧美精品日韩一本| 免费成人深夜小野草| 欧美不卡激情三级在线观看| 国产最新精品免费| 欧美国产成人在线| av中文字幕亚洲| 亚洲免费观看在线视频| 欧美视频一区二区三区| 全国精品久久少妇| 欧美精品一区二区在线播放| 国产成人精品网址| 国产精品成人一区二区艾草 | 久久这里只有精品首页| 国产黄色精品网站| 自拍偷拍欧美激情| 欧美在线观看一二区| 男女性色大片免费观看一区二区| 精品欧美乱码久久久久久1区2区| 国模一区二区三区白浆| 国产精品视频一二三| 91成人网在线| 久久电影网电视剧免费观看| 国产免费观看久久| 在线看日韩精品电影| 日韩在线观看一区二区| 国产亚洲欧美日韩日本| 一本久道久久综合中文字幕| 日本不卡的三区四区五区| 久久综合色天天久久综合图片| 成人精品视频一区二区三区| 一区二区三区精品视频在线| 欧美videos大乳护士334| 成人精品视频一区二区三区| 偷拍与自拍一区| 国产亚洲精久久久久久| 欧美图片一区二区三区| 国产美女在线精品| 亚洲自拍偷拍欧美| www国产亚洲精品久久麻豆| 91亚洲精品一区二区乱码| 男女性色大片免费观看一区二区| 国产精品毛片大码女人| 91精品国产综合久久久久久漫画| 国产很黄免费观看久久| 午夜影院久久久| 国产精品美女一区二区| 日韩欧美中文字幕精品| 色综合久久久久网| 精品一区二区三区免费观看| 亚洲在线中文字幕| 日本一区二区成人| 欧美大片国产精品| 色妹子一区二区| 精品一区二区久久| 婷婷国产在线综合| 国产精品国产三级国产三级人妇| 精品国产免费人成在线观看| 欧美天堂一区二区三区| 成人丝袜18视频在线观看| 免费在线看一区| 夜夜爽夜夜爽精品视频|