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

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

?? writefeatures.c

?? KLT: An Implementation of the Kanade-Lucas-Tomasi Feature Tracker KLT: An Implementation of the
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/********************************************************************* * writeFeatures.c * ********************************************************************* *//* Standard includes */#include <assert.h>#include <ctype.h>		/* isdigit() */#include <stdio.h>		/* sprintf(), fprintf(), sscanf(), fscanf() */#include <stdlib.h>		/* malloc() */#include <string.h>		/* memcpy(), strcmp() *//* Our includes */#include "base.h"#include "error.h"#include "pnmio.h"		/* ppmWriteFileRGB() */#include "klt.h"#define BINHEADERLENGTH	6extern int KLT_verbose;typedef enum {FEATURE_LIST, FEATURE_HISTORY, FEATURE_TABLE} structureType;static char warning_line[] = "!!! Warning:  This is a KLT data file.  "                             "Do not modify below this line !!!\n";static char binheader_fl[BINHEADERLENGTH+1] = "KLTFL1";static char binheader_fh[BINHEADERLENGTH+1] = "KLTFH1";static char binheader_ft[BINHEADERLENGTH+1] = "KLTFT1";/********************************************************************* * KLTWriteFeatureListToPPM */void KLTWriteFeatureListToPPM(  KLT_FeatureList featurelist,  KLT_PixelType *greyimg,  int ncols,  int nrows,  char *filename){  int nbytes = ncols * nrows * sizeof(char);  uchar *redimg, *grnimg, *bluimg;  int offset;  int x, y, xx, yy;  int i;	  if (KLT_verbose >= 1)     fprintf(stderr, "(KLT) Writing %d features to PPM file: '%s'\n",             KLTCountRemainingFeatures(featurelist), filename);  /* Allocate memory for component images */  redimg = (uchar *)  malloc(nbytes);  grnimg = (uchar *)  malloc(nbytes);  bluimg = (uchar *)  malloc(nbytes);  if (redimg == NULL || grnimg == NULL || bluimg == NULL)    KLTError("(KLTWriteFeaturesToPPM)  Out of memory\n");  /* Copy grey image to component images */  if (sizeof(KLT_PixelType) != 1)    KLTWarning("(KLTWriteFeaturesToPPM)  KLT_PixelType is not uchar");  memcpy(redimg, greyimg, nbytes);  memcpy(grnimg, greyimg, nbytes);  memcpy(bluimg, greyimg, nbytes);	  /* Overlay features in red */  for (i = 0 ; i < featurelist->nFeatures ; i++)    if (featurelist->feature[i]->val >= 0)  {      x = (int) (featurelist->feature[i]->x + 0.5);      y = (int) (featurelist->feature[i]->y + 0.5);      for (yy = y - 1 ; yy <= y + 1 ; yy++)        for (xx = x - 1 ; xx <= x + 1 ; xx++)            if (xx >= 0 && yy >= 0 && xx < ncols && yy < nrows)  {            offset = yy * ncols + xx;            *(redimg + offset) = 255;            *(grnimg + offset) = 0;            *(bluimg + offset) = 0;          }    }	  /* Write to PPM file */  ppmWriteFileRGB(filename, redimg, grnimg, bluimg, ncols, nrows);  /* Free memory */  free(redimg);  free(grnimg);  free(bluimg);}static FILE* _printSetupTxt(  char *fname, 	/* Input: filename, or NULL for stderr */  char *fmt,	/* Input: format (e.g., %5.1f or %3d) */  char *format,	/* Output: format (e.g., (%5.1f,%5.1f)=%3d) */  char *type)	/* Output: either 'f' or 'd', based on input format */{  FILE *fp;  const int val_width = 5;  int i;  /* Either open file or use stderr */  if (fname == NULL)  fp = stderr;  else  fp = fopen(fname, "wb");  if (fp == NULL)    KLTError("(KLTWriteFeatures) "             "Can't open file '%s' for writing\n", fname);  /* Parse format */  if (fmt[0] != '%')    KLTError("(KLTWriteFeatures) Bad Format: %s\n", fmt);  i = 0;  while (fmt[i] != '\0') i++;  *type = fmt[i-1];  if (*type != 'f' && *type != 'd')    KLTError("(KLTWriteFeatures) Format must end in 'f' or 'd'.");  /* Construct feature format */  sprintf(format, "(%s,%s)=%%%dd ", fmt, fmt, val_width);       return fp;}static FILE* _printSetupBin(  char *fname) 	/* Input: filename */{  FILE *fp;  if (fname == NULL)     KLTError("(KLTWriteFeatures) Can't write binary data to stderr");  fp = fopen(fname, "wb");  if (fp == NULL)    KLTError("(KLTWriteFeatures) "             "Can't open file '%s' for writing", fname);  return fp;}static void _printNhyphens(  FILE *fp,  int n){  int i;  for (i = 0 ; i < n ; i++)    fprintf(fp, "-");}static void _printInteger(  FILE *fp,  int integer,  int width){  char fmt[80];  sprintf(fmt, "%%%dd", width);  fprintf(fp, fmt, integer);}static KLT_BOOL _isCharInString(  char c,  char *str){  int width = strlen(str);  int i;  for (i = 0 ; i < width ; i++)    if (c == str[i])  return TRUE;  return FALSE;}/********************************************************************* * _findStringWidth * * Calculates the length of a string after expansion.  E.g., the * length of "(%6.1f)" is eight -- six for the floating-point number, * and two for the parentheses. */static int _findStringWidth(  char *str){  int width = 0;  int add;  int maxi = strlen(str) - 1;  int i = 0;	  while (str[i] != '\0')  {    if (str[i] == '%')  {      if (isdigit(str[i+1]))  {        sscanf(str+i+1, "%d", &add);        width += add;        i += 2;        while (!_isCharInString(str[i], "diouxefgn"))  {          i++;          if (i > maxi)            KLTError("(_findStringWidth) Can't determine length "                     "of string '%s'", str);        }        i++;      } else if (str[i+1] == 'c')  {        width++;        i += 2;      } else         KLTError("(_findStringWidth) Can't determine length "                 "of string '%s'", str);    } else  {      i++;      width++;    }  }	  return width;}static void _printHeader(  FILE *fp,  char *format,  structureType id,  int nFrames,  int nFeatures){  int width = _findStringWidth(format);  int i;	  assert(id == FEATURE_LIST || id == FEATURE_HISTORY || id == FEATURE_TABLE);  if (fp != stderr)  {    fprintf(fp, "Feel free to place comments here.\n\n\n");    fprintf(fp, "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n");    fprintf(fp, warning_line);    fprintf(fp, "\n");  }  fprintf(fp, "------------------------------\n");  switch (id)  {     case FEATURE_LIST: fprintf(fp, "KLT Feature List\n");    break;     case FEATURE_HISTORY: fprintf(fp, "KLT Feature History\n"); break;     case FEATURE_TABLE: fprintf(fp, "KLT Feature Table\n");   break;  }  fprintf(fp, "------------------------------\n\n");  switch (id)  {     case FEATURE_LIST: fprintf(fp, "nFeatures = %d\n\n", nFeatures);    break;     case FEATURE_HISTORY: fprintf(fp, "nFrames = %d\n\n", nFrames); break;     case FEATURE_TABLE: fprintf(fp, "nFrames = %d, nFeatures = %d\n\n",                                 nFrames, nFeatures);   break;  }  switch (id)  {     case FEATURE_LIST: fprintf(fp, "feature | (x,y)=val\n");       fprintf(fp, "--------+-");       _printNhyphens(fp, width);       fprintf(fp, "\n");          break;     case FEATURE_HISTORY: fprintf(fp, "frame | (x,y)=val\n");       fprintf(fp, "------+-");       _printNhyphens(fp, width);       fprintf(fp, "\n");          break;     case FEATURE_TABLE: fprintf(fp, "feature |          frame\n");          fprintf(fp, "        |");          for (i = 0 ; i < nFrames ; i++) _printInteger(fp, i, width);       fprintf(fp, "\n--------+-");          for (i = 0 ; i < nFrames ; i++) _printNhyphens(fp, width);       fprintf(fp, "\n");          break;  }}static void _printFeatureTxt(  FILE *fp,  KLT_Feature feat,  char *format,  char type){  assert(type == 'f' || type == 'd');  if (type == 'f')    fprintf(fp, format, (float) feat->x, (float) feat->y, feat->val);  else if (type == 'd')  {    /* Round x & y to nearest integer, unless negative */    float x = feat->x;    float y = feat->y;    if (x >= 0.0) x += 0.5;    if (y >= 0.0) y += 0.5;    fprintf(fp, format,             (int) x, (int) y, feat->val);  }}static void _printFeatureBin(  FILE *fp,  KLT_Feature feat){  fwrite(&(feat->x), sizeof(KLT_locType), 1, fp);  fwrite(&(feat->y), sizeof(KLT_locType), 1, fp);  fwrite(&(feat->val), sizeof(int), 1, fp);}static void _printShutdown(  FILE *fp){  /* Close file, if necessary */  if (fp != stderr)    fclose(fp);}/********************************************************************* * KLTWriteFeatureList() * KLTWriteFeatureHistory() * KLTWriteFeatureTable() *  * Writes features to file or to screen. * * INPUTS * fname: name of file to write data; if NULL, then print to stderr * fmt:   format for printing (e.g., "%5.1f" or "%3d"); *        if NULL, and if fname is not NULL, then write to binary file. */void KLTWriteFeatureList(  KLT_FeatureList fl,  char *fname,   char *fmt){  FILE *fp;  char format[100];  char type;  int i;  if (KLT_verbose >= 1 && fname != NULL)  {    fprintf(stderr,              "(KLT) Writing feature list to %s file: '%s'\n",             (fmt == NULL ? "binary" : "text"), fname);  }  if (fmt != NULL) {  /* text file or stderr */    fp = _printSetupTxt(fname, fmt, format, &type);    _printHeader(fp, format, FEATURE_LIST, 0, fl->nFeatures);	    for (i = 0 ; i < fl->nFeatures ; i++)  {      fprintf(fp, "%7d | ", i);      _printFeatureTxt(fp, fl->feature[i], format, type);      fprintf(fp, "\n");    }    _printShutdown(fp);  } else {  /* binary file */    fp = _printSetupBin(fname);    fwrite(binheader_fl, sizeof(char), BINHEADERLENGTH, fp);     fwrite(&(fl->nFeatures), sizeof(int), 1, fp);    for (i = 0 ; i < fl->nFeatures ; i++)  {      _printFeatureBin(fp, fl->feature[i]);    }    fclose(fp);  }}void KLTWriteFeatureHistory(  KLT_FeatureHistory fh,  char *fname,   char *fmt){  FILE *fp;  char format[100];  char type;  int i;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色诱亚洲精品久久久久久| 欧美日本乱大交xxxxx| 26uuu国产在线精品一区二区| 日日夜夜精品视频天天综合网| 欧美亚洲日本一区| 亚洲aⅴ怡春院| 欧美一区二区在线播放| 精品在线视频一区| 国产精品成人一区二区三区夜夜夜| 精品久久久久久久久久久院品网 | 久久精品国产99国产| 欧美电视剧在线看免费| 国产一区二区三区在线看麻豆| 国产婷婷一区二区| 色先锋资源久久综合| 婷婷久久综合九色综合绿巨人| 欧美一级黄色录像| 国产福利一区在线| 亚洲午夜一区二区| 精品国产成人系列| 91麻豆.com| 久久国产剧场电影| 国产精品久久久久久久裸模| 欧美怡红院视频| 国产一区二区三区在线观看免费| 中文字幕亚洲一区二区va在线| 欧美日韩国产综合一区二区 | 国产一区二区91| 中文字幕一区av| 日韩三级在线免费观看| 成人av手机在线观看| 亚洲成人资源在线| 国产天堂亚洲国产碰碰| 欧美偷拍一区二区| 国产成人午夜片在线观看高清观看| 亚洲麻豆国产自偷在线| 精品少妇一区二区三区在线播放| 91原创在线视频| 国产一区在线观看麻豆| 亚洲一区二区在线免费看| 精品99一区二区| 欧美中文字幕一区二区三区 | 2023国产精品自拍| 在线免费精品视频| 成人久久视频在线观看| 日日夜夜精品免费视频| 亚洲欧美二区三区| 国产天堂亚洲国产碰碰| 制服丝袜亚洲色图| 在线视频一区二区免费| 成人黄色在线网站| 久久99精品久久久久久动态图 | 26uuu久久天堂性欧美| 欧美视频自拍偷拍| 91免费观看视频在线| 狠狠色狠狠色综合系列| 日韩国产在线观看一区| 亚洲免费视频中文字幕| 国产精品午夜在线观看| 日韩欧美国产综合一区| 欧美老年两性高潮| 欧洲国内综合视频| 99久久99精品久久久久久| 国产成人av电影在线播放| 久久66热re国产| 日韩av网站免费在线| 午夜精品久久久久久久| 夜夜精品视频一区二区| 亚洲人午夜精品天堂一二香蕉| 久久精品视频一区二区三区| 精品国产免费人成电影在线观看四季 | 一本色道久久综合亚洲aⅴ蜜桃| 国产成人免费av在线| 国产一区二区按摩在线观看| 久久国产精品一区二区| 欧美在线一二三| 99re成人精品视频| 97精品久久久午夜一区二区三区| 成人黄色在线看| 99在线视频精品| 91农村精品一区二区在线| 97se亚洲国产综合在线| 91亚洲精品乱码久久久久久蜜桃| 粉嫩嫩av羞羞动漫久久久 | 国产自产2019最新不卡| 男男视频亚洲欧美| 免费看欧美美女黄的网站| 久久国产尿小便嘘嘘| 国产剧情一区在线| 春色校园综合激情亚洲| 91色porny| 欧美老年两性高潮| 欧美白人最猛性xxxxx69交| 日韩免费电影一区| 久久久美女毛片| 国产清纯在线一区二区www| 久久一留热品黄| 国产精品国产a| 亚洲摸摸操操av| 一区二区三区美女视频| 亚洲一区在线看| 日韩av网站免费在线| 黄色小说综合网站| 成人手机在线视频| 91国产成人在线| 69久久99精品久久久久婷婷| 天天亚洲美女在线视频| 久久97超碰国产精品超碰| 国产精品亚洲一区二区三区在线| bt7086福利一区国产| 91高清视频免费看| 欧美一区二区三区公司| 欧美精品一区二区久久婷婷| 国产精品青草综合久久久久99| 亚洲最色的网站| 美女国产一区二区三区| 成人一区二区视频| 欧美精品黑人性xxxx| 久久久精品中文字幕麻豆发布| 久久精品欧美一区二区三区麻豆| 中文字幕亚洲综合久久菠萝蜜| 亚洲高清免费视频| 国产成人精品aa毛片| 色综合久久久久| 日韩欧美黄色影院| 中文字幕日韩一区| 日本在线不卡视频一二三区| 99久久精品免费看国产免费软件| 日韩一区二区三区av| 国产蜜臀97一区二区三区 | 亚洲欧洲综合另类| 激情欧美一区二区| 欧美视频在线播放| 国产亚洲一二三区| 日韩成人午夜精品| 日本大香伊一区二区三区| 久久久蜜臀国产一区二区| 亚洲成人黄色小说| 不卡视频免费播放| 久久综合九色综合欧美就去吻| 亚洲午夜一区二区| 久久精品国产一区二区| 国产精品区一区二区三| 日本免费在线视频不卡一不卡二| 99久久精品国产观看| 久久综合色婷婷| 日本美女一区二区| 欧美日韩一区二区三区四区| 日韩毛片在线免费观看| 国产在线不卡一区| 日韩一区二区三区在线观看| 亚洲精品videosex极品| 99免费精品在线观看| 国产天堂亚洲国产碰碰| 久久精工是国产品牌吗| 51久久夜色精品国产麻豆| 亚洲综合偷拍欧美一区色| 一本到一区二区三区| **性色生活片久久毛片| 国产a久久麻豆| 国产欧美精品在线观看| 国产精品亚洲一区二区三区妖精| 日韩精品影音先锋| 经典一区二区三区| 日韩久久久精品| 麻豆成人久久精品二区三区红| 欧美日韩1区2区| 天天综合天天做天天综合| 欧美日韩国产一二三| 亚洲一区在线视频| 在线欧美一区二区| 亚洲成人1区2区| 欧美三级电影网| 视频一区在线视频| 日韩免费一区二区三区在线播放| 久久草av在线| 久久久久久久电影| 福利一区在线观看| 中文字幕一区二区三区不卡在线| 色婷婷综合久久久久中文一区二区| 一区二区成人在线| 欧美人牲a欧美精品| 麻豆一区二区99久久久久| 亚洲精品一区二区三区影院| 国产91精品精华液一区二区三区| 日本一区二区三区视频视频| 91毛片在线观看| 亚洲v日本v欧美v久久精品| 日韩三级伦理片妻子的秘密按摩| 国模冰冰炮一区二区| 国产精品伦一区| 欧美日韩在线三区| 精品一二三四区| 亚洲欧洲三级电影| 欧美日韩精品系列| 国产精品一区二区男女羞羞无遮挡 | 亚洲免费观看高清完整版在线观看| 欧美中文字幕久久| 免费成人你懂的| 中文字幕一区二区三区不卡|