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

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

?? image.c

?? 基于主成份分析(PCA)的人臉特征識(shí)別核心源程序。
?? C
字號(hào):
/***
 **     libface - Library of face recognition and supporting algorithms
        Copyright (c) 2003 Stefan Farthofer

	This file is part of libface, which is

        free software; you can redistribute it and/or modify
        it under the terms of the GNU General Public License as published by
        the Free Software Foundation; either version 2 of the License, or
        (at your option) any later version.

        This program is distributed in the hope that it will be useful,
        but WITHOUT ANY WARRANTY; without even the implied warranty of
        MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        GNU General Public License for more details.

        You should have received a copy of the GNU General Public License
        along with this program; if not, write to the Free Software
        Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

	For further information seek us at http://sourceforge.net/projects/openbio/
**	or write an email to dimitri.pissarenko@gmx.net or farthofer@chello.at.
***/
/* implementation of image handling functions */

#include <malloc.h>
#include <memory.h>
#include <IL/IL.h>
#include <IL/ILU.h>
#include "frbase.h"
#include "fr.h"

/* maybe put this in another header if we accumulate enough util functions */
int frutilEvalILErrors(void);

int frImgLoadFile(char* filename, FRimage* image) {
	ILuint img;
	int err;

	/* load image with IL */
	ilGenImages(1, &img);
	ilBindImage(img);
	ilLoadImage(filename);
	ilConvertImage(IL_LUMINANCE, IL_FLOAT);

	/* when loaded ok copy bound image to image struct */
	if ((err = frutilEvalILErrors()) == FR_OK) {
		err = frImgLoadBound(image);
	}

	ilDeleteImages(1, &img);
	return err;
}

int frImgSaveFile(char* filename, FRimage* image) {
	ILuint img;
	int err;

	ilGenImages(1, &img);
	ilBindImage(img);
	ilTexImage(image->width,image->height,1,1,IL_LUMINANCE, IL_FLOAT, image->imgdata);
	ilConvertImage(IL_LUMINANCE, IL_UNSIGNED_BYTE);
	ilSaveImage(filename);
	ilDeleteImages(1, &img);
	if ((err = frutilEvalILErrors()) != FR_OK)
		return err;
	return FR_OK;
}

int frImgLoadMem(void* mem, size_t sz, FRimage* image, ILenum type) {
	ILuint img;
	int err;

	/* load image with IL */
	ilGenImages(1, &img);
	ilBindImage(img);
	ilLoadL(type,mem,(ILuint)sz);
	ilConvertImage(IL_LUMINANCE, IL_FLOAT);

	/* when loaded ok copy bound image to image struct */
	if ((err = frutilEvalILErrors()) == FR_OK) {
		err = frImgLoadBound(image);
	}

	ilDeleteImages(1, &img);
	return err;
}

/* used to load real RAW images with 1 Byte per Pixel, don't confuse with
   IL_RAW since this format does expect a header with the width/height of
   the image to be loaded.
 */
int frImgLoadRaw(void* mem, int width, int height, FRimage* image) {
	ILuint img;
	int err = FR_OK;

	ilGenImages(1, &img);
	ilBindImage(img);
	ilTexImage(width, height, 1, 1, IL_LUMINANCE, IL_UNSIGNED_BYTE, mem);
	ilConvertImage(IL_LUMINANCE, IL_FLOAT);

	/* check if there were errors, then free IL image, set struct elements and return */
	err = frutilEvalILErrors();

	ilDeleteImages(1, &img);
	image->width = width;
	image->height = height;
	return FR_OK;
}

int frImgGetILImg(ILuint* imgnr, FRimage* image) {
	int err;

	ilGenImages(1, imgnr);
	ilBindImage(*imgnr);
	ilTexImage(image->width,image->height,1,1,IL_LUMINANCE, IL_FLOAT, image->imgdata);
	ilConvertImage(IL_LUMINANCE, IL_UNSIGNED_BYTE);

	/* if anything went wrong set imgnr to 0 and return with error */
	if ((err = frutilEvalILErrors()) != FR_OK) {
		ilDeleteImages(1, imgnr);
		*imgnr = 0;
		return err;
	}
	return FR_OK;
}

int frImgGetILImgFloat(ILuint* imgnr, FRimage* image) {
	int err;

	ilGenImages(1, imgnr);
	ilBindImage(*imgnr);
	ilTexImage(image->width,image->height,1,1,IL_LUMINANCE, IL_FLOAT, image->imgdata);

	/* if anything went wrong set imgnr to 0 and return with error */
	if ((err = frutilEvalILErrors()) != FR_OK) {
		ilDeleteImages(1, imgnr);
		*imgnr = 0;
		return err;
	}
	return FR_OK;
}

void frImgFree(FRimage* image) {
	if (image->imgdata != NULL) {
		free(image->imgdata);
	}
}

/* allocates an image struct and loads the currently bound IL image */
int frImgLoadBound(FRimage* image) {
	size_t sz;

	image->width = ilGetInteger(IL_IMAGE_WIDTH);
	image->height = ilGetInteger(IL_IMAGE_HEIGHT);
	sz = sizeof(float) * image->width * image->height;
	image->imgdata = (float*) malloc(sz);
	if (image->imgdata == NULL) return FR_ERR_NOMEM;
	memcpy((void*)image->imgdata, ilGetData(), sz);
	return FR_OK;
}

int frImgResize(FRimage* dst, FRimage* src, unsigned int w, unsigned int h) {
	ILuint img;
	int err;

	if ((err = frImgGetILImgFloat(&img, src))) return err;
	iluScale(w,h,1);
	if (frutilEvalILErrors()) return FR_ERR_IL;
	return frImgLoadBound(dst);
}

int frutilEvalILErrors(void) {
	ILenum err;
	int nr = 0;

	/* for now we don't do any logging, this should change in the future */
	while ((err = ilGetError()) != IL_NO_ERROR) {
		/* printf("%s %s", prefix, iluErrorString(err)); */
		nr++;
	}
	/* just say IL error for now */
	if (nr > 0)
		return FR_ERR_IL;
	else
		return FR_OK;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
老司机一区二区| 91在线码无精品| 亚洲男同1069视频| 精品少妇一区二区三区在线播放| 99精品欧美一区二区三区小说 | 国产精品18久久久久久vr| 亚洲免费在线视频一区 二区| 精品粉嫩超白一线天av| 91豆麻精品91久久久久久| 国产成人高清视频| 久久精品国产精品亚洲精品 | 日日欢夜夜爽一区| 中文字幕在线一区免费| 日韩精品最新网址| 欧美视频在线播放| 91视频在线看| 成人一道本在线| 国产一区二区成人久久免费影院| 午夜不卡av在线| 亚洲高清久久久| 亚洲黄色免费网站| 亚洲三级电影网站| 国产精品国产a级| 欧美国产一区视频在线观看| 精品国产髙清在线看国产毛片| 欧美天天综合网| 欧美视频在线观看一区二区| 色综合久久久网| 成人美女视频在线看| 国产成人精品一区二区三区四区 | 中文字幕一区二区在线观看| 久久久国产精品午夜一区ai换脸| 日韩精品一区国产麻豆| 欧美一激情一区二区三区| 欧美三级韩国三级日本一级| 在线精品视频小说1| 91免费在线看| 日本电影亚洲天堂一区| 色爱区综合激月婷婷| 色婷婷综合激情| 色哟哟精品一区| 欧美伊人久久大香线蕉综合69| 91蝌蚪porny成人天涯| 色综合色综合色综合| 91精彩视频在线观看| 在线视频国产一区| 欧美日韩国产在线播放网站| 国产精品午夜春色av| 国产亚洲欧美激情| 国产精品久久久久久久岛一牛影视 | 欧美一区二区在线观看| 日韩午夜精品视频| 日韩欧美亚洲国产另类| 久久久一区二区三区| 国产日韩精品一区二区三区| 国产精品你懂的在线| 18欧美亚洲精品| 亚洲国产精品久久久男人的天堂| 丝袜美腿亚洲综合| 免费在线看一区| 国产精品一区二区三区四区| 成人做爰69片免费看网站| 91免费看`日韩一区二区| 欧美私人免费视频| 精品毛片乱码1区2区3区| 国产免费成人在线视频| 一区二区高清视频在线观看| 欧美aaaaa成人免费观看视频| 国产精品综合久久| 色综合激情五月| 日韩色视频在线观看| 久久精品亚洲精品国产欧美kt∨ | 精品国产区一区| 国产精品白丝在线| 亚洲a一区二区| 国产成人欧美日韩在线电影| 91日韩一区二区三区| 日韩一二三区视频| 亚洲欧美综合网| 日本在线不卡视频| fc2成人免费人成在线观看播放 | 午夜精品成人在线视频| 国产一区二三区| 日本乱人伦aⅴ精品| 日韩欧美一区二区免费| 日韩伦理电影网| 麻豆国产精品一区二区三区| 99视频有精品| 欧美精品一区男女天堂| 亚洲综合自拍偷拍| 国产精品综合二区| 91麻豆精品国产无毒不卡在线观看| 欧美激情中文不卡| 青椒成人免费视频| 色拍拍在线精品视频8848| 亚洲精品在线电影| 日韩精品国产精品| 91看片淫黄大片一级在线观看| 精品电影一区二区| 婷婷中文字幕综合| 国产农村妇女毛片精品久久麻豆 | 国产精品久久久久影院亚瑟| 日本亚洲欧美天堂免费| 日本道在线观看一区二区| 国产清纯白嫩初高生在线观看91 | 国产99久久久国产精品潘金网站| 欧美日韩成人一区二区| 最新热久久免费视频| 精品一区二区三区在线播放视频 | 欧美日韩免费视频| 国产精品国产三级国产aⅴ中文| 久久精品国产澳门| 在线不卡免费欧美| 亚洲综合色自拍一区| 波多野洁衣一区| 国产欧美1区2区3区| 久久99久国产精品黄毛片色诱| 欧美丝袜丝交足nylons图片| 亚洲人成网站精品片在线观看| 国产成人自拍高清视频在线免费播放| 欧美一区二区精品久久911| 亚洲电影在线播放| 在线观看亚洲精品| 艳妇臀荡乳欲伦亚洲一区| 不卡视频一二三| 国产精品欧美久久久久无广告| 国内成人自拍视频| 26uuu另类欧美| 精品一区免费av| 精品电影一区二区| 国产精品综合在线视频| 精品福利视频一区二区三区| 蜜臀av一区二区在线观看| 这里只有精品电影| 日本成人中文字幕在线视频| 在线不卡免费av| 婷婷夜色潮精品综合在线| 欧美日韩一区二区三区在线| 亚洲国产欧美日韩另类综合| 在线免费观看日本欧美| 亚洲第一搞黄网站| 69av一区二区三区| 久热成人在线视频| 26uuu国产一区二区三区| 国内偷窥港台综合视频在线播放| 精品88久久久久88久久久 | 欧美性猛交一区二区三区精品| 一区二区三区四区在线免费观看 | 欧美亚洲高清一区| 天天色综合成人网| 欧美一级免费观看| 狠狠色丁香婷婷综合| 国产欧美视频一区二区| 99精品视频在线观看免费| 亚洲尤物视频在线| 91精品国产黑色紧身裤美女| 激情综合色综合久久综合| 国产人伦精品一区二区| 日本福利一区二区| 日韩av电影一区| 国产欧美一区二区精品忘忧草| av在线播放不卡| 亚洲国产日韩一级| 精品1区2区在线观看| 成人18精品视频| 色偷偷久久人人79超碰人人澡| 亚洲一区二区三区视频在线播放 | 欧美一区二区在线视频| 国产一区 二区 三区一级| 亚洲欧美国产三级| 欧美精品久久久久久久久老牛影院| 精品在线播放免费| 亚洲欧美日韩久久| 欧美一级国产精品| 成人黄色av网站在线| 丝袜诱惑亚洲看片| 国产欧美日韩视频在线观看| 欧美午夜一区二区三区| 国产综合久久久久久久久久久久| 国产精品国产三级国产有无不卡 | 欧美极品xxx| 欧美人xxxx| 成年人网站91| 人人狠狠综合久久亚洲| 欧美韩国日本一区| 欧美一二三四在线| 91视频国产资源| 国产综合久久久久久鬼色| 亚洲综合视频网| 国产欧美视频在线观看| 911国产精品| 91麻豆免费看| 国产成人啪午夜精品网站男同| 亚洲风情在线资源站| 国产精品久久免费看| 精品日本一线二线三线不卡| 在线观看不卡一区| av在线播放不卡| 韩国欧美国产1区| 日韩精品欧美精品|