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

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

?? 模糊控制dlg.cpp

?? 設計算法求出模糊控制表
?? CPP
字號:
// 模糊控制Dlg.cpp : implementation file
//

#include "stdafx.h"
#include "模糊控制.h"
#include "模糊控制Dlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About
static double cc=0;
class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyDlg dialog

CMyDlg::CMyDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CMyDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CMyDlg)
	m_z = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CMyDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CMyDlg)
	DDX_Control(pDX, IDC_EDIT2, m_y_Edit);
	DDX_Control(pDX, IDC_EDIT1, m_x_Edit);
	DDX_Text(pDX, IDC_EDIT3, m_z);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CMyDlg, CDialog)
	//{{AFX_MSG_MAP(CMyDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyDlg message handlers

BOOL CMyDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CMyDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CMyDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CMyDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}



//形成控制表
int CMyDlg::contorol(double X, double Y)//X和Y分別對e和差值e的模糊化表
{ int x,y;
	if (X>4)
	{
		x=4;
	} 
	else if (X<-4)
	{
		x=-4;
	} 
	else
	{
		x=int(X);
	}
	if (Y>2)
	{
		y=2;
	} 
	else if (Y<-2)
	{
		y=-2;
	} 
	else
	{
		y=int(Y);
	}
	
//e的模糊化
double PBe[9],PSe[9],Ze[9],NSe[9],NBe[9];
int i=0;
for ( i=0;i<9;i++)
{
	PBe[i]=0;PSe[i]=0;Ze[i]=0;NSe[i]=0;NBe[i]=0;
}
PBe[7]=0.5;PBe[8]=1;
PSe[5]=0.5;PSe[6]=1;PSe[7]=0.5;
Ze[3]=0.5;Ze[4]=1;Ze[5]=0.5;
NSe[1]=0.5;NSe[2]=1;NSe[3]=0.5;
NBe[0]=1;NBe[1]=0.5;NBe[2]=0.5;

//差值 e 的模糊化
int PBde[5],PSde[5],Zde[5],NSde[5],NBde[5];
for ( i=0;i<=4;i++)
{
	PBde[i]=0;PSde[i]=0;Zde[i]=0;NSde[i]=0;NBde[i]=0;
}
PBde[4]=1;PSde[3]=1;Zde[2]=1;NSde[1]=1;NBde[0]=1;

//u 的模糊化
double PBu[7],PSu[7],Zu[7],NSu[7],NBu[7];
for ( i=0;i<7;i++)
{
	PBu[i]=0;PSu[i]=0;Zu[i]=0;NSu[i]=0;NBu[i]=0;
}
PBu[5]=0.5;PBu[6]=1;
PSu[4]=1;PSu[5]=0.5;
Zu[2]=0.5;Zu[3]=1;Zu[4]=0.5;
NSu[1]=1;NSu[2]=0.5;
NBu[0]=1;NBu[1]=0.5; 



	int de=0,flag=-1;//de不為0的項的模糊數 flag為項的標志,  對差值e 即規則B
	//令NB,NS,Z,PS,PB分別為0,1,2,3,4
	if(PBde[y+2]) {de=0;flag=4;}
	else if(PSde[y+2]) {de=1;flag=3;}
	else if(Zde[y+2])  {de=1;flag=2;}
	else if(NSde[y+2]) {de=1;flag=1;}
	else if(NBde[y+2]) {de=1;flag=0;}

	double f=0,e=0,dai[3][3]={0};//不為0的項的模糊數, 對e 即規則 A
    int q=0; 
	   if(PBe[x+4])
	   { 
		e=PBe[x+4];
		   if(flag>-1)
		{ 
			f=Fetch(4,flag);dai[q][0]=e;dai[q][1]=de;dai[q][2]=f;q++;
		}
	   }

	   if(PSe[x+4])
	   {
		   e=PSe[x+4];
           if(flag>-1)
		   { 
			   f=Fetch(3,flag);dai[q][0]=e;dai[q][1]=de;dai[q][2]=f;q++;
		   }
	   }
	if(Ze[x+4])  
	{
		e=Ze[x+4];
	    if(flag>-1)
		{f=Fetch(2,flag);dai[q][0]=e;dai[q][1]=de;dai[q][2]=f;q++;}
	}
	if(NSe[x+4]) 
	{
		e=NSe[x+4];
		if(flag>-1) 
		{f=Fetch(1,flag);dai[q][0]=e;dai[q][1]=de;dai[q][2]=f;q++;}
	}
	if(NBe[x+4])
	{
		e=NBe[x+4];
		if(flag>-1){f=Fetch(0,flag);dai[q][0]=e;dai[q][1]=de;dai[q][2]=f;q++;}
	}
	//求出C撇  至多為3個
	double c[7],c1[7],c2[7],c3[7];
	for (i=0;i<7;i++)
	{
      c[i]=0;c1[i]=0;c2[i]=0,c3[i]=0;
	}

	for (i=0;i<7;i++)
	{
    	if(dai[0][2]==0)  cc=NBu[i];
		if(dai[0][2]==1)  cc=NSu[i]; 
		if(dai[0][2]==2)  cc=Zu[i];
		if(dai[0][2]==3)  cc=PSu[i];
		if(dai[0][2]==4)  cc=PBu[i];
        c1[i]=minimum(dai[0][0],dai[0][1],cc);
		c2[i]=minimum(dai[1][0],dai[1][1],cc);
		c3[i]=minimum(dai[2][0],dai[2][1],cc);
	}

	for (i=0;i<7;i++)
	{
		c[i]=maximum(c1[i],c2[i],c3[i]);
	}
//重心法算出Z
	double g=0,p=0;
	for (i=0;i<7;i++)
	{
		if(c[i])
		{
			g+=c[i]*(i-3);
			p+=c[i];
		} 
	}
	int z=0; double z1=0,z2=0;//計算權值
	z=int(g/p); z1=g/p; z2=z1-z;
	if(z2>0.5&&z2<1) 
		z=z+1;
	

return z;
}



	//查找有效規則表

int CMyDlg::Fetch(int a, int b)  //規則 C
{
	
//規則表確定
//令NB,NS,Z,PS,PB分別為0,1,2,3,4
int G[5][5]={4,4,3,2,0,
             4,4,3,1,0,
			 4,3,2,1,0,
			 4,3,1,0,0,
			 4,2,1,0,0};
   return G[a][b];
}



void CMyDlg::OnButton1() 
{
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);
	char cstrItem1[10], cstrItem2[10];
	double dfItem1,dfItem2;
	int dfResult;
	char cBuffer[50];
	m_x_Edit.GetWindowText(cstrItem1,10);
	m_y_Edit.GetWindowText(cstrItem2,10);
	dfItem1=atof((LPCTSTR)cstrItem1);
	dfItem2=atof((LPCTSTR)cstrItem2);
	dfResult=contorol(dfItem1, dfItem2);
	_gcvt(dfResult,10,cBuffer);
	m_z=(LPCTSTR)cBuffer;
	UpdateData(FALSE);

}



double CMyDlg::minimum(double a, double b, double c)
{
  return min(min(a,b),c);
}



double CMyDlg::maximum(double a, double b, double c)
{
   return max(max(a,b),c); 
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性一二三区| 欧洲日韩一区二区三区| 中文字幕在线观看不卡| 欧美午夜不卡视频| 狠狠色丁香久久婷婷综| 亚洲精品一二三| 精品国产精品一区二区夜夜嗨| 不卡的看片网站| 日韩精品久久理论片| 一区二区中文字幕在线| 日韩精品在线看片z| 色av成人天堂桃色av| 国产伦精品一区二区三区免费迷 | caoporn国产一区二区| 午夜精品久久一牛影视| 日韩专区欧美专区| 国产欧美精品一区| 日韩免费一区二区| 欧美日韩亚洲另类| 色综合天天综合狠狠| 国产又粗又猛又爽又黄91精品| 夜夜操天天操亚洲| 国产精品色哟哟| 久久免费看少妇高潮| 91精品国产综合久久福利软件| 色综合天天做天天爱| 国产精品一品二品| 久久精品噜噜噜成人av农村| 午夜激情一区二区三区| 亚洲精品免费播放| 国产精品成人免费在线| 国产日韩欧美一区二区三区乱码 | 91久久香蕉国产日韩欧美9色| 国产suv精品一区二区6| 六月婷婷色综合| 日本中文字幕一区二区有限公司| 一区二区视频在线看| 国产精品麻豆久久久| 国产欧美一区二区精品性色| 久久综合九色综合欧美98| 欧美一级生活片| 91精品国产一区二区三区蜜臀| 色婷婷久久一区二区三区麻豆| 99久久综合99久久综合网站| 国产成人精品三级| 国产精品一区二区在线看| 国产乱码精品一区二区三区av| 久久99国产精品久久99| 国产在线视频不卡二| 久久69国产一区二区蜜臀| 美女一区二区视频| 激情文学综合网| 国产精品一区二区果冻传媒| 国产精品 欧美精品| 国产suv精品一区二区三区| 国产成人精品aa毛片| 成人免费毛片app| 91视频91自| 91福利在线观看| 色哟哟欧美精品| 日韩一区二区三区av| 欧美日本在线播放| 这里只有精品99re| 欧美电视剧在线观看完整版| 久久夜色精品一区| 中文字幕亚洲电影| 亚洲精品成人悠悠色影视| 一区二区三区在线免费观看 | 91蜜桃婷婷狠狠久久综合9色| 91视频com| 欧美日韩国产在线观看| 欧美一区二区播放| 国产婷婷一区二区| 国产精品女上位| 亚洲欧美激情小说另类| 亚洲视频精选在线| 日韩经典中文字幕一区| 免费美女久久99| 韩国av一区二区三区| 韩国成人福利片在线播放| 播五月开心婷婷综合| 欧美熟乱第一页| 精品少妇一区二区三区日产乱码 | 亚洲九九爱视频| 日韩精品国产欧美| 国产伦精品一区二区三区免费迷| 91网站在线播放| 欧美一区二区三区爱爱| 国产精品三级久久久久三级| 亚洲成av人片一区二区梦乃| 精品写真视频在线观看| 91在线观看污| 91精品国产免费| 国产精品久久久久久久久免费丝袜 | 欧美高清激情brazzers| 久久天天做天天爱综合色| 亚洲精品亚洲人成人网 | 欧美色手机在线观看| 精品国产免费一区二区三区四区 | 亚洲精品乱码久久久久久| 日韩av一区二| 99视频精品在线| 91精品在线观看入口| 国产精品久久久久久久浪潮网站| 日韩黄色免费网站| 99re这里只有精品首页| 欧美一卡2卡三卡4卡5免费| 亚洲免费观看高清完整版在线| 蜜桃视频在线观看一区二区| 色天使久久综合网天天| 2023国产精华国产精品| 午夜精品久久久久久久久| 不卡在线观看av| 精品嫩草影院久久| 夜夜嗨av一区二区三区网页| 高清beeg欧美| 日韩欧美综合在线| 亚洲mv在线观看| 97久久超碰国产精品电影| 欧美xfplay| 首页欧美精品中文字幕| 99精品视频免费在线观看| 精品国产乱码久久久久久老虎| 五月婷婷久久综合| 色激情天天射综合网| 国产精品婷婷午夜在线观看| 免费美女久久99| 欧美日韩国产电影| 国产喂奶挤奶一区二区三区 | 欧美三区在线观看| 国产精品毛片久久久久久久 | 欧美大片顶级少妇| 亚洲成人资源在线| 在线亚洲一区二区| 国产精品不卡在线| 国产成人免费视频| 久久久青草青青国产亚洲免观| 六月丁香婷婷久久| 欧美一区在线视频| 天天综合网 天天综合色| 欧美在线视频全部完| 亚洲日本va午夜在线影院| 国产高清久久久久| 精品精品欲导航| 久久国产麻豆精品| 香蕉乱码成人久久天堂爱免费| 韩国av一区二区三区四区| 欧美一区二区免费视频| 亚洲午夜久久久久久久久久久| 成人app网站| 日本一区二区三级电影在线观看| 极品瑜伽女神91| 精品国产乱码久久久久久久久| 免费成人av在线播放| 91精品国产综合久久久蜜臀粉嫩| 偷窥国产亚洲免费视频| 欧美日韩亚洲综合在线| 亚洲大片一区二区三区| 欧美亚洲另类激情小说| 午夜久久久久久| 日韩欧美在线影院| 久久精品国产秦先生| 欧美不卡123| 国产精品99久| 国产精品成人一区二区艾草| 色综合久久99| 丝袜美腿亚洲一区二区图片| 欧美一级高清片| 精品影视av免费| 久久精品视频一区二区三区| 99久久精品99国产精品| 亚洲免费在线视频| 91捆绑美女网站| 亚洲一区二区三区不卡国产欧美 | 欧美色网一区二区| 亚洲第一二三四区| 欧美一区二区性放荡片| 韩国精品在线观看| 成人免费在线播放视频| 在线免费视频一区二区| 一区二区高清免费观看影视大全| 欧美精品自拍偷拍动漫精品| 日本午夜一区二区| 国产欧美精品一区aⅴ影院| av激情成人网| 图片区小说区国产精品视频| 在线播放视频一区| 激情欧美一区二区| 亚洲欧美综合色| 欧美日本一区二区| 狠狠色狠狠色综合日日91app| 国产精品嫩草久久久久| 色婷婷精品久久二区二区蜜臀av| 日韩精品视频网站| 久久精品人人做人人爽97| 91看片淫黄大片一级在线观看| 三级不卡在线观看| 国产精品乱码人人做人人爱| 在线看日韩精品电影| 日韩不卡一区二区|