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

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

?? piddlg.cpp

?? 實現了PID控制的仿真顯示
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// PIDDlg.cpp : implementation file
//

#include "stdafx.h"
#include "PID.h"
#include "PIDDlg.h"
#include <stdlib.h>
#include <math.h>
#include <string.h>
#include <float.h>
 

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

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

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()

/////////////////////////////////////////////////////////////////////////////
// CPIDDlg dialog

CPIDDlg::CPIDDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CPIDDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CPIDDlg)
	m_divTd = 0.0f;
	m_integralTi = 0.0f;
	m_integralV = 0.0f;
	m_paramK1 = 0.0f;
	m_paramT1 = 0.0f;
	m_preparamI = 0.0f;
	m_preparamK = 0.0f;
	m_proportionKp = 0.0f;
	m_sampleT = 0.0f;
	m_stepR0 = 0.0f;
	m_stepU0 = 0.0f;
	m_chuanxian = 0.0f;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CPIDDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CPIDDlg)
	DDX_Text(pDX, IDC_DIVTd, m_divTd);
	DDX_Text(pDX, IDC_INTEGRALTi, m_integralTi);
	DDX_Text(pDX, IDC_INTEGRALVALUE, m_integralV);
	DDX_Text(pDX, IDC_PARAMK1, m_paramK1);
	DDX_Text(pDX, IDC_PARAMT1, m_paramT1);
	DDX_Text(pDX, IDC_PREPARAMI, m_preparamI);
	DDX_Text(pDX, IDC_PREPARAMK, m_preparamK);
	DDX_Text(pDX, IDC_PROPORTIONKp, m_proportionKp);
	DDX_Text(pDX, IDC_SAMPLET, m_sampleT);
	DDX_Text(pDX, IDC_STEPR0, m_stepR0);
	DDX_Text(pDX, IDC_STEPU0, m_stepU0);
	DDX_Text(pDX, IDC_EDIT_CHUXIAN, m_chuanxian);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CPIDDlg, CDialog)
	//{{AFX_MSG_MAP(CPIDDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_CONFIG, OnConfig)
	ON_BN_CLICKED(IDC_CHUANDI, OnChuandi)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CPIDDlg message handlers

BOOL CPIDDlg::OnInitDialog()
{
	CDialog::OnInitDialog();
	UpdateData(true);

	// 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
	for(int i=0;i<100;i++)
	{
		YI[i]=0;
	}
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CPIDDlg::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 CPIDDlg::OnPaint() 
{
	CPaintDC dc(this); // device context for painting
	 	// TODO: Add your message handler code here
	show_data();
	
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CPIDDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}
void CPIDDlg::show_data()
{ 
	CWnd* pWnd=GetDlgItem(IDC_STATIC_SHOW);	
	pWnd->Invalidate();
	pWnd->UpdateWindow();
	CDC *pDC=pWnd->GetDC();
//	pDC->SetBkColor(RGB(0,255,255));
	CPen pen_bian,*poldpen1;
	pen_bian.CreatePen(PS_SOLID,2,RGB(0,0,255));

	poldpen1=pDC->SelectObject(&pen_bian);

    CPen pen_bian2,*poldpen2;
   	pen_bian2.CreatePen(PS_SOLID,1,RGB(255,0,0));
	poldpen2=pDC->SelectObject(&pen_bian2);

	CPen pen_grid,*poldpen3;
	pen_grid.CreatePen(PS_DOT,1,RGB(0,0,255));
	const int num=100;
    double initX[num];//={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20};
    double initY[num];//={2,5,1,8,8,17,25,35.2,40.1,50,33.3,28.4,22.2,24.1,26.2,18.3,14.1,24.7,18,6};
	//分別取得X和Y最大值,最小值
	initX[0]=0;
	initY[0]=0;
	 for(int i=0;i<num;i++)
	 {
		 initX[i]=i+1;
		 initY[i]=i+1;
	 }
	UpdateData();
 	double U[num];
	   U[0]=0;
   double Y[num];
	    Y[0]=0;
	    Y[1]=0;
      for( i=2;i<num;i++)
	   {
		   U[i-1]=m_stepU0;		  
		  double a=(-1)*(m_sampleT)/(m_paramT1);
		  double b=(-2)*(m_sampleT)/(m_paramT1);
		  double c= exp(a);
		  double d= exp(b);
		   Y[i]=2*c*(Y[i-1])-d*(Y[i-2])+(m_paramK1)*(1-c+a*c)*(U[i-1])-(m_paramK1)*(1-c+a)*c*(U[i-2]);
	  }
       double maxX=initX[0];
       double minX=initX[0];
       double maxY=initY[0];
       double minY=initY[0];
       double MAXY=Y[0];
       double MINY=Y[0];
       for(  i=0;i<num;i++)
       {
              if(initX[i]>maxX)
                     maxX=initX[i];
              if(initX[i]<minX)
                     minX=initX[i];
              if(initY[i]>maxY)
                     maxY=initY[i];
              if(initY[i]<minY)
                     minY=initY[i];
			  if(Y[i]>MAXY)
			         MAXY=Y[i];
			  if(Y[i]<MINY)
			         MINY=Y[i];
       } 
// m_chuanxian=MAXY;	  
      //如果原點必須在X軸上,加上下面2行,否則注釋掉

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91黄色激情网站| 自拍av一区二区三区| 99精品欧美一区二区蜜桃免费| 日韩和欧美一区二区三区| 亚洲自拍另类综合| 一区二区三区在线视频免费| 亚洲欧美日韩中文播放| 国产精品久久久久婷婷二区次| 精品国产乱子伦一区| 欧美一级二级三级乱码| 日韩午夜在线观看视频| 2024国产精品视频| 久久久精品黄色| 国产精品不卡视频| 亚洲卡通动漫在线| 亚洲一二三四久久| 亚洲国产三级在线| 久久精品国产99| 成人一级黄色片| 欧美三级在线视频| 日韩欧美成人午夜| 国产精品女同互慰在线看| 亚洲欧洲精品成人久久奇米网| 亚洲欧美一区二区不卡| 秋霞午夜av一区二区三区| 国产精品自拍网站| 色婷婷久久久久swag精品 | 国产成人精品亚洲午夜麻豆| 亚洲成在线观看| 久99久精品视频免费观看| 国产成人8x视频一区二区 | 欧美日韩在线播放三区四区| 欧美视频在线一区二区三区| 日韩欧美电影在线| 国产精品超碰97尤物18| 日韩中文字幕一区二区三区| 国产成人免费在线观看不卡| 91精彩视频在线| 精品久久久久久久久久久久久久久久久 | 亚洲精品日产精品乱码不卡| 一区二区三区精品视频在线| 久久91精品久久久久久秒播| 成人久久久精品乱码一区二区三区 | 丝袜美腿亚洲综合| 成人高清伦理免费影院在线观看| 色综合视频一区二区三区高清| 欧美不卡在线视频| 一区二区三区四区亚洲| 国产成人高清视频| 91麻豆成人久久精品二区三区| 日韩一区二区中文字幕| 一区二区三区不卡视频在线观看 | 欧美α欧美αv大片| 一区二区在线观看视频在线观看| 国产一区二三区| 制服丝袜av成人在线看| 一区二区三区色| 成人a级免费电影| 欧美精品一区在线观看| 午夜成人免费视频| 成人动漫中文字幕| 国产欧美综合在线| 国产精品一区二区三区网站| 精品国产伦理网| 精品综合久久久久久8888| 69av一区二区三区| 亚洲夂夂婷婷色拍ww47| 一本大道综合伊人精品热热| 国产精品国产a级| 国产成人8x视频一区二区| 国产视频在线观看一区二区三区| 国内精品国产三级国产a久久| 欧美日韩国产一级| 婷婷亚洲久悠悠色悠在线播放| 欧美伊人久久久久久久久影院| 亚洲美女视频在线| 99久久精品国产观看| 国产精品色一区二区三区| 国产激情视频一区二区在线观看| 精品国产一区二区精华| 国产一区二区在线观看免费 | 国产一区二区三区蝌蚪| 2023国产精华国产精品| 亚洲第一在线综合网站| 5566中文字幕一区二区电影| 日本视频一区二区| 欧美一级片在线看| 久久成人久久鬼色| 久久影音资源网| 麻豆国产精品官网| 日韩精品一区二区三区三区免费| 日日夜夜精品视频免费| 精品免费日韩av| 国产一区二区看久久| 欧美大片一区二区三区| 国产福利一区在线| 亚洲人成网站在线| 宅男在线国产精品| 91视频观看视频| 日韩欧美国产小视频| 久久综合九色综合欧美98| 国产精品区一区二区三区| 成人午夜免费视频| 中文字幕一区在线| 666欧美在线视频| 国产成人精品免费一区二区| 亚洲美女视频一区| 精品奇米国产一区二区三区| 成人av片在线观看| 国产亚洲欧洲997久久综合 | 91社区在线播放| 日韩电影免费在线看| 国产色91在线| 欧美日韩国产不卡| 成人免费高清在线| 日本不卡高清视频| 日韩一区欧美小说| 日韩一区二区免费在线观看| 97se亚洲国产综合自在线| 亚洲天天做日日做天天谢日日欢 | 亚洲欧美一区二区三区极速播放| 日韩视频免费观看高清完整版在线观看 | 亚洲图片欧美激情| 在线播放一区二区三区| 盗摄精品av一区二区三区| 午夜影院在线观看欧美| 日韩无一区二区| 91丝袜美女网| 国产成人激情av| 精品一区二区三区免费| 亚洲国产另类精品专区| 中文字幕一区二区三区色视频| 欧美亚洲愉拍一区二区| 不卡一区二区中文字幕| 精品在线一区二区| 日韩高清一级片| 亚洲一区二区美女| 一区二区三区在线观看网站| 国产网站一区二区三区| 色狠狠桃花综合| 成人激情午夜影院| 国产不卡在线播放| 国产一区二区三区免费播放| 美女视频一区二区| 日产国产欧美视频一区精品| 国产精品每日更新在线播放网址| 亚洲精品一区二区三区蜜桃下载| 欧美一区二区三区小说| 欧美在线观看一二区| 成人精品小蝌蚪| 成人网页在线观看| 青青国产91久久久久久| 午夜激情久久久| 日韩黄色免费网站| 午夜视频一区二区| 婷婷激情综合网| 日日夜夜精品视频免费| 午夜精品久久久久久| 亚洲国产精品人人做人人爽| 亚洲国产精品一区二区久久| 亚洲成人一区在线| 青娱乐精品在线视频| 久久成人综合网| 丰满亚洲少妇av| 91小视频免费观看| 欧美亚洲综合久久| 日韩一级视频免费观看在线| 欧美一区三区四区| 2021中文字幕一区亚洲| 国产精品午夜免费| 自拍偷拍国产精品| 日精品一区二区| 国产精品99久久久久| 成人黄色小视频| 在线免费观看视频一区| 欧美美女一区二区| 精品久久久久香蕉网| 国产精品传媒入口麻豆| 亚洲一区二区偷拍精品| 亚洲成人动漫在线观看| 精品一区二区三区欧美| 白白色 亚洲乱淫| 色综合视频在线观看| 日韩美女一区二区三区四区| 久久久国产精品午夜一区ai换脸| 亚洲人吸女人奶水| 亚洲视频一区二区免费在线观看| 亚洲激情在线激情| 六月婷婷色综合| 99久久99久久精品免费看蜜桃| 欧美亚洲国产一区二区三区va | 亚洲三级电影全部在线观看高清| 亚洲一区二区三区美女| 国产91精品久久久久久久网曝门 | 一本色道综合亚洲| 精品国产免费人成在线观看| 亚洲免费观看高清| 国产成人午夜高潮毛片| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 国产一区二三区|