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

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

?? blobls.c

?? NIST Handwriting OCR Testbed
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*# proc: build_blobls - allocates and initializes a list of blobs.# proc:# proc: alloc_blobls - allocates a list of blobs.# proc:# proc: free_blobls - deallocates a list of blobs including image data if not NULL.# proc:# proc: realloc_blobls - reallocates a list of blobs that has overflowed.# proc:# proc: append_blobls - adds a blob to the end of a blob list.# proc:# proc: merge_with_blobls - merges two blobs contained in a blob list and frees# proc:                 up the location of the source blob.# proc: merge_among_blobls - merges two blobs, each in a separate blob list, and frees# proc:                 up the location of the source blob.# proc: merge_blobs - composites two blobs back together according to their cut# proc:               corrdinates from their parent image.# proc: remove_blobls - removes a blob from its blob list at a specified location by# proc:                 sliding (collapsing) the contents of the list down in memory.# proc: init_blobls - sets up global blob list attributes.# proc:# proc: build_blob - allocates and initializes a blob given image data and attributes.# proc:# proc: dup_blob - returns a duplicate copy of the blob passed.# proc:# proc: update_blobls_stats - recomputes blob attributes specified by the flag passed# proc:                       across all the blobs in the list.# proc: compute_blob_stats - computes blob attributes specified by the flag passed.# proc:# proc: alloc_blob - allocates a blob structure without any allocation for image data.# proc:# proc: free_blob - deallocates a blob structure and its image data if not NULL.# proc:# proc: char2bin_blobls - converts all the blobs in a list containing binary char image# proc:                   data to one bit per pixel data.# proc: find_first_max_blob_memb - used in coordination with the blob_offsetof() macro,# proc:           this routine will find the maximum value for a specific blob attribute.# proc: compute_avr_blob_memb - used in coordination with the blob_offsetof() macro,# proc:           this routine computes the average value for a specific blob attribute.# proc: prct_blobls_memb - selects the specified percentile from the list of blob# proc:             attributes.# proc: median_blob_memb - finds median from the list of blob attributes.# proc:# proc: sort_blobls_on_memb - used in coordination with the blob_offsetof() macro,# proc:             this routine sorts a list of blobs on a specific blob attribute.# proc: is_blob_above - determines if one blob is above another.# proc:# proc: find_blob_nbrs - given a list of blobs sorted left-to-right, returns blobs to the# proc:                  left and right of a given blob.# proc: find_blob_ind_blob_nbrs - given a list of blobs and a sorted rank of the list,# proc:                  returns blobs to the left and right of a given blob.# proc: find_first_blob_inside - determines if a blob is inside one of the blobs# proc:                          contained in a list.# proc: blob_hori_overlaps - given a blob and a list of blobs, finds all those blobs# proc:                 that horizontally overlap the first blob and measures and stores# proc:                 the distance of the overlaps.*/#include <stdio.h>#include <blobls.h>#include <multsort.h>#include <defs.h>/*******************************************************************/build_blobls(blobls, blob_alloc, flags, bpp, b_g)BLOBLS **blobls;int blob_alloc, flags, bpp, b_g;{   alloc_blobls(blobls, blob_alloc);   init_blobls((*blobls), flags, bpp, b_g);}/*******************************************************************/alloc_blobls(blobls, blob_alloc)BLOBLS **blobls;int blob_alloc;{   if(((*blobls) = (BLOBLS *)malloc(sizeof(BLOBLS))) == NULL)      syserr("alloc_blobls", "malloc", "blobls");   if(blob_alloc == 0)      (*blobls)->blobs = (BLOB **)NULL;   else      if(((*blobls)->blobs = (BLOB **)malloc(blob_alloc * sizeof(BLOB *))) == NULL)         syserr("alloc_blobls", "malloc", "blobs");   (*blobls)->num = 0;   (*blobls)->alloc = blob_alloc;}/*******************************************************************/free_blobls(blobls)BLOBLS *blobls;{   int i;   if(blobls->blobs != (BLOB **)NULL){      for(i = 0; i < blobls->num; i++){        free_blob(blobls->blobs[i]);      }      free(blobls->blobs);   }   free(blobls);}/*******************************************************************/realloc_blobls(blobls)BLOBLS *blobls;{   blobls->alloc += BLOB_CHUNKS;   if((blobls->blobs = (BLOB **)realloc(blobls->blobs,                               blobls->alloc * sizeof(BLOB *))) == NULL)      syserr("realloc_blobls", "realloc", "blob list");}/*******************************************************************/append_blobls(blobls, blob)BLOBLS *blobls;BLOB *blob;{   if(blobls->num >= blobls->alloc)      /* realloc first */      realloc_blobls(blobls);   blobls->blobs[blobls->num] = blob;   (blobls->num)++;}/************************************************************/merge_within_blobls(blobls, src, dst)BLOBLS *blobls;int src, dst;{   BLOB *nblob, *sptr, *dptr;   if((src < 0) || (src >= blobls->num))      fatalerr("merge_within_blobs", "src blob index not within blob list", NULL);   if((dst < 0) || (dst >= blobls->num))      fatalerr("merge_within_blobls", "dst blob index not within blob list", NULL);   sptr = blobls->blobs[src];   dptr = blobls->blobs[dst];   merge_blobs(&nblob, sptr, dptr, blobls->flags);   free(dptr->data);   free(dptr);   blobls->blobs[dst] = nblob;   free(sptr->data);   free(sptr);   remove_blobls(blobls, src);}/*******************************************************************/merge_among_blobls(sblobls, src, dblobls, dst)BLOBLS *sblobls, *dblobls;int src, dst;{   BLOB *nblob, *sptr, *dptr;   if((src < 0) || (src >= sblobls->num))      fatalerr("merge_among_blobs", "src blob index not within blob list", NULL);   if((dst < 0) || (dst >= dblobls->num))      fatalerr("merge_among_blobls", "dst blob index not within blob list", NULL);   sptr = sblobls->blobs[src];   dptr = dblobls->blobs[dst];   merge_blobs(&nblob, sptr, dptr, dblobls->flags);   free(dptr->data);   free(dptr);   dblobls->blobs[dst] = nblob;   /* remove dot blob from list */   free(sptr->data);   free(sptr);   remove_blobls(sblobls, src);}/*******************************************************************/merge_blobs(nblob, blob1, blob2, flags)BLOB **nblob, *blob1, *blob2;int flags;{   unsigned char *allocate_image();   int lx, rx, ty, by, tflags;   alloc_blob(nblob);   lx = min(blob1->x1, blob2->x1);   rx = max(blob1->x1 + blob1->w,            blob2->x1 + blob2->w);   ty = min(blob1->y1, blob2->y1);   by = max(blob1->y1 + blob1->h,            blob2->y1 + blob2->h);   (*nblob)->x1 = lx;   (*nblob)->y1 = ty;   (*nblob)->w = rx - lx;   (*nblob)->h = by - ty;   (*nblob)->data = allocate_image((*nblob)->w, (*nblob)->h, 8);   /* copy first blob */   subimage_copy(blob1->data, blob1->w, blob1->h,                 (*nblob)->data, (*nblob)->w, (*nblob)->h, 0, 0, blob1->w, blob1->h,                 blob1->x1 - lx, blob1->y1 - ty);   /* OR second blob */   subimage_or(blob2->data, blob2->w, blob2->h,               (*nblob)->data, (*nblob)->w, (*nblob)->h, 0, 0, blob2->w, blob2->h,               blob2->x1 - lx, blob2->y1 - ty);   /* compute new pixcnt without rescanning image */   if(flags & BLOB_PIXCNTS){      (*nblob)->pixcnt = blob1->pixcnt + blob2->pixcnt;      /* don't recount pixels, already taken care of */      tflags = flags & ~BLOB_PIXCNTS;   }   else      tflags = flags;   /* compute other blob statistics according to flags set */   compute_blob_stats((*nblob), tflags);}/*******************************************************************/remove_blobls(blobls, bi)BLOBLS *blobls;int bi;{   if((bi < 0) || (bi >= blobls->num))      fatalerr("remove_blobls", "blob index out of range of current list", NULL);   (blobls->num)--;   /* shift memory if blob not at end of list */   if(bi != blobls->num)      memcpy(&(blobls->blobs[bi]), &(blobls->blobs[bi+1]),             (blobls->num - bi) * sizeof(BLOB *));}/*******************************************************************/init_blobls(blobls, flags, bpp, b_g)BLOBLS *blobls;int flags, bpp, b_g;{   blobls->flags = flags;   blobls->bpp = bpp;   blobls->b_g = b_g;}/*******************************************************************/build_blob(blob, flags, bdata, bx, by, bw, bh)BLOB **blob;int flags;unsigned char *bdata;int bx, by, bw, bh;{   alloc_blob(blob);   (*blob)->data = bdata;   (*blob)->x1 = bx;   (*blob)->y1 = by;   (*blob)->w = bw;   (*blob)->h = bh;   compute_blob_stats((*blob), flags);}/*******************************************************************/BLOB *dup_blob(blob, bpp)BLOB *blob;int bpp;{   BLOB *oblob;   unsigned char *imagedup();   alloc_blob(&oblob);   memcpy(oblob, blob, sizeof(BLOB));   /* allocate and copy separate image space */   oblob->data = imagedup(blob->data, blob->w, blob->h, bpp);   return(oblob);}/*******************************************************************/update_blobls_stats(blobls, flags)BLOBLS *blobls;int flags;{   int i;   int do_xy2s, do_cxys, do_as, do_pixcnt;/*   if(!(blobls->flags & BLOB_XY1S) || !(blobls->flags & BLOB_WHS))      fatalerr("update_blobls_stats",               "must have at least (x1, y1) and (w, h) already in blob structures",               NULL);*/   /* set up tests for flags */   do_xy2s = (flags & BLOB_XY2S)?1:0;   do_cxys = (flags & BLOB_CXYS)?1:0;   do_as = (flags & BLOB_AS)?1:0;   do_pixcnt = (flags & BLOB_PIXCNTS)?1:0;   /* update blob stats accordingly */   for(i = 0; i < blobls->num; i++){

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美区自拍先锋| 中文字幕一区二区三区蜜月| 国产一区二区三区在线观看免费 | 一区二区三区 在线观看视频| 91久久国产最好的精华液| 日韩精品一二区| 亚洲同性gay激情无套| 3atv在线一区二区三区| 成人手机在线视频| 美女看a上一区| 亚洲欧美日韩国产另类专区| 91精品在线观看入口| 日本高清不卡一区| 国内精品伊人久久久久av一坑 | 久久久久久久综合日本| 日本二三区不卡| 激情综合色综合久久| 日韩理论片在线| 精品日韩一区二区三区| 欧美视频一区二区在线观看| 成人性生交大片| 日本欧美一区二区| 亚洲精品视频在线| 国产精品美女久久久久高潮| 在线综合+亚洲+欧美中文字幕| 成人一区二区三区视频| 亚洲国产欧美日韩另类综合| 亚洲精品日韩综合观看成人91| 精品精品欲导航| 欧美午夜免费电影| 91麻豆精品秘密| 麻豆一区二区在线| 亚洲成av人片| 一区二区三区 在线观看视频| 国产亚洲成av人在线观看导航| 欧美大片在线观看一区二区| 欧美三级韩国三级日本一级| 不卡视频一二三四| 91小视频免费观看| 国产精品一二一区| 久久se精品一区二区| 久久成人久久爱| 日本美女一区二区三区视频| 亚洲精品国产精华液| 一区二区三区中文字幕电影 | 亚洲黄一区二区三区| 日本一区二区视频在线| 日韩欧美国产综合在线一区二区三区| 91国产精品成人| 成人av在线播放网址| 日本欧美在线观看| 美女高潮久久久| 麻豆视频一区二区| 日韩成人一级大片| 久久精品国产一区二区三区免费看 | 国产精品少妇自拍| 欧美videofree性高清杂交| 欧美精品一区二区三区高清aⅴ | 69堂国产成人免费视频| 欧美性色欧美a在线播放| 91成人免费网站| 欧美午夜片在线观看| 欧美区在线观看| 色就色 综合激情| 在线免费观看一区| 在线免费观看不卡av| 欧美日韩国产电影| 亚洲欧美综合网| 亚洲欧美偷拍卡通变态| 首页欧美精品中文字幕| 日韩av电影天堂| 精品一区二区成人精品| 粉嫩av一区二区三区粉嫩| 波多野结衣亚洲| 日本高清成人免费播放| 日韩一区二区电影网| 久久一区二区视频| 中文字幕免费在线观看视频一区| 一区二区三区四区亚洲| 亚洲综合一区在线| 秋霞电影网一区二区| 日韩综合小视频| 九一久久久久久| 丁香另类激情小说| 成人午夜精品在线| 欧美日韩二区三区| 久久综合色天天久久综合图片| 日韩免费视频一区二区| 最新热久久免费视频| 亚洲一区二区偷拍精品| 麻豆91精品视频| 91免费视频观看| 91精品欧美综合在线观看最新| 久久女同精品一区二区| 亚洲精选视频免费看| 久久精品国产秦先生| 91色porny| 欧美哺乳videos| 亚洲视频狠狠干| 国产在线精品一区二区三区不卡| 91视频国产观看| 精品国产一区二区三区不卡| 亚洲黄色av一区| 国产乱码精品一区二区三区忘忧草 | 成人欧美一区二区三区白人| 午夜天堂影视香蕉久久| 亚洲国产视频在线| 成人丝袜高跟foot| 日韩欧美国产电影| 国产精品久久综合| 国产资源在线一区| 欧美三级电影在线看| 欧美精品一区二区精品网| 亚洲成av人片一区二区三区| 91精品午夜视频| 久久精品免费在线观看| 天天操天天干天天综合网| 成人高清免费观看| 欧美一区二区三区视频免费播放 | 国产精品亲子乱子伦xxxx裸| 一区二区在线观看不卡| 国产一区二区精品久久| 欧美日韩在线播放| 国产精品嫩草影院com| 国产伦精品一区二区三区免费迷 | 久久精品久久久精品美女| 欧美剧在线免费观看网站| 中文字幕乱码日本亚洲一区二区| 蜜臀精品久久久久久蜜臀| 欧美日韩免费不卡视频一区二区三区| 中文字幕乱码亚洲精品一区| 久久精品国产澳门| 91在线精品一区二区三区| 久久久久99精品国产片| 免费成人你懂的| 在线视频一区二区三| 亚洲欧美怡红院| 成人国产精品视频| 欧美大片一区二区| 日本午夜精品视频在线观看| 欧美日韩视频第一区| 亚洲福中文字幕伊人影院| 91浏览器打开| 国产精品成人网| 一本久久综合亚洲鲁鲁五月天 | 粉嫩一区二区三区性色av| 日本一区二区免费在线| 国产激情视频一区二区在线观看 | 亚洲一级二级三级| 色综合天天综合网天天看片| 中文字幕亚洲电影| 91免费视频网址| 亚洲黄色免费电影| 欧美少妇一区二区| 日韩国产欧美在线观看| 91精品国产黑色紧身裤美女| 午夜精品一区在线观看| 欧美中文字幕一区二区三区 | 亚洲欧美偷拍另类a∨色屁股| 色综合天天综合狠狠| 亚洲视频你懂的| 欧美视频中文字幕| 视频一区二区不卡| 久久精品人人做| 在线精品国精品国产尤物884a| 香港成人在线视频| 国产亚洲综合在线| 在线免费观看一区| 狠狠色综合日日| 亚洲欧美日本韩国| 日韩午夜中文字幕| 成人午夜免费电影| 石原莉奈在线亚洲三区| 欧美v国产在线一区二区三区| 不卡一区二区中文字幕| 石原莉奈在线亚洲三区| 国产精品污污网站在线观看| 在线一区二区三区四区五区| 久久99在线观看| 中文字幕在线免费不卡| 欧美日韩精品二区第二页| 国产激情视频一区二区在线观看| 一区二区三区欧美| 久久精子c满五个校花| 日本道免费精品一区二区三区| 美女国产一区二区三区| 自拍偷拍亚洲综合| 精品国产99国产精品| 欧洲精品视频在线观看| 国产盗摄精品一区二区三区在线| 亚洲高清久久久| 国产精品久久久久久久久免费丝袜| 欧美一区二区三区视频| 99久久精品国产一区| 久久精品噜噜噜成人88aⅴ| 一区二区三区资源| 国产欧美视频一区二区三区| 777亚洲妇女| 欧美在线你懂得| 97se亚洲国产综合在线|