⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ttcreateperiodictask.cpp

📁 一个很棒的网络控制系统仿真软件
💻 CPP
字号:
#define KERNEL_MATLAB#include "../ttkernel.h" RTsys *rtsys;#include "../createpertask.cpp"#include "getrtsys.cpp"void mexFunction( int nlhs, mxArray *plhs[],                  int nrhs, const mxArray *prhs[] ){  rtsys = getrtsys() ; // Get pointer to rtsys   // Check number and type of arguments.   if (nrhs < 5 || nrhs > 6) {    mexErrMsgTxt("ttCreatePeriodicTask: Wrong number of input arguments! \nUsage: ttCreatePeriodicTask(name, release, period, priority, codefcn)\n       ttCreatePeriodicTask(name, release, period, priority, codefcn, data)");  }  if (mxIsChar(prhs[0]) != 1) {    mexErrMsgTxt("ttCreatePeriodicTask: name must be a string");  }  if (!mxIsDoubleScalar(prhs[1])) {    mexErrMsgTxt("ttCreatePeriodicTask: release must be a double scalar");  }  if (!mxIsDoubleScalar(prhs[2])) {    mexErrMsgTxt("ttCreatePeriodicTask: period must be a double scalar");  }  if (!mxIsDoubleScalar(prhs[3])) {    mexWarnMsgTxt("ttCreatePeriodicTask: priority must be a double scalar");  }  if (mxIsChar(prhs[4]) != 1 || mxGetM(prhs[4]) != 1) {    mexErrMsgTxt("ttCreatePeriodicTask: codeFcn must be a non-empty string");  }    char name[100];  mxGetString(prhs[0], name, 100);  double release = *mxGetPr(prhs[1]);  if (release < -EPS) {    release = 0.0;    mexWarnMsgTxt("ttCreatePeriodicTask: negative release changed to zero");  }    double period = *mxGetPr(prhs[2]);  double priority = *mxGetPr(prhs[3]);  char codeFcn[100];  mxGetString(prhs[4], codeFcn, 100);  // Make sure that the code function exists in Matlab path  mxArray *lhs[1];  mxArray *rhs[1];  rhs[0] = mxDuplicateArray(prhs[4]);  mexCallMATLAB(1, lhs, 1, rhs, "exist");  int number = (int) *mxGetPr(lhs[0]);  if (number == 0) {    char buf[200];    sprintf(buf, "ttCreatePeriodicTask: codeFcn '%s' not in path!", codeFcn);    mexErrMsgTxt(buf);  }  if (ttCreatePeriodicTask(name, release, period, priority, NULL)) {        // Add name of code function (m-file) and data variable    TaskNode *n = (TaskNode*) rtsys->taskList->getLast();        n->getTask()->codeFcnMATLAB = new char[strlen(codeFcn)+1];    strcpy(n->getTask()->codeFcnMATLAB, codeFcn);        char dataname[100];    char blockhandle[16];    if (nrhs == 6) { // data specified      // Create globally unique name for data: gcbh + taskname + "_task_"      mexCallMATLAB(1, lhs, 0, NULL, "gcbh"); // Get block handle      sprintf(blockhandle, "%f", *(mxGetPr(lhs[0])));      strcpy(dataname, blockhandle);      strcat(dataname, name);      strcat(dataname, "_task_");            // Write data structure to global workspace      mxArray* data = mxDuplicateArray(prhs[5]);      mexPutVariable("global", dataname, data);      mxDestroyArray(data);            n->getTask()->dataMATLAB = new char[strlen(dataname)+1];      strcpy(n->getTask()->dataMATLAB, dataname);    }  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -