久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標題: Freeimage自動閾值分割 [打印本頁]

作者: bibi    時間: 2015-4-18 20:50
標題: Freeimage自動閾值分割
Freeimage的圖片切割分塊的處理。。。。尼瑪突然感到頭好暈。。。。。。。。。。。




/////////////////////////////////////////////////////////////////////////////////////////
//源代碼

1、otsu閾值分割


/*
parameter:   *image              --- buffer for image
rows, cols        --- size of image
     x0, y0, dx, dy   --- region of vector used for computing threshold
vvv                  --- debug option, is 0, no debug information outputed
*/

/*======================================================================*/
/*   OTSU global thresholding routine                                   */
/*   takes a 2D unsigned char array pointer, number of rows, and        */
/*   number of cols in the array. returns the value of the threshold    */
/*======================================================================*/
int CStatintDlg::otsu (unsigned char *image, int rows, int cols, int x0, int y0, int dx, int dy, int vvv)
{
unsigned char *np;      // 圖像指針
int thresholdValue=1; // 閾值
int ihist[256];             // 圖像直方圖,256個點
int i, j, k;          // various counters
int n, n1, n2, gmin, gmax;
double m1, m2, sum, csum, fmax, sb;
// 對直方圖置零...
memset(ihist, 0, sizeof(ihist));
gmin=255; gmax=0;
// 生成直方圖
for (i = y0 + 1; i < y0 + dy - 1; i++) {
np = &image[i*cols+x0+1];
for (j = x0 + 1; j < x0 + dx - 1; j++) {
ihist[*np]++;
if(*np > gmax) gmax=*np;
if(*np < gmin) gmin=*np;
np++; /* next pixel */
}
}
// set up everything
sum = csum = 0.0;
n = 0;
for (k = 0; k <= 255; k++) {
sum += (double) k * (double) ihist[k];    /* x*f(x) 質量矩*/
n   += ihist[k];                                         /*  f(x)    質量    */
}
if (!n) {
// if n has no value, there is problems...
fprintf (stderr,"NOT NORMAL thresholdValue = 160\n");
return (160);
}
// do the otsu global thresholding method
fmax = -1.0;
n1 = 0;
for (k = 0; k < 255; k++) {
n1 += ihist[k];
if (!n1) { continue; }
n2 = n - n1;
if (n2 == 0) { break; }
csum += (double) k *ihist[k];
m1 = csum / n1;
m2 = (sum - csum) / n2;
sb = (double) n1 *(double) n2 *(m1 - m2) * (m1 - m2);
/* bbg: note: can be optimized. */
if (sb > fmax) {
fmax = sb;
thresholdValue = k;
}
}
// at this point we have our thresholding value
// debug code to display thresholding values
if ( vvv & 1 )
fprintf(stderr,"# OTSU: thresholdValue = %d gmin=%d gmax=%d\n",
thresholdValue, gmin, gmax);
return(thresholdValue);
}


//快速判別
void CStatintDlg::OnBnClickedDiscrimination()
{
if(m_kOrgImage.IsEmpty())  //there is no image we should exit from here
return;

size_t bpp = m_kOrgImage.GetBPP();
    if(1 == bpp) return;

m_kOrgImage.ConvertToGreyscale();
BYTE *lpBits = m_kOrgImage.GetBits();
    unsigned int width = m_kOrgImage.GetWidth();
unsigned int height = m_kOrgImage.GetHeight();

   m_Threshold = otsu(lpBits,height,width,0,0,width,height,0);
   TRACE1("otsu=%d\n\n",m_Threshold);

   ASSERT(m_Threshold >0 && m_Threshold < 256);
   //////////////////////////////////////////////////////////////////////////
   unsigned int v = ( width - 1 ) / m_nBlockWidth + 1;
   unsigned int h = ( height - 1 ) / m_nBlockheight + 1;

  dMatrix Ratiomat(h,v);   //比列矩陣
  uMatrix BitMat(h,v);     //0-1矩陣  

   long sFront,sBack;
   double fRatio;

   for(unsigned int j = 0; j < h; j ++ )
   {
   for(unsigned int i = 0; i < v; i ++ )
   {
   RECT rt;
   rt.left = i * m_nBlockWidth;
   rt.top = j * m_nBlockheight;
   rt.right = rt.left + m_nBlockWidth;
   rt.bottom = rt.top + m_nBlockheight;
   if( rt.right > (LONG)width ){
   rt.right = width;
   }

   if( rt.bottom > (LONG)height ){
   rt.bottom = height;
   }

   FIBITMAP* pCut = ::FreeImage_Copy( m_kOrgImage.GetHandle(), rt.left, rt.top, rt.right, rt.bottom );
    ::FreeImage_GetHistogram(pCut , m_hgray, FICC_RGB);

sFront = 0;
sBack = 0;
for (unsigned int k = 0;k<256;k++)
{
if(k > m_Threshold)
sFront += m_hgray[k];
else
sBack += m_hgray[k];
}

if(0 == sBack)   //防止處以0
fRatio = 1.0f;
else
    fRatio = (double)sFront/(double)sBack;

            Ratiomat[j] = fRatio;

if ( (abs(fRatio - m_fLowVal) > 1e-20 ) && (abs(fRatio - m_fHighVal) > 1e-20 ))
BitMat[j] = 1;
else
BitMat[j] = 0;


//舉例怎么取矩陣的值
TRACE3("Ratiomat[%d][%d]=%f%%\n",j,i,fRatio*100);

   if( pCut )
   ::FreeImage_DestroyICCProfile( pCut );

   }
   }


   //////////////////////////////////////////////////////////////////////////

   m_kOrgImage.Threshold(m_Threshold);

   UpdateImage();

}











歡迎光臨 (http://m.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 亚洲成人久久久 | 中文字幕在线观看不卡 | 毛片在线观看网站 | 在线观看国产小视频 | 在线观看视频一区二区三区 | 国产成人在线免费视频 | 日本精品在线视频 | 中文字幕在线观看不卡 | 欧美日皮视频 | 国产精品日韩欧美 | 免费看一级黄色片 | 极品淫少妇 | 91最新网址 | 国产成人精品一区二区三区在线 | 四虎影院永久免费 | 国产精品欧美激情 | 午夜丁香 | 国产视频一区在线观看 | 天天综合天天做天天综合 | 九九热在线观看 | 亚洲免费在线播放 | 亚洲免费视频观看 | 国产呦小j女精品视频 | 成人免费激情视频 | 午夜国产一区 | 国产一区二区精品丝袜 | 亚洲美女在线视频 | 99视频在线精品免费观看2 | 欧美精品在线观看 | 午夜影院在线观看视频 | 91伦理| 午夜亚洲精品 | 久久日av| 久久国产99 | 青青久操 | 精品一区二区视频 | 欧美一级片 | 天堂va蜜桃一区二区三区 | 在线观看的av | av一二三区| 无套内谢的新婚少妇国语播放 |