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

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

?? mrf.cpp

?? Supervised Image Segmentation Using Markov Random Fields
?? CPP
字號:
/****************************************************************** * Modul name : mrf.cpp * Author     : Csaba Gradwohl (Gradwohl.Csaba@stud.u-szeged.hu) with some *              minor contributions from Zoltan Kato (kato@inf.u-szeged.hu). * Copyright  : GNU General Public License www.gnu.org/copyleft/gpl.html * Description: * Intensity-based image segmentation using a Markov random field * segmentation model and four different optimization algorithms: * Metropolis - Simulated Annealing using Metropolis dynamics * Gibbs      - Simulated Annealing using a Gibbs sampler * ICM        - Iterated Conditional Modes, a deterministic suboptimal *              method (depends on a good initialization). * MMD        - Modified Metropolis Dynamics, a pseudo-stochastic *              suboptimal method which is less sensitive to *              initialization than ICM. * * The program GUI is written in wxWindows hence the code can be * compiled and ran under Windows as well as under Linux/Unix. * * $Id: mrf.cpp,v 1.7 2005/02/15 21:46:16 kato Exp $ * $Revision: 1.7 $ * $State: Exp $ * $Log: mrf.cpp,v $ * Revision 1.7  2005/02/15 21:46:16  kato * CPU timer now doesn't count GUI overhead * * Revision 1.6  2005/02/14 15:25:38  kato * fixed frame size * * Revision 1.5  2004/12/13 13:35:04  kato * Adjusted position of version & copyright info * * Revision 1.4  2004/12/13 13:31:12  kato * Added copyright & version information, * Class parameter window is larger * * Revision 1.3  2004/12/13 13:15:02  kato * Bug fixes * * Revision 1.2  2004/12/13 12:07:28  kato * added CPU timer * * Revision 1.1  2004/12/08 13:15:06  kato * Initial revision * *  *****************************************************************/#ifndef lintstatic char rcsid_mrf_cpp[]="$Id: mrf.cpp,v 1.7 2005/02/15 21:46:16 kato Exp $";#endif/* wxWindows includes */#include <wx/wxprec.h>#ifndef WX_PRECOMP    #include <wx/wx.h>#endif#include <wx/image.h>#include <math.h>#include <stdlib.h>/* Random number generators */#include "randomc.h"   // define classes for random number generators/* Timer classes */#include "CKProcessTimeCounter.h"#define WINDOW_TITLE "MRF Image Segmentation Demo $Revision: 1.7 $"#define VERSION      "MRF Image Segmentation Demo $Revision: 1.7 $ (Last built "\                     __DATE__" "__TIME__") "#define COPYRIGHT    "(c) 2004 by Csaba Gradwohl & Zoltan Kato (SZTE - Hungary)"static wxTextCtrl *gaussians;            // output textfield for Gaussian parametersstatic CKProcessTimeCounter timer("core"); // CPU timerstatic bool timer_valid = FALSE;/* Program's application class  */class MyApp: public wxApp{  virtual bool OnInit(); // this is the main entry point};/* ImageOperations class: it handles all image operations such as * loading, saving, etc...  */class ImageOperations{public:  ImageOperations(wxWindow *_frame);    // constructor  wxImage *LoadBmp(wxString bmp_name);	// loads an image from file		  bool SaveBmp(wxString bmp_name);      // saves out_image to a given file  bool IsOutput();			// TRUE if  out_image <> NULL  void SetNoRegions(int n);	      	// sets the number of regions,					// allocates/frees memory for					// means and variances  int GetNoRegions() { return no_regions; }  void SetBeta(double b) { beta = b; }  void SetT(double x) { t = x; }  void SetT0(double t) { T0 = t; }  void SetC(double x) { c = x; }  void SetAlpha(double x) { alpha = x; }  int GetK() { return K; }  double GetT() { return T; }  double GetE() { return E; }  double GetTimer() { return (timer_valid? timer.GetElapsedTimeMs() : 0.0); }  void CalculateMeanAndVariance(int region);  // computes mean and					      // variance of the given region.  double CalculateEnergy();                   // computes global energy					      // based on the current					      // lableing in data  double LocalEnergy(int i, int j, int label);// computes the local					      // energy at site (i,j)					      // assuming "label" has					      // been assigned to it.  void Metropolis(bool mmd=false);  // executes Metropolis or MMD (if mmd=true)  void ICM();			    // executes ICM  void Gibbs();			    // executes Gibbs samplerprivate:  wxWindow *frame;		    // the main window  wxImage *in_image, *out_image;    // input & output images  int width, height;		    // width and height of the				    // displayed image  int no_regions;	            // number of regions for Gaussian				    // parameter computation  double beta;                      // strength of second order clique potential  double t;			    // Stop criteraia threshold: stop				    // if (deltaE < t)  double T0;		            // Initial temperature (not used by ICM)  double c;			    // Temperature scheduler's factor:				    // T(n+1)=c*T(n).  double alpha;		            // alpha value for MMD  double *mean;			    // computed mean values and  double *variance;		    // variances for each region  double E;			    // current global energy  double E_old;			    // global energy in the prvious iteration  double T;			    // current temperature  int K;			    // current iteration #  int **classes;		    // this is the labeled image  int **in_image_data;		    // Intensity values of the input image   void InitOutImage();  void CreateOutput();	           // creates and draws the output				   // image based on the current labeling  double Singleton(int i, int j, int label); // computes singleton					     // potential at site					     // (i,j) having a label "label"  double Doubleton(int i, int j, int label); // computes doubleton					     // potential at site					     // (i,j) having a label "label"};/* MyScrolledWindow class: the window used for diaplaying images */class MyScrolledWindow: public wxScrolledWindow{public:  MyScrolledWindow(wxWindow* parent, wxWindowID id = -1, 		   const wxPoint& pos = wxDefaultPosition, 		   const wxSize& size = wxDefaultSize, 		   long style = wxHSCROLL | wxVSCROLL, 		   const wxString& name = "scrolledWindow"):     wxScrolledWindow(parent, id, pos, size, style, name)   { bmp = NULL; }  void SetBmp(wxImage *_bmp);     // assigns the image to the window.protected:  virtual void OnDraw(wxDC& dc);  // displays the image in the windowprivate:  wxImage *bmp;			  // the image to be displayed  int xDst, yDst;		  // the position of the image within				  // the window (meaningful only when				  // the image is smaller than the window)  wxMemoryDC memDC;		  // memDC storing the image  void OnLeftDown(wxMouseEvent& event);	   // Left button event handler  void OnMouseMotion(wxMouseEvent& event); // mouse motion event handler  DECLARE_EVENT_TABLE()};/* MyFrame class: the main window */class MyFrame: public wxFrame{public:  MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size);  ~MyFrame();  /* returns the coordinates of the given training rectangle (or the   * current one if region==-1)   */  void GetRegion(int &x, int &y, int &w, int &h, int region=-1);    int GetActRegion() { return act_region;}  void SetRegs1(int x, int y) {     regs[act_region*4] = x;     regs[act_region*4+1] = y;   }  void SetRegs2(int x, int y) {     regs[act_region*4+2] = x;     regs[act_region*4+3] = y;   }  MyScrolledWindow *GetInputWindow() { return input_window; }  MyScrolledWindow *GetOutputWindow() { return output_window; }    bool IsSelected(int region) { // tells whether the region has been selected     return (regs[region*4] || regs[region*4+1] || 	    regs[region*4+2] || regs[region*4+3]);   }   bool AllRegionsSelected() { // tells whether all the regions has been selected    for(int i=1; i<imageop->GetNoRegions(); ++i)      if (!IsSelected(i)) return false;     return true;   }   private:  ImageOperations *imageop;   MyScrolledWindow *input_window, *output_window;    // input & output						     // images' window  wxButton *load_button, *save_button, *doit_button; // buttons  wxButton *select_region_button;  wxChoice *op_choice;		// scroll-list of optimization algorithms  wxTextCtrl *regions;          // input field for number of classes,  wxTextCtrl *tbeta, *tt;	// beta, threshold t,  wxTextCtrl *tT0, *tc;		// initial temperature T0, scheduler factor c,  wxTextCtrl *talpha;		// and MMD's alpha  int act_region;   // the current class  int *regs;	    // stores the training rectangles for each class.    /* Event handlers   */    void OnOpen(wxCommandEvent& event);         // Load  void OnSave(wxCommandEvent& event);         // Save  void OnDoit(wxCommandEvent& event);         // DoIt  void OnChoice(wxCommandEvent& event);	      // optimization method selection   void OnRegions(wxCommandEvent& event);      // number of classes  void OnSelectRegion(wxCommandEvent& event); // select training rectangle  void OnPaint(wxPaintEvent& event);	      // paint handler  DECLARE_EVENT_TABLE()    };enum { ID_LOAD_BUTTON, ID_SAVE_BUTTON, ID_DOIT_BUTTON, ID_CHOICE,       ID_REGIONS, ID_SELECTREGION_BUTTON, ID_BETA, ID_T, ID_T0, ID_C,       ID_ALPHA, ID_GAUSSIANS };/* Event table */BEGIN_EVENT_TABLE(MyFrame, wxFrame)  EVT_BUTTON(ID_LOAD_BUTTON, MyFrame::OnOpen)  EVT_BUTTON(ID_SAVE_BUTTON, MyFrame::OnSave)  EVT_BUTTON(ID_DOIT_BUTTON, MyFrame::OnDoit)  EVT_CHOICE(ID_CHOICE, MyFrame::OnChoice)  EVT_PAINT(MyFrame::OnPaint)  EVT_TEXT(ID_REGIONS, MyFrame::OnRegions)  EVT_BUTTON(ID_SELECTREGION_BUTTON, MyFrame::OnSelectRegion)END_EVENT_TABLE()BEGIN_EVENT_TABLE(MyScrolledWindow, wxScrolledWindow)  EVT_LEFT_DOWN(MyScrolledWindow::OnLeftDown)  EVT_MOTION(MyScrolledWindow::OnMouseMotion)END_EVENT_TABLE()IMPLEMENT_APP(MyApp)bool MyApp::OnInit(){  MyFrame *frame = new MyFrame( WINDOW_TITLE, 				wxPoint(0,0), wxSize(900,620) );  frame->Show( TRUE );  SetTopWindow( frame );  return TRUE;}void MyScrolledWindow::SetBmp(wxImage *_bmp) {  xDst = yDst = 0;  // center if image is smaller than the window  if (_bmp!=NULL)    {      if (_bmp->GetWidth() < 300) xDst = (300-_bmp->GetWidth())/2;      if (_bmp->GetHeight() < 250) yDst = (250-_bmp->GetHeight())/2;      memDC.SelectObject(*_bmp);    }  bmp = _bmp; }	void MyScrolledWindow::OnDraw(wxDC& dc){  if (bmp != NULL)    {      // determine which part of the image is visible in the window.      int x, y;      GetViewStart(&x, &y);      x *= 10; y *= 10;	   // must be multiplied by ScrollUnit      // copy the visible part into the window      int _xDst, _yDst;      CalcUnscrolledPosition(xDst, yDst, &_xDst, &_yDst);      dc.Blit(_xDst, _yDst, 300, 250, &memDC, x, y);            // draw the training rectangle on the input image      MyFrame *parent = (MyFrame *)GetParent();      if (parent->GetInputWindow() == this)	{	  int x1, y1, w, h;	  parent->GetRegion(x1, y1, w, h);	  if (x1!=0 || y1!=0 || w!=0 || h!=0)	    {	      wxPen pen(*wxRED_PEN);	      wxBrush brush(*wxTRANSPARENT_BRUSH);	      dc.SetPen(pen);	      dc.SetBrush(brush);	      dc.DrawRectangle(x1+xDst, y1+yDst, w, h);	    }	}    }}/* Left mouse button event handler */void MyScrolledWindow::OnLeftDown(wxMouseEvent& event){  // comvert window coordinates to image coordinates  int x, y;  GetViewStart(&x, &y);  x *= 10; y *= 10;	 // must be multiplied by ScrollUnit  MyFrame *frame = (MyFrame *)GetParent();  if (frame->GetActRegion() != -1)	// in this case regs != NULL    {      if (event.m_x >= xDst && event.m_x < xDst+bmp->GetWidth() &&	  event.m_y >= yDst && event.m_y < yDst+bmp->GetHeight())	frame->SetRegs1(event.m_x+x-xDst, event.m_y+y-yDst); // scroll added	}}/* Mouse motion event handler */void MyScrolledWindow::OnMouseMotion(wxMouseEvent& event){  if (event.LeftIsDown())    {      // comvert window coordinates to image coordinates      int x, y;      GetViewStart(&x, &y);      x *= 10; y *= 10;		// must be multiplied by ScrollUnit      MyFrame *frame = (MyFrame *)GetParent();      if (frame->GetActRegion() != -1)		// in this case regs != NULL	{	  if (event.m_x >= xDst && event.m_x < xDst+bmp->GetWidth() &&	      event.m_y >= yDst && event.m_y < yDst+bmp->GetHeight())	    frame->SetRegs2(event.m_x+x-xDst, event.m_y+y-yDst); // scroll added	  Refresh();		}	}}/*********************************************************************/* Functions of MyFrame class/********************************************************************/void MyFrame::OnPaint(wxPaintEvent& event){  wxPaintDC pDC(this);  wxString str;  str.Printf("Number of classes:");  pDC.DrawText(str, 20, 325);    str.Printf("

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本大道av伊人久久综合| 国产精品久久久久久久久快鸭| 欧美精品一区二区久久久| 国产精品女上位| 强制捆绑调教一区二区| 99久久久无码国产精品| 久久久亚洲精品一区二区三区 | 精品福利一区二区三区| 亚洲精品中文在线观看| 国产精品一卡二卡| 欧美一级高清片| 亚洲成人免费电影| 色综合天天综合狠狠| 国产欧美一二三区| 国产一区二区不卡| 欧美zozozo| 另类小说图片综合网| 欧美二区在线观看| 亚洲成人激情社区| 欧美三级韩国三级日本一级| 中文字幕一区二区三区四区| 国产精品自拍av| 国产偷国产偷精品高清尤物| 久久精品久久99精品久久| 日韩一级黄色片| 青青草97国产精品免费观看无弹窗版| 在线观看日韩精品| 亚洲一区二区在线播放相泽| 91福利视频网站| 亚洲精品免费在线播放| 91福利在线免费观看| 一区二区三区美女| 色婷婷综合久久久久中文| 亚洲精品日日夜夜| 欧美熟乱第一页| 午夜电影网亚洲视频| 欧美日韩电影在线| 青青草精品视频| 精品国产三级电影在线观看| 国产在线精品不卡| 国产精品美女www爽爽爽| av高清不卡在线| 艳妇臀荡乳欲伦亚洲一区| 欧美自拍偷拍一区| 图片区小说区区亚洲影院| 51久久夜色精品国产麻豆| 日本伊人午夜精品| 久久久久国产成人精品亚洲午夜| 国产精品一二三在| 亚洲免费电影在线| 欧美福利视频一区| 国产自产2019最新不卡| 中文字幕一区二区三区在线观看| av中文字幕一区| 亚洲成a人v欧美综合天堂下载 | 亚洲成人先锋电影| 日韩久久久久久| 成人禁用看黄a在线| 亚洲精品高清视频在线观看| 欧美日韩不卡一区二区| 国产一区二区三区在线观看免费 | 性做久久久久久久免费看| 欧美r级在线观看| 97久久超碰精品国产| 视频一区二区不卡| 国产欧美精品一区aⅴ影院| 欧美性受极品xxxx喷水| 极品少妇一区二区三区精品视频| 国产精品乱码久久久久久| 欧美日韩国产首页在线观看| 国产麻豆精品在线| 亚洲chinese男男1069| 久久九九影视网| 欧美日韩一区二区在线观看| 韩国成人精品a∨在线观看| 亚洲欧美怡红院| 精品国产1区2区3区| 在线欧美日韩国产| 国产宾馆实践打屁股91| 无码av免费一区二区三区试看| 日本一区免费视频| 在线播放亚洲一区| 99re成人精品视频| 国内成+人亚洲+欧美+综合在线| 亚洲黄色av一区| 欧美激情在线一区二区| 欧美一区二区私人影院日本| 色综合一区二区| 国产69精品久久777的优势| 日本一道高清亚洲日美韩| 亚洲欧美色综合| 国产精品色眯眯| 亚洲精品在线一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 色婷婷综合在线| 成人在线视频首页| 久久精品免费观看| 日韩中文字幕区一区有砖一区| 亚洲视频中文字幕| 久久精品一区二区三区四区| 日韩免费观看高清完整版在线观看| 日本福利一区二区| av在线不卡观看免费观看| 国产另类ts人妖一区二区| 日本中文一区二区三区| 日韩影院精彩在线| 日韩高清一区在线| 亚洲福利一区二区| 亚洲国产精品人人做人人爽| 亚洲男人的天堂在线aⅴ视频| 中文字幕av一区二区三区免费看| 欧美精品一区二区三区蜜桃| 精品国精品国产尤物美女| 日韩天堂在线观看| 欧美一级二级在线观看| 欧美一卡2卡3卡4卡| 欧美一级高清大全免费观看| 日韩视频123| 久久综合九色综合欧美就去吻| 精品国产区一区| 欧美国产视频在线| 亚洲欧洲成人精品av97| 亚洲色图欧美激情| 亚洲成人在线观看视频| 日本aⅴ亚洲精品中文乱码| 奇米精品一区二区三区在线观看| 免费视频一区二区| 国产尤物一区二区| voyeur盗摄精品| 欧美视频日韩视频在线观看| 欧美日韩卡一卡二| 日韩欧美激情四射| 欧美激情综合网| 亚洲一区电影777| 毛片不卡一区二区| 国产成人在线电影| 在线观看网站黄不卡| 日韩免费一区二区三区在线播放| 久久久久久久久久久99999| 国产精品精品国产色婷婷| 一区二区三区不卡在线观看| 日韩av不卡一区二区| 国产精品69久久久久水密桃| 色噜噜狠狠成人中文综合| 在线播放视频一区| 久久久久久久久免费| 亚洲美女精品一区| 捆绑紧缚一区二区三区视频| 成人激情午夜影院| 欧美裸体一区二区三区| 国产性色一区二区| 亚洲va中文字幕| 成人久久18免费网站麻豆| 欧美日韩国产高清一区| 亚洲国产精品t66y| 人人爽香蕉精品| 91黄色激情网站| 精品国产髙清在线看国产毛片| 中文字幕一区二区日韩精品绯色| 日韩av网站免费在线| 97精品国产露脸对白| 精品剧情在线观看| 亚洲成人福利片| 成人激情小说网站| 精品欧美一区二区在线观看| 一区二区三区不卡视频在线观看| 美女www一区二区| 色屁屁一区二区| 国产精品女人毛片| 青青草伊人久久| 欧美日韩国产首页| 亚洲人成在线播放网站岛国| 国产成人免费在线观看不卡| 欧美高清精品3d| 亚洲一区自拍偷拍| aaa国产一区| 久久精品无码一区二区三区| 日韩电影网1区2区| 欧美性大战久久| 一区二区三区免费在线观看| voyeur盗摄精品| 国产精品视频yy9299一区| 麻豆精品一区二区| 在线综合亚洲欧美在线视频 | 国产精品国产三级国产a| 久久精品二区亚洲w码| 欧美日韩高清不卡| 亚洲综合另类小说| 日本电影欧美片| 国产精品久久久久久久久久久免费看| 国产精品资源站在线| 久久综合久久综合亚洲| 国产专区综合网| 久久综合给合久久狠狠狠97色69| 日韩影院免费视频| 日韩天堂在线观看| 另类中文字幕网| 久久午夜免费电影| 国产精品一区二区久久不卡 | 日韩中文欧美在线|