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

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

?? nrutil.cpp

?? HMM的算法適合應用于圖像識別
?? 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一区二区三区免费野_久草精品视频
精品国产乱码久久久久久浪潮| 亚洲人被黑人高潮完整版| 国产精品美女视频| 亚洲国产一区二区视频| 国产91富婆露脸刺激对白| 777久久久精品| 一区二区三区精品久久久| 激情综合色综合久久综合| 欧美视频精品在线观看| 国产精品久久久久久户外露出 | wwwwww.欧美系列| 一区二区在线免费| 国产精品911| 日韩精品一区二区三区老鸭窝| 亚洲一线二线三线久久久| 粉嫩av一区二区三区| 精品久久人人做人人爰| 天堂精品中文字幕在线| 91国产成人在线| 国产精品素人视频| 国产高清不卡一区| 2024国产精品视频| 九色porny丨国产精品| 欧美一区二区三区视频免费播放 | 午夜精品久久久久久| 91网站最新地址| 国产精品毛片久久久久久| 国产一区视频导航| 久久久99久久精品欧美| 国产精品综合二区| 国产欧美日韩在线观看| 国产激情视频一区二区三区欧美| 精品国产凹凸成av人导航| 久久国产精品第一页| 日韩欧美的一区二区| 看片网站欧美日韩| 久久夜色精品国产噜噜av| 经典三级在线一区| 国产目拍亚洲精品99久久精品| 六月丁香婷婷色狠狠久久| 亚洲精品一区二区三区蜜桃下载| 韩国女主播成人在线观看| 久久综合五月天婷婷伊人| 国产一区二区精品久久99| 国产欧美日韩精品在线| 99视频精品全部免费在线| 成人欧美一区二区三区黑人麻豆| 色系网站成人免费| 亚洲国产精品久久不卡毛片| 777奇米四色成人影色区| 精品一区二区三区久久久| 欧美激情综合五月色丁香| 9i在线看片成人免费| 亚洲综合视频网| 欧美电视剧在线看免费| 国产成人亚洲综合a∨婷婷| 国产精品不卡在线| 欧美日韩性生活| 国产一区二区三区综合| 中文字幕亚洲一区二区av在线 | hitomi一区二区三区精品| 亚洲一区在线看| 日韩欧美国产麻豆| 99久久婷婷国产综合精品电影| 一区二区免费在线| 久久婷婷久久一区二区三区| 91啪亚洲精品| 久久国产综合精品| 亚洲摸摸操操av| 日韩三区在线观看| 91丝袜高跟美女视频| 日本麻豆一区二区三区视频| 国产精品国产三级国产普通话99| 欧美日产国产精品| 成人小视频在线| 日本 国产 欧美色综合| 国产精品福利电影一区二区三区四区| 欧美另类久久久品| 成人精品免费看| 欧美aaa在线| 亚洲永久免费av| 日本一区二区视频在线观看| 91国产福利在线| 国产成人亚洲精品狼色在线| 亚洲成人在线免费| 中文字幕中文字幕在线一区| 日韩欧美一区二区不卡| 日本高清不卡在线观看| 国产精品综合一区二区| 蜜乳av一区二区三区| 亚洲在线成人精品| 中文字幕欧美三区| 久久综合资源网| 欧美一级片在线观看| 欧美四级电影网| 一本色道a无线码一区v| 国产999精品久久久久久绿帽| 老司机精品视频导航| 亚州成人在线电影| 亚洲精品美国一| 亚洲欧美在线视频| 国产农村妇女毛片精品久久麻豆 | 裸体歌舞表演一区二区| 天天操天天色综合| 一区二区三区中文在线| 国产精品成人免费在线| 久久精品一区二区三区四区| 日韩精品中文字幕一区二区三区| 欧美日韩视频在线第一区| 欧美优质美女网站| 在线视频你懂得一区| 99久久免费精品| 99国产精品久久久久久久久久 | 国产曰批免费观看久久久| 日本免费新一区视频| 免费观看在线综合| 精品一区二区影视| 黄页网站大全一区二区| 韩国av一区二区| 国产福利一区二区三区视频| 懂色av一区二区在线播放| 国产成人精品三级麻豆| 国产经典欧美精品| 国产激情91久久精品导航| 成人av一区二区三区| 91亚洲资源网| 欧洲精品在线观看| 7777女厕盗摄久久久| 日韩欧美国产系列| 久久精品亚洲一区二区三区浴池| 国产欧美日本一区视频| 中文字幕五月欧美| 亚洲国产日韩精品| 免费的国产精品| 粉嫩一区二区三区在线看| kk眼镜猥琐国模调教系列一区二区| 97久久超碰国产精品| 欧美在线一区二区三区| 在线电影院国产精品| 久久亚洲综合色| 亚洲视频在线一区| 日韩精品1区2区3区| 精品亚洲porn| 色婷婷综合久久久久中文 | 日本精品视频一区二区| 欧美日韩一区小说| 久久久三级国产网站| ...xxx性欧美| 蜜臂av日日欢夜夜爽一区| 成人一区在线看| 欧美日韩精品电影| 国产午夜精品久久| 性做久久久久久久免费看| 国产成人午夜电影网| 色婷婷久久久综合中文字幕| 日韩午夜在线观看视频| 136国产福利精品导航| 久久99精品久久只有精品| 99vv1com这只有精品| 欧美电影精品一区二区| 一区二区久久久久久| 国产一区欧美二区| 欧美激情在线看| 亚洲mv在线观看| 成人动漫视频在线| 日韩三级电影网址| 亚洲午夜免费电影| 成人精品小蝌蚪| 精品国产乱码久久| 午夜精品成人在线视频| 91日韩精品一区| 国产欧美va欧美不卡在线| 蜜臀精品久久久久久蜜臀| 一本色道久久综合亚洲aⅴ蜜桃| 久久久国产一区二区三区四区小说| 午夜国产精品影院在线观看| yourporn久久国产精品| 国产人成一区二区三区影院| 强制捆绑调教一区二区| 欧美色偷偷大香| 亚洲卡通动漫在线| 99久久99久久久精品齐齐| 国产午夜精品在线观看| 国产一区二区成人久久免费影院| 欧美丰满高潮xxxx喷水动漫| 亚洲最大成人网4388xx| 99久久99久久精品国产片果冻| 国产视频911| 国产高清在线观看免费不卡| 精品国产99国产精品| 蜜臀av性久久久久蜜臀aⅴ | 人禽交欧美网站| 在线看一区二区| 亚洲伊人色欲综合网| 91国产免费观看| 亚洲二区在线观看| 这里只有精品99re| 日韩成人一区二区三区在线观看| 欧美日韩第一区日日骚| 日韩制服丝袜先锋影音|