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

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

?? traits.c

?? 基于主成份分析(PCA)的人臉特征識別核心源程序。
?? C
字號:
/***
 **     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.
***/

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

/* prototypes for utility functions */
void frutilFreeTraitArray(FRrecognitionParameters *gParms, FRimageTrait* traits, unsigned int nrTraits);


/* calculate traits */
int frTraitsCalc(FRrecognitionParameters* gParms, FRimage* rawImage, FRimageTrait** traits) {
	unsigned int i;
	int err = FR_OK;
	FRrecoAlgo* algo;
	FRimage image;

	/* TODO: call face finder and resize found face properly */
	/* for now, just resize */
	if (frImgResize(&image, rawImage, gParms->width, gParms->height)) return FR_ERR_IL;


	*traits = (FRimageTrait*) malloc(sizeof(FRimageTrait)*gParms->nrAlgorithms);
	if (traits == NULL) return FR_ERR_NOMEM;

	for (i=0; err == FR_OK && i < gParms->nrAlgorithms; i++) {
		algo = frGetRecoAlgoById(gParms->algorithms[i].algorithmType);
		err = algo->computeTrait(gParms, gParms->algorithms[i].data, &image, &(*traits)->data);
	}

	if (err != FR_OK) {
		frutilFreeTraitArray(gParms, *traits, i-1);
		*traits = NULL;
	}
	return err;
}

/* traits serialize */
size_t frTraitsGetSize(FRrecognitionParameters* gParms, FRimageTrait* traits) {
	unsigned int i;
	size_t sz=0;
	FRrecoAlgo* algo;

	for (i=0; i < gParms->nrAlgorithms; i++) {
		algo = frGetRecoAlgoById(gParms->algorithms[i].algorithmType);
		sz = sz + algo->getTraitSize(gParms, gParms->algorithms[i].data, traits[i].data);
	}
	return sz;
}

void frTraitsFree(FRrecognitionParameters* gParms, FRimageTrait** traits) {
	frutilFreeTraitArray(gParms, *traits, gParms->nrAlgorithms);
	*traits = NULL;
}

int frTraitsSerialize(FRrecognitionParameters* gParms, BYTE** mem, size_t maxsz, FRimageTrait** traits, BYTE direction) {
	BYTE* begin = *mem;
	unsigned int i;
	int err = FR_OK;
	FRrecoAlgo* algo;

	/* sanity check size */
	if (direction == FR_OUT && maxsz < frTraitsGetSize(gParms, *traits))
		return FR_ERR_ALLOCMORE;

	/* if we are reading from serialized form, allocate memory for our structure array */
	if (direction == FR_IN) {
		*traits = (FRimageTrait*) malloc(sizeof(FRimageTrait)*gParms->nrAlgorithms);
		if (*traits == NULL) return FR_ERR_NOMEM;
	}

	/* write/read data */
	for (i=0; err == FR_OK && i < gParms->nrAlgorithms; i++) {
		algo = frGetRecoAlgoById(gParms->algorithms[i].algorithmType);
		err = algo->serializeTrait(gParms, gParms->algorithms[i].data, &(*traits)[i].data, mem, maxsz-(*mem-begin),direction);
	}

	if (err != FR_OK && direction == FR_IN)
		frutilFreeTraitArray(gParms, *traits, i-1);

	return err;
}

int frTraitsSaveFile(FRrecognitionParameters* gParms, FILE* fileHandle, FRimageTrait* traits) {
	BYTE* buffer, * temp;
	size_t sz;
	int err;

	/* copy data to buffer */
	sz = frTraitsGetSize(gParms, traits);
	temp = buffer = (BYTE*) malloc(sz);
	if (buffer == NULL) return FR_ERR_NOMEM;
	err = frTraitsSerialize(gParms, &temp, sz, &traits, FR_OUT);

	/* write size and data */
	if (err == FR_OK && !fwrite(&sz, sizeof(sz),1, fileHandle)) err = FR_ERR_FILE;
	if (err == FR_OK && !fwrite(buffer,sz, 1, fileHandle)) err = FR_ERR_FILE;

	free(buffer);
	return err;
}

int frTraitsLoadFile(FRrecognitionParameters* gParms, FILE* fileHandle, FRimageTrait** traits) {
	BYTE* buffer, * temp;
	size_t sz;
	int err = FR_OK;

	/* read size */
	if (!fread(&sz, sizeof(sz), 1, fileHandle)) return FR_ERR_FILE;

	/* allocate buffer */
	temp = buffer = (BYTE*) malloc(sz);
	if (buffer == NULL) return FR_ERR_NOMEM;

	/* read serialized data */
	if (!fread(buffer, sz, 1, fileHandle)) err = FR_ERR_FILE;

	/* deserialize */
	if (err == FR_OK) err = frTraitsSerialize(gParms, &temp, sz, traits, FR_IN);
	free(buffer);
	return err;
}

void frutilFreeTraitArray(FRrecognitionParameters *gParms, FRimageTrait* traits, unsigned int nrTraits) {
	FRrecoAlgo* algo;
	unsigned int i;

	for (i=0; i < nrTraits; i++) {
		algo = frGetRecoAlgoById(gParms->algorithms[i].algorithmType);
		algo->freeTrait(gParms, gParms->algorithms[i].data, &traits[i].data);
	}
	free(traits);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美视频在线一区| 亚洲最大成人综合| 亚洲免费电影在线| 九一久久久久久| 欧美在线观看一二区| 国产精品88888| 欧美日韩中文精品| 亚洲欧美国产高清| 国产成人丝袜美腿| 日韩一二三区视频| 欧美大片在线观看一区二区| 亚洲久草在线视频| 亚洲成av人片一区二区三区| 午夜精品福利在线| 91免费看片在线观看| 欧美极品另类videosde| 国产精品色噜噜| 一区二区三区丝袜| 蜜臀av性久久久久蜜臀av麻豆| 韩国在线一区二区| 在线综合+亚洲+欧美中文字幕| 亚洲色欲色欲www| 婷婷综合久久一区二区三区| 91成人免费在线视频| 亚洲欧洲99久久| 日韩av电影免费观看高清完整版 | 国产一区日韩二区欧美三区| 风间由美中文字幕在线看视频国产欧美| 成人sese在线| 日本一区二区三区四区在线视频| 国内精品视频666| 99久久99精品久久久久久| 欧美乱妇15p| 国产嫩草影院久久久久| 亚洲成人免费av| 成人精品在线视频观看| 国产亚洲1区2区3区| 亚洲一二三区不卡| 欧美色电影在线| 丝袜诱惑制服诱惑色一区在线观看 | 在线观看不卡视频| 精品伦理精品一区| 在线视频国内自拍亚洲视频| 一区二区中文字幕在线| 91麻豆高清视频| 精品国免费一区二区三区| 久久国产综合精品| 精品视频999| 美女一区二区在线观看| 久久久久久99久久久精品网站| 国内精品国产成人国产三级粉色 | 亚洲一区二区欧美日韩| 6080午夜不卡| 一区二区三区久久| 国产成a人无v码亚洲福利| 国产精品国产三级国产aⅴ入口 | 成人永久免费视频| 一区二区三区中文字幕电影| 国产**成人网毛片九色 | 91麻豆精品久久久久蜜臀| 激情文学综合插| 亚洲人成影院在线观看| 国产精品一区一区| 国产精品灌醉下药二区| 国产成+人+日韩+欧美+亚洲| 亚洲一区二区三区激情| 精品久久久久99| 91在线精品一区二区| 免费成人av在线播放| 中文字幕一区二区三区在线不卡| 国产成人一区在线| 久久久久久久电影| 丁香亚洲综合激情啪啪综合| 国产综合色精品一区二区三区| 欧美日韩专区在线| 国产精品99久久不卡二区| 亚洲午夜日本在线观看| 中文字幕av免费专区久久| 91.麻豆视频| 日韩精品一二区| 91精品国产综合久久蜜臀| 成人免费视频播放| 免费高清视频精品| 一区二区三区四区不卡视频| 欧美在线播放高清精品| 亚洲永久免费av| 亚洲国产精品成人久久综合一区| 欧美老人xxxx18| 日本道色综合久久| 成人性生交大片免费看中文| 亚洲精品视频在线| 中文字幕第一区二区| 91色在线porny| 亚洲在线观看免费视频| 日韩一级高清毛片| 国产a区久久久| 中文字幕在线一区二区三区| 色吊一区二区三区 | 久久国产日韩欧美精品| 国产日产欧美精品一区二区三区| www.av亚洲| 亚洲18影院在线观看| 1区2区3区欧美| 欧美疯狂做受xxxx富婆| 欧美在线免费视屏| 日本视频一区二区三区| 亚洲成人福利片| 亚洲黄色性网站| 伊人色综合久久天天| 日韩一区二区三区三四区视频在线观看| 极品少妇xxxx偷拍精品少妇| 国产精品剧情在线亚洲| 国产日韩一级二级三级| 久久先锋影音av| 欧美这里有精品| 日本韩国欧美国产| 26uuu精品一区二区三区四区在线| 成人深夜在线观看| 丰满放荡岳乱妇91ww| 午夜成人免费视频| 日本vs亚洲vs韩国一区三区二区| 中文字幕不卡在线播放| 亚洲欧洲日本在线| 中文字幕综合网| 亚洲一区二区在线播放相泽 | 美腿丝袜一区二区三区| 久久精品国产一区二区三| 国产一区二区三区日韩| 高清在线不卡av| 蜜桃视频免费观看一区| 亚洲欧美电影一区二区| 亚洲国产日韩一区二区| 奇米一区二区三区| 激情综合色综合久久| 亚洲国产一区在线观看| 中文字幕中文字幕一区| 亚洲国产精品麻豆| 久久精品国产亚洲a| 亚洲一卡二卡三卡四卡| 免费视频最近日韩| 五月婷婷另类国产| 一个色妞综合视频在线观看| 国产精品污网站| 国产成人精品亚洲午夜麻豆| 成人99免费视频| 成人免费视频视频在线观看免费| 91美女在线看| 欧美不卡在线视频| 亚洲欧美激情视频在线观看一区二区三区 | 国产在线播放一区二区三区| 日本亚洲电影天堂| 午夜精品久久久久影视| 一区二区三区四区蜜桃| 樱桃视频在线观看一区| 伊人婷婷欧美激情| 国产一区中文字幕| 国产成人8x视频一区二区| 欧美优质美女网站| 欧美日韩国产首页| 国产欧美一区二区精品秋霞影院| 亚洲国产精品一区二区尤物区| 精品中文av资源站在线观看| 色综合 综合色| 欧美又粗又大又爽| 久久麻豆一区二区| 免费人成网站在线观看欧美高清| 97se亚洲国产综合自在线不卡| 欧美第一区第二区| 天堂久久一区二区三区| 国产成人av电影在线| 日韩欧美国产综合| 精品日本一线二线三线不卡| 亚洲综合丝袜美腿| av激情综合网| 欧美天堂亚洲电影院在线播放| 国产午夜一区二区三区| 蜜桃传媒麻豆第一区在线观看| 在线欧美日韩精品| 最新国产成人在线观看| 国产成人在线网站| 欧美电影免费观看高清完整版在线 | 日韩电影一二三区| 精品中文字幕一区二区小辣椒| 高清不卡在线观看av| 精品国产人成亚洲区| 国产精品久久久久久久午夜片 | 奇米精品一区二区三区在线观看| 一道本成人在线| 亚洲日本一区二区| 成人黄色电影在线 | 一本色道久久加勒比精品| 国产午夜亚洲精品羞羞网站| 国产精品盗摄一区二区三区| 亚洲第一狼人社区| 日本电影欧美片| 亚洲精品第一国产综合野| 久久精品72免费观看| 日韩精品自拍偷拍| 久久精品国产亚洲aⅴ | 91麻豆精品91久久久久同性|