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

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

?? nrutil.cpp

?? HMM模型的C語言實現
?? CPP
字號:
//nrutil.cpp
#include "StdAfx.h"
#include <stdio.h>
#include <stddef.h>
#include <stdlib.h>

//報告錯誤
void nrerror(char *error_text)
{
	printf("Numerical Recipes run-time error...\n");
	printf("%s\n",error_text);
	printf("...now exiting to system...\n");
	exit(1);
}

/*****************************************************************************
 * 函數名稱:vector
 * 功能:申請一個實數數組
 * 參數:nl:數組的最低下標
 *       nh:數組的最高下標
 * 返回:數組地址
 */
float *vector(long nl,long nh)
{
	float *v;

	v=(float *)calloc((unsigned) (nh-nl+1),sizeof(float));
	if (!v) nrerror("allocation failure in vector()");
	return v-nl;
}

/*****************************************************************************
 * 函數名稱:ivector
 * 功能:申請一個整數數組
 * 參數:nl:數組的最低下標
 *       nh:數組的最高下標
 * 返回:數組地址
 */
int *ivector(long nl,long nh)
{
	int *v;

	v=(int *)calloc((unsigned) (nh-nl+1),sizeof(int));
	if (!v) nrerror("allocation failure in ivector()");
	return v-nl;
}

/*****************************************************************************
 * 函數名稱:cvector
 * 功能:申請一個無符號字符數組
 * 參數:nl:數組的最低下標
 *       nh:數組的最高下標
 * 返回:數組地址
 */
unsigned char *cvector(long nl,long nh)
{
	unsigned char *v;

	v=(unsigned char *)calloc((unsigned) (nh-nl+1),sizeof(unsigned char));
	if (!v) nrerror("allocation failure in cvector()");
	return v-nl;
}

/*****************************************************************************
 * 函數名稱:lvector
 * 功能:申請一個長整數型數組
 * 參數:nl:數組的最低下標
 *       nh:數組的最高下標
 * 返回:數組地址
 */
unsigned long *lvector(long nl,long nh)
{
	unsigned long *v;

	v=(unsigned long *)calloc((unsigned) (nh-nl+1),sizeof(unsigned long));
	if (!v) nrerror("allocation failure in lvector()");
	return v-nl;
}

/*****************************************************************************
 * 函數名稱:dvector
 * 功能:申請一個雙精度實數數組
 * 參數:nl:數組的最低下標
 *       nh:數組的最高下標
 * 返回:數組地址
 */
double *dvector(long nl,long nh)
{
	double *v;

	v=(double *)calloc((unsigned) (nh-nl+1),sizeof(double));
	if (!v) nrerror("allocation failure in dvector()");
	return v-nl;
}

/*****************************************************************************
 * 函數名稱:matrix
 * 功能:申請一個實數二維數組(矩陣)
 * 參數:nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 返回:數組地址
 */
float **matrix(long nrl,long nrh,long ncl,long nch)
{
	int i;
	float **m;

	m=(float **) calloc((unsigned) (nrh-nrl+1),sizeof(float*));
	if (!m) nrerror("allocation failure 1 in matrix()");
	m -= nrl;

	for(i=nrl;i<=nrh;i++) {
		m[i]=(float *) calloc((unsigned) (nch-ncl+1),sizeof(float));
		if (!m[i]) nrerror("allocation failure 2 in matrix()");
		m[i] -= ncl;
	}
	return m;
}

/*****************************************************************************
 * 函數名稱:dmatrix
 * 功能:申請一個雙精度實數二維數組(矩陣)
 * 參數:nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 返回:數組地址
 */
double **dmatrix(long nrl,long nrh,long ncl,long nch)
{
	int i;
	double **m;

	m=(double **) calloc((unsigned) (nrh-nrl+1),sizeof(double*));
	if (!m) nrerror("allocation failure 1 in dmatrix()");
	m -= nrl;

	for(i=nrl;i<=nrh;i++) {
		m[i]=(double *) calloc((unsigned) (nch-ncl+1),sizeof(double));
		if (!m[i]) nrerror("allocation failure 2 in dmatrix()");
		m[i] -= ncl;
	}
	return m;
}

/*****************************************************************************
 * 函數名稱:imatrix
 * 功能:申請一個整數二維數組(矩陣)
 * 參數:nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 返回:數組地址
 */
int **imatrix(long nrl,long nrh,long ncl,long nch)
{
	int i,**m;

	m=(int **)calloc((unsigned) (nrh-nrl+1),sizeof(int*));
	if (!m) nrerror("allocation failure 1 in imatrix()");
	m -= nrl;

	for(i=nrl;i<=nrh;i++) {
		m[i]=(int *)calloc((unsigned) (nch-ncl+1),sizeof(int));
		if (!m[i]) nrerror("allocation failure 2 in imatrix()");
		m[i] -= ncl;
	}
	return m;
}

/*****************************************************************************
 * 函數名稱:cmatrix
 * 功能:申請一個無符號字符型二維數組(矩陣)
 * 參數:nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 返回:數組地址
 */
unsigned char **cmatrix(long nrl,long nrh,long ncl,long nch)
{
	int i;
	unsigned char **m;

	m=(unsigned char **) calloc((unsigned) (nrh-nrl+1),sizeof(unsigned char*));
	if (!m) nrerror("allocation failure 1 in dmatrix()");
	m -= nrl;

	for(i=nrl;i<=nrh;i++) {
		m[i]=(unsigned char *) calloc((unsigned) (nch-ncl+1),sizeof(unsigned char));
		if (!m[i]) nrerror("allocation failure 2 in dmatrix()");
		m[i] -= ncl;
	}
	return m;
}

/*****************************************************************************
 * 函數名稱:submatrix
 * 功能:求一個二維矩陣的子矩陣
 * 參數:a:二維矩陣的首地址
 *       oldrl:數組的行最低下標
 *       oldrh:數組的行最高下標
 *       oldcl:數組的列最低下標
 *       oldch:數組的列最高下標
 *       newrl:新數組的行最低下標
 *       newcl:新數組的列最低下標
 * 返回:數組地址
 */
float **submatrix(float **a,long oldrl,long oldrh,long oldcl,long oldch,long newrl,long newcl)
{
	int i,j;
	float **m;

	m=(float **) calloc((unsigned) (oldrh-oldrl+1),sizeof(float*));
	if (!m) nrerror("allocation failure in submatrix()");
	m -= newrl;

	for(i=oldrl,j=newrl;i<=oldrh;i++,j++) m[j]=a[i]+oldcl-newcl;

	return m;
}

/*****************************************************************************
 * 函數名稱:convert_matrix
 * 功能:將一個實數一維數組轉化為二維數組(矩陣)
 * 參數:a:原一維數組
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 返回:二維數組地址
 */
float **convert_matrix(float *a,long nrl,long nrh,long ncl,long nch)
{
	int i,j,nrow,ncol;
	float **m;

	nrow=nrh-nrl+1;
	ncol=nch-ncl+1;
	m = (float **) calloc((unsigned) (nrow),sizeof(float*));
	if (!m) nrerror("allocation failure in convert_matrix()");
	m -= nrl;
	for(i=0,j=nrl;i<=nrow-1;i++,j++) m[j]=a+ncol*i-ncl;
	return m;
}

/*****************************************************************************
 * 函數名稱:free_vector
 * 功能:釋放一個實數一維數組
 * 參數:nl:數組的行最低下標
 *       nh:數組的行最高下標
 * 無返回值
 */
void free_vector(float *v,long nl,long nh)
{
	free((char*) (v+nl));
}

/*****************************************************************************
 * 函數名稱:free_dvector
 * 功能:釋放一個整型一維數組
 * 參數:nl:數組的行最低下標
 *       nh:數組的行最高下標
 * 無返回值
 */
void free_ivector(int *v,long nl,long nh)
{
	free((char*) (v+nl));
}

/*****************************************************************************
 * 函數名稱:free_vector
 * 功能:釋放一個無符號字符型一維數組
 * 參數:nl:數組的行最低下標
 *       nh:數組的行最高下標
 * 無返回值
 */
void free_cvector(unsigned char *v,long nl,long nh)
{
	free((char*) (v+nl));
}

/*****************************************************************************
 * 函數名稱:free_vector
 * 功能:釋放一個長整型一維數組
 * 參數:nl:數組的行最低下標
 *       nh:數組的行最高下標
 * 無返回值
 */
void free_lvector(unsigned long *v,long nl,long nh)
{
	free((char*) (v+nl));
}

/*****************************************************************************
 * 函數名稱:free_vector
 * 功能:釋放一個雙精度一維數組
 * 參數:nl:數組的行最低下標
 *       nh:數組的行最高下標
 * 無返回值
 */
void free_dvector(double *v,long nl,long nh)
{
	free((char*) (v+nl));
}

/*****************************************************************************
 * 函數名稱:free_matrix
 * 功能:釋放一個實數二維數組(矩陣)
 * 參數:m:原數組地址
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 無返回值
 */
void free_matrix(float **m,long nrl,long nrh,long ncl,long nch)
{
	int i;

	for(i=nrh;i>=nrl;i--) free((char*) (m[i]+ncl));
	free((char*) (m+nrl));
}

/*****************************************************************************
 * 函數名稱:free_dmatrix
 * 功能:釋放一個雙精度二維數組(矩陣)
 * 參數:m:原數組地址
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 無返回值
 */
void free_dmatrix(double **m,long nrl,long nrh,long ncl,long nch)
{
	int i;

	for(i=nrh;i>=nrl;i--) free((char*) (m[i]+ncl));
	free((char*) (m+nrl));
}

/*****************************************************************************
 * 函數名稱:free_imatrix
 * 功能:釋放一個整型二維數組(矩陣)
 * 參數:m:原數組地址
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 無返回值
 */
void free_imatrix(int **m,long nrl,long nrh,long ncl,long nch)
{
	int i;

	for(i=nrh;i>=nrl;i--) free((char*) (m[i]+ncl));
	free((char*) (m+nrl));
}

/*****************************************************************************
 * 函數名稱:free_cmatrix
 * 功能:釋放一個無符號字符二維數組(矩陣)
 * 參數:m:原數組地址
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 無返回值
 */
void free_cmatrix(unsigned char **m,long nrl,long nrh,long ncl,long nch)
{
	int i;

	for(i=nrh;i>=nrl;i--) free((char*) (m[i]+ncl));
	free((char*) (m+nrl));
}

/*****************************************************************************
 * 函數名稱:free_submatrix
 * 功能:釋放一個子二維數組(矩陣)
 * 參數:b:原數組地址
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 無返回值
 */
void free_submatrix(float **b,long nrl,long nrh,long ncl,long nch)
{
	free((char*) (b+nrl));
}
/*****************************************************************************
 * 函數名稱:free_convert_matrix
 * 功能:釋放轉化后的二維數組(矩陣)
 * 參數:b:原數組地址
 *       nrl:數組的行最低下標
 *       nrh:數組的行最高下標
 *       ncl:數組的列最低下標
 *       nch:數組的列最高下標
 * 無返回值
 */
void free_convert_matrix(float **b,long nrl,long nrh,long ncl,long nch)
{
	free((char*) (b+nrl));
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲第一激情av| 日韩中文字幕一区二区三区| 日本一区二区三区久久久久久久久不| 欧美变态tickling挠脚心| 久久久欧美精品sm网站| 亚洲卡通欧美制服中文| 午夜精品国产更新| 成人禁用看黄a在线| 欧美日韩视频第一区| 日本一区二区成人在线| 亚洲成av人影院| 国产福利91精品一区二区三区| 在线看日韩精品电影| 国产无人区一区二区三区| 日韩精品三区四区| 精品国产亚洲一区二区三区在线观看| 自拍偷拍国产亚洲| 成人免费电影视频| 国产精品传媒入口麻豆| 国产一区二区不卡| 国产在线日韩欧美| 日韩av网站在线观看| 欧美日韩精品一区视频| 美女网站视频久久| 欧美—级在线免费片| 欧美色精品天天在线观看视频| 午夜视频在线观看一区二区 | 欧美日韩电影在线| 亚洲精品高清视频在线观看| 成人午夜电影网站| 国产三级一区二区| 成人黄页毛片网站| 国产精品―色哟哟| 91在线无精精品入口| 亚洲国产岛国毛片在线| 91亚洲精品久久久蜜桃| 亚洲美女在线国产| 欧美福利一区二区| 六月丁香婷婷久久| 久久久国产一区二区三区四区小说| 麻豆成人免费电影| 国产视频视频一区| 日本韩国一区二区| 久久精品国产免费| 久久精品人人爽人人爽| 91网站最新网址| 无码av免费一区二区三区试看| 精品日韩欧美一区二区| 天使萌一区二区三区免费观看| 在线观看免费视频综合| 日韩和欧美的一区| 国产精品久久久久影院亚瑟| 91九色最新地址| 韩日精品视频一区| 亚洲成人一二三| 久久久久久毛片| 制服丝袜亚洲精品中文字幕| 国产一区二区女| 肉色丝袜一区二区| 国产精品久久久久久久午夜片| 欧美高清视频www夜色资源网| 国产黄色成人av| 蜜臀av一区二区在线免费观看 | 中文字幕不卡在线播放| 色天使色偷偷av一区二区| 国产精品一卡二卡在线观看| 亚洲在线观看免费视频| 国产精品久久毛片a| 日韩欧美视频在线| 日本福利一区二区| 国产精品1024| 久久不见久久见中文字幕免费| 自拍av一区二区三区| 久久青草国产手机看片福利盒子 | 91色.com| 欧美日韩视频在线第一区| 欧美顶级少妇做爰| 日韩欧美卡一卡二| 国产精品久线在线观看| 一片黄亚洲嫩模| 美女脱光内衣内裤视频久久影院| 亚洲精品乱码久久久久久黑人| 亚洲欧美日韩小说| 一区二区欧美在线观看| 亚洲乱码国产乱码精品精小说| 亚洲黄色片在线观看| 亚洲第一二三四区| 久久精品国产亚洲aⅴ| 国产一区二区91| 91片在线免费观看| 欧美一三区三区四区免费在线看 | 色综合色狠狠综合色| 欧美性感一区二区三区| 久久日韩精品一区二区五区| 久久久久久久电影| 亚洲精品ww久久久久久p站| 日本不卡高清视频| 色综合久久88色综合天天免费| 欧美亚一区二区| 国产色产综合色产在线视频| 亚洲一区在线观看视频| 国精产品一区一区三区mba桃花| 成人av影院在线| 欧美精品一区二区三区四区 | 国产91清纯白嫩初高中在线观看| 91免费国产在线观看| 久久综合色一综合色88| 亚洲gay无套男同| 99久久99久久综合| 欧美激情自拍偷拍| 九九精品一区二区| 欧美一区二区三区视频免费| 蜜桃av噜噜一区| 欧美理论在线播放| 亚洲综合在线五月| 成人avav在线| 一区二区中文视频| 成人a级免费电影| 久久久久久久久久久久久女国产乱 | 欧美久久免费观看| 亚洲精品成人精品456| 91小视频在线免费看| 欧美成人猛片aaaaaaa| 日本伊人精品一区二区三区观看方式| 91香蕉视频污在线| 亚洲久草在线视频| 欧美亚洲国产一卡| 亚洲一区二区中文在线| 欧美日韩一级黄| 午夜精品福利一区二区三区av| 色猫猫国产区一区二在线视频| 亚洲欧洲中文日韩久久av乱码| 97se亚洲国产综合自在线观| 一区二区三区在线影院| 91精品午夜视频| 国产一区二区三区电影在线观看| 久久综合九色综合97婷婷女人 | 欧美国产日本视频| 成人午夜视频在线观看| 亚洲色图欧美在线| 欧美日韩一区在线| 毛片一区二区三区| 国产午夜亚洲精品羞羞网站| 丁香另类激情小说| 日韩高清在线不卡| 国产精品国产三级国产普通话蜜臀| 欧美主播一区二区三区美女| 久久er精品视频| 一区二区三区影院| 久久久精品tv| 91精品国产丝袜白色高跟鞋| 成人久久18免费网站麻豆 | 欧美一区二区女人| 欧美在线看片a免费观看| 国产精品亚洲综合一区在线观看| 亚洲国产欧美日韩另类综合| 久久久99精品免费观看不卡| 欧美乱熟臀69xxxxxx| 91在线高清观看| 波多野结衣在线aⅴ中文字幕不卡| 亚洲国产色一区| 洋洋av久久久久久久一区| 最新成人av在线| 国产精品嫩草99a| 亚洲国产精品成人综合| 久久久久亚洲蜜桃| 久久一夜天堂av一区二区三区| 91精品欧美福利在线观看| 欧美巨大另类极品videosbest| 欧美久久久久久久久中文字幕| 色香蕉久久蜜桃| 色综合天天综合网天天看片| 波波电影院一区二区三区| 成人一区二区三区视频在线观看| 国产一区二区视频在线播放| 国产麻豆视频精品| 成人免费高清在线观看| 97精品久久久午夜一区二区三区 | 亚洲欧美国产77777| 一区二区在线看| 亚洲成人自拍一区| 久久er99精品| 色综合久久久久综合体桃花网| 欧美日韩国产电影| 久久精品免视看| 伊人开心综合网| 日本免费新一区视频| 国产大片一区二区| 在线观看网站黄不卡| 欧美v亚洲v综合ⅴ国产v| 中文字幕在线不卡视频| 日本va欧美va瓶| 一本大道久久a久久精二百| 91精品国产美女浴室洗澡无遮挡| 26uuu国产电影一区二区| 亚洲最色的网站| av亚洲精华国产精华精| 国产欧美一二三区| 一区二区成人在线| 国产成人精品1024|