您当前的位置:首页 > IT编程 > C++
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:C++ ssSetNumInputPorts函数代码示例

51自学网 2021-06-03 08:18:03
  C++
这篇教程C++ ssSetNumInputPorts函数代码示例写得很实用,希望能帮到您。

本文整理汇总了C++中ssSetNumInputPorts函数的典型用法代码示例。如果您正苦于以下问题:C++ ssSetNumInputPorts函数的具体用法?C++ ssSetNumInputPorts怎么用?C++ ssSetNumInputPorts使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。

在下文中一共展示了ssSetNumInputPorts函数的26个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的C++代码示例。

示例1: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S) {	bool dataPort;	ssSetNumSFcnParams(S,3);	if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {		return; /* Parameter mismatch will be reported by Simulink */	}	dataPort = PARAM(2)[0];	if (dataPort) {		if (!ssSetNumInputPorts(S,2)) return;		ssSetInputPortWidth(S,1,DYNAMICALLY_SIZED);		ssSetInputPortDirectFeedThrough(S,1,1);	} else {		if (!ssSetNumInputPorts(S,1)) return;	}	ssSetInputPortWidth(S,0,1);	ssSetInputPortDirectFeedThrough(S,0,1);	ssSetNumContStates(S,0);	ssSetNumDiscStates(S,0);	if (!ssSetNumOutputPorts(S,0)) return;	ssSetInputPortDataType(S, 0, DYNAMICALLY_TYPED);	ssSetNumSampleTimes(S,1);	ssSetNumRWork(S,1);	ssSetNumIWork(S,1);	ssSetNumPWork(S,2);	ssSetNumModes(S,0);	ssSetNumNonsampledZCs(S,0);	ssSetOptions(S,0);}
开发者ID:rhopfer,项目名称:rtairos,代码行数:33,


示例2: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *    The sizes information is used by Simulink to determine the S-function *    block's characteristics (number of inputs, outputs, states, etc.). */static void mdlInitializeSizes(SimStruct *S){    ssSetNumSFcnParams(S, 0);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        return;    }    if (!ssSetNumInputPorts(S, 0)) return;    if (!ssSetNumOutputPorts(S, 1)) return;    ssSetOutputPortWidth(S, 0, 1);    ssSetOutputPortDataType(S, 0, SS_DOUBLE);  /* same as clock block */    ssSetOutputPortConstOutputExprInRTW(S, 0, 1);    ssSetNumSampleTimes(S, 1);    /* specify the sim state compliance to be same as a built-in block */    ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);    ssSetOptions(S,                 SS_OPTION_WORKS_WITH_CODE_REUSE |                 SS_OPTION_USE_TLC_WITH_ACCELERATOR);}
开发者ID:x-sven,项目名称:himbeere,代码行数:30,


示例3: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *   Setup sizes of the various vectors. */static void mdlInitializeSizes(SimStruct *S){    DECL_AND_INIT_DIMSINFO(inputDimsInfo);    DECL_AND_INIT_DIMSINFO(outputDimsInfo);    ssSetNumSFcnParams(S, NPARAMS);     if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {	 return; /* Parameter mismatch will be reported by Simulink */     }    ssSetNumContStates(S, NUM_CONT_STATES);    ssSetNumDiscStates(S, NUM_DISC_STATES);    if (!ssSetNumInputPorts(S, NUM_INPUTS)) return;    /*Input Port 0 */    ssSetInputPortWidth(S,  0, INPUT_0_WIDTH); /* */    ssSetInputPortDataType(S, 0, SS_UINT8);    ssSetInputPortComplexSignal(S,  0, INPUT_0_COMPLEX);    ssSetInputPortDirectFeedThrough(S, 0, INPUT_0_FEEDTHROUGH);    ssSetInputPortRequiredContiguous(S, 0, 1); /*direct input signal access*/    /*Input Port 1 */    ssSetInputPortWidth(S,  1, INPUT_1_WIDTH);    ssSetInputPortDataType(S, 1, SS_UINT8);    ssSetInputPortComplexSignal(S, 1, INPUT_1_COMPLEX);    ssSetInputPortDirectFeedThrough(S, 1, INPUT_1_FEEDTHROUGH);    ssSetInputPortRequiredContiguous(S, 1, 1); /*direct input signal access*/    /*Input Port 2 */    ssSetInputPortWidth(S,  2, INPUT_2_WIDTH); /* */    ssSetInputPortDataType(S, 2, SS_UINT8);    ssSetInputPortComplexSignal(S,  2, INPUT_2_COMPLEX);    ssSetInputPortDirectFeedThrough(S, 2, INPUT_2_FEEDTHROUGH);    ssSetInputPortRequiredContiguous(S, 2, 1); /*direct input signal access*/    if (!ssSetNumOutputPorts(S, NUM_OUTPUTS)) return;    /* Output Port 0 */    ssSetOutputPortWidth(S, 0, OUTPUT_0_WIDTH);    ssSetOutputPortDataType(S, 0, SS_DOUBLE);    ssSetOutputPortComplexSignal(S, 0, OUTPUT_0_COMPLEX);    /* Output Port 1 */    ssSetOutputPortWidth(S, 1, OUTPUT_1_WIDTH);    ssSetOutputPortDataType(S, 1, SS_DOUBLE);    ssSetOutputPortComplexSignal(S, 1, OUTPUT_1_COMPLEX);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    ssSetSimulinkVersionGeneratedIn(S, "8.4");    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, (SS_OPTION_EXCEPTION_FREE_CODE |                     SS_OPTION_USE_TLC_WITH_ACCELERATOR | 		     SS_OPTION_WORKS_WITH_CODE_REUSE));}
开发者ID:sarnold,项目名称:Hexapod,代码行数:64,


示例4: mdlInitializeSizes

/*=====================================* * Configuration and execution methods * *=====================================*/static void mdlInitializeSizes(SimStruct *S){#ifdef DEBUG	debug("mdlInitializeSizes entered./n");#endif    ssSetNumSFcnParams(S, NPAR);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {		mdlCheckParameters(S);        if (ssGetErrorStatus(S) != NULL) return;    }    ssSetNumContStates(S, 0);    ssSetNumDiscStates(S, 0);    if (!ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, NI);    ssSetInputPortDirectFeedThrough(S, 0, 1);    if (!ssSetNumOutputPorts(S, 1)) return;    ssSetOutputPortWidth(S, 0, NO);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE);#ifdef DEBUG	debug("mdlInitializeSizes left./n");#endif} /* mdlInitializeSizes */
开发者ID:sk4ld,项目名称:DVCP-VAM,代码行数:37,


示例5: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){  uint_T i;  ssSetNumSFcnParams(S, NUMBER_OF_PARAMS);#if defined(MATLAB_MEX_FILE)  if (ssGetNumSFcnParams(S) == ssGetSFcnParamsCount(S)) {    mdlCheckParameters(S);    if (ssGetErrorStatus(S) != NULL) {      return;    }  } else {    return;  }#endif  for (i = 0; i < NUMBER_OF_PARAMS; i++) {    ssSetSFcnParamNotTunable(S, i);  }  ssSetNumInputPorts(S, 0);  ssSetNumOutputPorts(S, 1);  ssSetOutputPortWidth(S, 0, 1);  ssSetNumContStates(S, 0);  ssSetNumDiscStates(S, 0);  ssSetNumSampleTimes(S, 1);  ssSetNumPWork(S,1);  ssSetNumIWork(S,1);  ssSetNumRWork(S,2);}
开发者ID:ArcEye,项目名称:RTAI,代码行数:28,


示例6: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *    The sizes information is used by Simulink to determine the S-function *    block's characteristics (number of inputs, outputs, states, etc.). */static void mdlInitializeSizes(SimStruct *S) {        ssSetNumSFcnParams(S, 0);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        return;    }    //  printf("URG: 111/n");    ssSetNumContStates(S, 0);    ssSetNumDiscStates(S, 0);        if (!ssSetNumInputPorts(S, 0)) return;        if (!ssSetNumOutputPorts(S, 1)) return;    ssSetOutputPortWidth(S, 0, 682);    ssSetOutputPortDataType(S, 0, SS_INT16);        ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);            /* Specify the sim state compliance to be same as a built-in block */    //  ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);        ssSetOptions(S, 0);        printf("URG: Inicializando driver URG-04LX.../n");}
开发者ID:BrianCarvajal,项目名称:iwalker-slam,代码行数:37,


示例7: mdlInitializeSizes

/* Function: mdlInitializeSizes */static void mdlInitializeSizes(SimStruct *S){    ssSetNumSFcnParams(S, 19);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        return; /* Parameter mismatch will be reported by Simulink */    }    ssSetNumContStates(S, 4); /* Number of continuous states*/    if (!ssSetNumInputPorts(S, 3)) return; /*Number of INPUTS*/    ssSetInputPortWidth(S, 0, 1);          /* In0.0: I */    ssSetInputPortWidth(S, 1, 1);          /* In1.0: x */    ssSetInputPortWidth(S, 2, 1);          /* In1.0: dx */    ssSetInputPortDirectFeedThrough(S, 0, 1);    ssSetInputPortDirectFeedThrough(S, 1, 1);    ssSetInputPortDirectFeedThrough(S, 2, 1);    if (!ssSetNumOutputPorts(S, 1)) return;/* Number of OUTPUTS */    ssSetOutputPortWidth(S, 0, 1);         /* Out0.0: deltaF */    ssSetNumSampleTimes(S, 1);    ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);    ssSetOptions(S, 0);}
开发者ID:JobAngel,项目名称:Job-IIT,代码行数:28,


示例8: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S) {    ssSetNumSFcnParams(S, NPAR);    if(ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S))   return;        if(!ssSetNumInputPorts(S, NIN)) return;        {        int_T   i;        for(i = 0; i < NIN; i++){            ssSetInputPortDirectFeedThrough(S, i, 1);            ssSetInputPortDataType(S, i, DYNAMICALLY_TYPED);        }                ssSetInputPortWidth(S, 0, IP0_SIZE);        ssSetInputPortWidth(S, 1, IP1_SIZE);        ssSetInputPortWidth(S, 2, IP2_SIZE);    }        if(!ssSetNumOutputPorts(S, NOUT))    return;    {            ssSetOutputPortWidth(S, 0, OP0_SIZE);			ssSetOutputPortWidth(S, 1, OP1_SIZE);    }        ssSetNumSampleTimes(S, 1);           sensorData.imuData_ptr = &imuData;	sensorData.gpsData_ptr = &gpsData;	sensorData.adData_ptr = &adData;	sensorData.accelData_ptr = &accelData;		init_control();}
开发者ID:PAAW,项目名称:mAEWing1,代码行数:33,


示例9: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){    ssSetNumSFcnParams(S, N_PARAMS);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        return;    }    ssSetNumContStates(S, N_STATES);    ssSetNumDiscStates(S, 0);    if (!ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, N_INPUTS);    ssSetInputPortDirectFeedThrough(S, 0, 1);    if (!ssSetNumOutputPorts(S, 1)) return;    ssSetOutputPortWidth(S, 0, N_OUTPUTS);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    ssSetOptions(S, 0);}
开发者ID:zapv1348,项目名称:fall_2015,代码行数:27,


示例10: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S) {    ssSetNumContStates(    S, 0);   /* number of continuous states           */    ssSetNumDiscStates(    S, 0);   /* number of discrete states             */#ifdef CO_DEBUG    printf("co_udp_receiver :: in mdlInitializeSizes/n");#endif    /* CO changes ... */    ssSetNumInputPorts(S, 0);   /* number of inputs                      */    /*ssSetInputPortWidth( S, 0, DYNAMICALLY_SIZED);*/    ssSetNumOutputPorts( S, 2);   /* number of outputs , all in one vector         */    //ssSetOutputPortMatrixDimensions(S, 0, TRAJ_NUM_POINTS,TRAJ_NUM_COLUMNS);    ssSetOutputPortWidth(S, 0, 7*SEGMENTNUMBER); // length of data    ssSetOutputPortWidth(S, 1, 1); // status output    /*ssSetInputPortDirectFeedThrough(S, 0, 1);    direct feedthrough flag               */    /*ssSetInputPortDirectFeedThrough(S, 1, 1); */  /* direct feedthrough flag               */    ssSetNumSampleTimes(   S, 0);   /* number of sample times                */    ssSetNumSFcnParams(    S, 2);   /* number of input arguments             */    ssSetNumRWork(         S, 0);   /* number of real work vector elements   */    ssSetNumIWork(         S, 0);   /* number of integer work vector elements*/    ssSetNumPWork(         S, 1);   /* number of pointer work vector elements*/#ifdef CO_DEBUG    printf("co_udp_receiver :: mdlInitializeSizes/n");#endif}
开发者ID:kaihumuc,项目名称:walking_imitation_toro,代码行数:28,


示例11: mdlInitializeSizes

static void mdlInitializeSizes( SimStruct *S )/* ======================================================================== */{	int_T port;	/* set number of expected parameters and check for a mismatch. */	ssSetNumSFcnParams( S, NUM_PARAMS );#if defined(MATLAB_MEX_FILE)	if ( ssGetNumSFcnParams( S ) == ssGetSFcnParamsCount( S ) )	{		mdlCheckParameters( S );		if ( ssGetErrorStatus( S ) != NULL )			return;	}else  {		return;	}#endif	/* sampling */	ssSetNumSampleTimes( S, PORT_BASED_SAMPLE_TIMES );	/* Set number of input ports and tunability */	ssSetSFcnParamTunable( S, DEVICE_INDEX, SS_PRM_NOT_TUNABLE );	/* set the resulting number of ports */	if ( !ssSetNumInputPorts( S, 1 ) )		return;	port = 0;	{		const Frame_T	inputsFrames	= ( (double) mxGetScalar( ssGetSFcnParam( S, USE_FRAMES ) ) > 0.0) ? FRAME_YES : FRAME_NO;		double		sample_time	= 1 / mxGetScalar( ssGetSFcnParam( S, SAMPLE_RATE ) );		const int_T	buf_length	= (int_T) (double) mxGetScalar( ssGetSFcnParam( S, FRAME_LENGTH ) );		const time_T	period		= (time_T) (sample_time * buf_length);		ssSetInputPortMatrixDimensions( S, port, buf_length, 1 );		ssSetInputPortComplexSignal( S, port, COMPLEX_YES );		ssSetInputPortDataType( S, port, SS_DOUBLE );		ssSetInputPortFrameData( S, port, inputsFrames );		ssSetInputPortDirectFeedThrough( S, port, 1 );		ssSetInputPortSampleTime( S, port, period );		ssSetInputPortOffsetTime( S, port, 0.0 );	}	/* Set number of output ports */	if ( !ssSetNumOutputPorts( S, 0 ) )		return;	/* data port properties */	/* Prepare work Vectors */	ssSetNumPWork( S, P_WORK_LENGTH );	ssSetNumIWork( S, I_WORK_LENGTH );	ssSetNumRWork( S, R_WORK_LENGTH );	ssSetNumModes( S, 0 );	ssSetNumNonsampledZCs( S, 0 );	/* Specify the sim state compliance to be same as a built-in block */	ssSetSimStateCompliance( S, USE_DEFAULT_SIM_STATE );	ssSetOptions( S, 0 );}
开发者ID:jocover,项目名称:Simulink-MATLAB-HackRF,代码行数:60,


示例12: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){   ssSetNumSFcnParams(S, 4);  /* B,x0,U,P Number of expected parameters */  if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S))    return;  else  {    if (CheckPar(S))      return;  }    ssSetNumContStates(S, (int) B(S,"CStates"));    ssSetNumDiscStates(S, (int) B(S,"DStates"));    if (!ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, (int)  (U(S,"Number")*B(S,"WaterIn")+B(S,"Setpoints")));    ssSetInputPortDirectFeedThrough(S, 0, (int) B(S,"Direct"));    ssSetInputPortRequiredContiguous(S, 0, 1); /*direct input signal access*/    if (!ssSetNumOutputPorts(S,1)) return;    ssSetOutputPortWidth(S, 0, (int) (U(S,"Number")*B(S,"WaterOut")+B(S,"Measurements")) );    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE |                 SS_OPTION_USE_TLC_WITH_ACCELERATOR);       }
开发者ID:Stimela,项目名称:Stimela,代码行数:34,


示例13: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *   Setup sizes of the various vectors. */static void mdlInitializeSizes(SimStruct *S){    ssSetNumSFcnParams(S, 0);    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        return; /* Parameter mismatch will be reported by Simulink */    }    if (!ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, DYNAMICALLY_SIZED);    ssSetInputPortDirectFeedThrough(S, 0, 1);    if (!ssSetNumOutputPorts(S,1)) return;    ssSetOutputPortWidth(S, 0, DYNAMICALLY_SIZED);    ssSetNumSampleTimes(S, 1);    /* specify the sim state compliance to be same as a built-in block */    ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S,                 SS_OPTION_WORKS_WITH_CODE_REUSE |                 SS_OPTION_EXCEPTION_FREE_CODE |                 SS_OPTION_USE_TLC_WITH_ACCELERATOR);    /*main();*/}
开发者ID:verivital,项目名称:slsf_randgen,代码行数:30,


示例14: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){    int i;    ssSetNumSFcnParams(S, NPARAMS);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        return;    }        for (i = 0; i < NPARAMS; i++)        ssSetSFcnParamTunable(S, i, 0);        ssSetNumContStates(S, 0);    ssSetNumDiscStates(S, 0);        if (!ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, 3);    ssSetInputPortRequiredContiguous(S, 0, true);    ssSetInputPortDirectFeedThrough(S, 0, 1);        if (!ssSetNumOutputPorts(S, 1)) return;    ssSetOutputPortWidth(S, 0, 7);        ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 2);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    }
开发者ID:AlonsoChurch,项目名称:T-MATS,代码行数:31,


示例15: mdlInitializeSizes

void mdlInitializeSizes(SimStruct *S)/* ======================================================================== */{    /* parameters */    ssSetNumSFcnParams(S, NUM_PARAMS);    #if defined(MATLAB_MEX_FILE)    if (ssGetNumSFcnParams(S) == ssGetSFcnParamsCount(S)) {        mdlCheckParameters(S);        if (ssGetErrorStatus(S) != NULL) return;    } else        return;    #endif    ssSetSFcnParamTunable(S, FREQUENCY,   SS_PRM_SIM_ONLY_TUNABLE);    ssSetSFcnParamTunable(S, BANDWIDTH,   SS_PRM_NOT_TUNABLE);    ssSetSFcnParamTunable(S, TXVGA_GAIN,  SS_PRM_SIM_ONLY_TUNABLE);    /* ports */    ssSetNumSampleTimes(S, 1);    if (!ssSetNumOutputPorts(S, 0) || !ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, DYNAMICALLY_SIZED);    ssSetInputPortComplexSignal(S, 0, COMPLEX_YES);    ssSetInputPortDataType(S, 0, SS_INT8);    ssSetInputPortDirectFeedThrough(S, 0, true);    ssSetInputPortOptimOpts(S, 0, SS_REUSABLE_AND_LOCAL);    /* work Vectors */    ssSetNumPWork(S, P_WORK_LENGTH);    ssSetNumIWork(S, 0);    ssSetNumRWork(S, NUM_PARAMS);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);    ssSetOptions(S, 0);}
开发者ID:PostalMuttonchops,项目名称:simulink-hackrf,代码行数:35,


示例16: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *   Setup sizes of the various vectors. */static void mdlInitializeSizes(SimStruct *S){    DECL_AND_INIT_DIMSINFO(outputDimsInfo);    ssSetNumSFcnParams(S, NPARAMS);     if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {	 return; /* Parameter mismatch will be reported by Simulink */     }    ssSetNumContStates(S, NUM_CONT_STATES);    ssSetNumDiscStates(S, NUM_DISC_STATES);    if (!ssSetNumInputPorts(S, NUM_INPUTS)) return;    if (!ssSetNumOutputPorts(S, NUM_OUTPUTS)) return;    ssSetOutputPortWidth(S, 0, OUTPUT_0_WIDTH);    ssSetOutputPortDataType(S, 0, SS_INT32);    ssSetOutputPortComplexSignal(S, 0, OUTPUT_0_COMPLEX);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, (SS_OPTION_EXCEPTION_FREE_CODE |		     SS_OPTION_WORKS_WITH_CODE_REUSE));}
开发者ID:Adeange1,项目名称:roboboat2015,代码行数:33,


示例17: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S) {    int_T msgType;    int_T initValLen;    ssSetNumSFcnParams(S,5);    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        return; /* Parameter mismatch will be reported by Simulink */    }    ssSetNumContStates(S,0);    ssSetNumDiscStates(S,0);    if (!ssSetNumInputPorts(S,0)) return;    msgType = (int_T)*mxGetPr(ssGetSFcnParam(S,0));    switch (msgType) {    case SUBSCRIBER_TWIST_STAMPED:    case PUBLISHER_POINT_STAMPED:        if (!ssSetNumOutputPorts(S,2)) return;        ssSetOutputPortWidth(S,1,2);        break;    default:        if (!ssSetNumOutputPorts(S,1)) return;    }    switch (msgType) {    case SUBSCRIBER_FLOAT64:    case SUBSCRIBER_INT32:    case SUBSCRIBER_BOOL:    case SUBSCRIBER_TIME:        ssSetOutputPortWidth(S,0,1);        break;    case SUBSCRIBER_FLOAT64ARRAY:        ssSetOutputPortWidth(S,0,DYNAMICALLY_SIZED);        break;    case SUBSCRIBER_TWIST:    case SUBSCRIBER_TWIST_STAMPED:        ssSetOutputPortWidth(S,0,6);        break;    case PUBLISHER_POINT:    case PUBLISHER_POINT_STAMPED:    case PUBLISHER_POSE2D:        ssSetOutputPortWidth(S,0,3);        break;    default:        ssSetErrorStatus(S, "Unknown message type!");        return;    }    initValLen = mxGetNumberOfElements(ssGetSFcnParam(S,2));    if (initValLen > 1) {        ssSetOutputPortWidth(S,0,initValLen);    }    ssSetNumSampleTimes(S,1);    ssSetNumRWork(S,0);    ssSetNumIWork(S,1);    ssSetNumPWork(S,2);    ssSetNumModes(S,0);    ssSetNumNonsampledZCs(S,0);    ssSetOptions(S,0);}
开发者ID:rhopfer,项目名称:rtairos,代码行数:60,


示例18: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){  ssSetNumSFcnParams(S, 0);  /* Number of expected parameters */  if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {    return;  }  ssSetNumContStates(S, 2);  ssSetNumDiscStates(S, 0);  if (!ssSetNumInputPorts(S, 0)) return;  if (!ssSetNumOutputPorts(S, 1)) return;  ssSetOutputPortWidth(S, 0, 2);  ssSetNumSampleTimes(S, 1);  ssSetNumRWork(S, 0);  ssSetNumIWork(S, 0);  ssSetNumPWork(S, 0);  ssSetNumModes(S, 0);  ssSetNumNonsampledZCs(S, 1);  ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);  ssSetOptions(S, 0);}
开发者ID:AkshayBabbar,项目名称:drake,代码行数:25,


示例19: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *    The sizes information is used by Simulink to determine the S-function *    block's characteristics (number of inputs, outputs, states, etc.). */static void mdlInitializeSizes(SimStruct *S){    /* See sfuntmpl_doc.c for more details on the macros below */    ssSetNumSFcnParams(S, NUM_PARAMS);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) == ssGetSFcnParamsCount(S))    {      mdlCheckParameters(S);      if (ssGetErrorStatus(S) != NULL)        /* Return if number of expected != number of actual parameters */        return;    }    else      return;    ssSetNumContStates(S, 0);    ssSetNumDiscStates(S, 0);    ssSetNumInputPorts(S, 0);    ssSetNumOutputPorts(S, 0);    ssSetNumSampleTimes(S, 1);    ssSetSFcnParamTunable(S, 0, 0);    ssSetSFcnParamTunable(S, 1, 0);    ssSetSFcnParamTunable(S, 2, 0);    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE | SS_OPTION_CAN_BE_CALLED_CONDITIONALLY);}
开发者ID:MWRobocon,项目名称:ETRobocon2014,代码行数:30,


示例20: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *   Setup sizes of the various vectors. */static void mdlInitializeSizes(SimStruct *S){    DECL_AND_INIT_DIMSINFO(outputDimsInfo);    ssSetNumSFcnParams(S, NPARAMS);     if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {	 return; /* Parameter mismatch will be reported by Simulink */     }    ssSetNumContStates(S, NUM_CONT_STATES);    ssSetNumDiscStates(S, NUM_DISC_STATES);    if (!ssSetNumInputPorts(S, NUM_INPUTS)) return;    if (!ssSetNumOutputPorts(S, NUM_OUTPUTS)) return;    /* Output Port 0 */    ssSetOutputPortWidth(S, 0, OUTPUT_0_WIDTH);    ssSetOutputPortDataType(S, 0, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 0, OUTPUT_0_COMPLEX);    /* Output Port 1 */    ssSetOutputPortWidth(S, 1, OUTPUT_1_WIDTH);    ssSetOutputPortDataType(S, 1, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 1, OUTPUT_1_COMPLEX);    /* Output Port 2 */    ssSetOutputPortWidth(S, 2, OUTPUT_2_WIDTH);    ssSetOutputPortDataType(S, 2, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 2, OUTPUT_2_COMPLEX);    /* Output Port 3 */    ssSetOutputPortWidth(S, 3, OUTPUT_3_WIDTH);    ssSetOutputPortDataType(S, 3, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 3, OUTPUT_3_COMPLEX);    /* Output Port 4 */    ssSetOutputPortWidth(S, 4, OUTPUT_4_WIDTH);    ssSetOutputPortDataType(S, 4, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 4, OUTPUT_4_COMPLEX);    /* Output Port 5 */    ssSetOutputPortWidth(S, 5, OUTPUT_5_WIDTH);    ssSetOutputPortDataType(S, 5, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 5, OUTPUT_5_COMPLEX);    /* Output Port 6 */    ssSetOutputPortWidth(S, 6, OUTPUT_6_WIDTH);    ssSetOutputPortDataType(S, 6, SS_SINGLE);    ssSetOutputPortComplexSignal(S, 6, OUTPUT_6_COMPLEX);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    ssSetSimulinkVersionGeneratedIn(S, "8.6");    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, (SS_OPTION_EXCEPTION_FREE_CODE |                     SS_OPTION_USE_TLC_WITH_ACCELERATOR | 		     SS_OPTION_WORKS_WITH_CODE_REUSE));}
开发者ID:gte999s,项目名称:QuadCopter,代码行数:62,


示例21: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *    The sizes information is used by Simulink to determine the S-function *    block's characteristics (number of inputs, outputs, states, etc.). */static void mdlInitializeSizes(SimStruct *S){    /* See sfuntmpl.doc for more details on the macros below */    ssSetNumSFcnParams(S, 0);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        return;    }    ssSetNumContStates(S, 1);  /* how many continuous states? */    ssSetNumDiscStates(S, 0);    if (!ssSetNumInputPorts(S, 1)) return;    ssSetInputPortWidth(S, 0, 1);    /*     * Set direct feedthrough flag (1=yes, 0=no).     * A port has direct feedthrough if the input is used in either     * the mdlOutputs or mdlGetTimeOfNextVarHit functions.     * See matlabroot/simulink/src/sfuntmpl_directfeed.txt.     */    ssSetInputPortDirectFeedThrough(S, 0, 1);    if (!ssSetNumOutputPorts(S, 1)) return;    ssSetOutputPortWidth(S, 0, 1);    ssSetNumSampleTimes(S, 1);    /*      * If your Fortran code uses REAL for the state, input, and/or output      * datatypes, use these DWorks as work areas to downcast continuous      * states from double to REAL before calling your code.  You could     * also put the work vectors in hard-coded local (stack) variables.     *     * For fixed step code, keep a copy of the variables  to be output      * in a DWork vector so the mdlOutputs() function can provide output      * data when needed. You can use as many DWork vectors as you like      * for both input and output (or hard-code local variables).     */    if(!ssSetNumDWork(   S, 3)) return;    ssSetDWorkWidth(     S, 0, ssGetOutputPortWidth(S,0));    ssSetDWorkDataType(  S, 0, SS_SINGLE); /* use SS_DOUBLE if needed */    ssSetDWorkWidth(     S, 1, ssGetInputPortWidth(S,0));    ssSetDWorkDataType(  S, 1, SS_SINGLE);    ssSetDWorkWidth(     S, 2, ssGetNumContStates(S));    ssSetDWorkDataType(  S, 2, SS_SINGLE);    ssSetNumNonsampledZCs(S, 0);    /* Specify the sim state compliance to be same as a built-in block */    /* see sfun_simstate.c for example of other possible settings */    ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);    ssSetOptions(S, 0);}
开发者ID:Tri-o-copter,项目名称:Brainware,代码行数:63,


示例22: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){    int i,nChannels;    static char msg[256];    ssSetNumSFcnParams(S, NUMBER_OF_ARGS);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        sprintf(msg,"Wrong Number of input arguments passed./n%d arguments are expected/n",NUMBER_OF_ARGS);        ssSetErrorStatus(S,msg);        return;    }    ssSetNumContStates(S, 0);    ssSetNumDiscStates(S, 0);        ssSetNumInputPorts(S, 0);//there is no input     //if (!ssSetNumInputPorts(S, 1)) return;        nChannels=(uint_T)mxGetN(CHANNEL_ARG);       //if (!ssSetNumOutputPorts(S, 1)) return;    ssSetNumOutputPorts(S,nChannels);//set number of outputs ports    for(i=0;i<nChannels;i++)    {        ssSetOutputPortWidth(S, i, 1);//set width of each port to 1        }        ssSetInputPortWidth(S, 0, 1);    ssSetInputPortRequiredContiguous(S, 0, true); /*direct input signal access*/    /*     * Set direct feedthrough flag (1=yes, 0=no).     * A port has direct feedthrough if the input is used in either     * the mdlOutputs or mdlGetTimeOfNextVarHit functions.     */    ssSetInputPortDirectFeedThrough(S, 0, 1);       ssSetNumSampleTimes(S, 1);//set number of sample time to 1,which means all input ports share same Ts        ssSetNumRWork(S, NO_R_WORKS);//number of float in work vector    ssSetNumIWork(S, NO_I_WORKS);//number of int in work vector    ssSetNumPWork(S, 0);//number of pointer in work vector        ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);//no need for pass-zero check         ssSetSFcnParamNotTunable(S,0);    ssSetSFcnParamNotTunable(S,1);    ssSetSFcnParamNotTunable(S,2);    ssSetSFcnParamNotTunable(S,3);    ssSetSFcnParamNotTunable(S,4);        ssSetOptions(S,SS_OPTION_EXCEPTION_FREE_CODE|SS_OPTION_PLACE_ASAP);    /* Specify the sim state compliance to be same as a built-in block */    ssSetSimStateCompliance(S, USE_DEFAULT_SIM_STATE);}
开发者ID:nathanlrf,项目名称:AutoLab,代码行数:57,


示例23: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *    The sizes information is used by Simulink to determine the S-function *    block's characteristics (number of inputs, outputs, states, etc.). */static void mdlInitializeSizes(SimStruct *S){        char host[] = "localhost";	int port = 9002;        trigger = 0;    /* See sfuntmpl_doc.c for more details on the macros below */    ssSetNumSFcnParams(S, 1);  /* Number of expected parameters */    if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {        /* Return if number of expected != number of actual parameters */        return;    }    ssSetNumContStates(S, 0);    ssSetNumDiscStates(S, 0);    /* This functions receives no inputs, but it could use inputs instead of hard-coded parameters (e.g. port and host) */    if (!ssSetNumInputPorts(S, 0)) return;    /*ssSetInputPortWidth(S, 0, 1);*/    /*ssSetInputPortRequiredContiguous(S, 0, true); /direct input signal access*/    /*     * Set direct feedthrough flag (1=yes, 0=no).     * A port has direct feedthrough if the input is used in either     * the mdlOutputs or mdlGetTimeOfNextVarHit functions.     * See matlabroot/simulink/src/sfuntmpl_directfeed.txt.     */    /*ssSetInputPortDirectFeedThrough(S, 0, 1);*/    if (!ssSetNumOutputPorts(S, 2)) return;    ssSetOutputPortWidth(S, 0, PAYLOAD_LEN/2);     ssSetOutputPortDataType(S, 0, SS_UINT16);    ssSetOutputPortWidth(S, 1, 1);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE);            /* Connect to the SerialForwarder server using functions linked in sfsource.o */    fd = open_sf_source(host, port);            if (fd < 0){            ssSetErrorStatus(S,"SerialForwarder not running in the specified host and port");            return;        }}
开发者ID:araujokth,项目名称:kth-wsn,代码行数:61,


示例24: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S) {  ssSetNumSFcnParams(S, 2);  ssSetNumContStates(S, 0);  ssSetNumDiscStates(S, 0);  ssSetNumInputPorts(S, 0);  ssSetNumOutputPorts(S, 0);  ssSetNumSampleTimes(S, 1);  ssSetNumPWork(S, 1);  // start time}
开发者ID:aespielberg,项目名称:drake,代码行数:10,


示例25: mdlInitializeSizes

/* Function: mdlInitializeSizes =============================================== * Abstract: *   Setup sizes of the various vectors. */static void mdlInitializeSizes(SimStruct *S){    DECL_AND_INIT_DIMSINFO(outputDimsInfo);    ssSetNumSFcnParams(S, NPARAMS);     if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) {	 return; /* Parameter mismatch will be reported by Simulink */     }    ssSetNumContStates(S, NUM_CONT_STATES);    ssSetNumDiscStates(S, NUM_DISC_STATES);    if (!ssSetNumInputPorts(S, NUM_INPUTS)) return;    if (!ssSetNumOutputPorts(S, NUM_OUTPUTS)) return;    /* Output Port 0 */    outputDimsInfo.width = OUTPUT_0_WIDTH;    ssSetOutputPortDimensionInfo(S, 0, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,0, OUTPUT_0_WIDTH, OUTPUT_DIMS_0_COL);    ssSetOutputPortFrameData(S, 0, OUT_0_FRAME_BASED);    ssSetOutputPortDataType(S, 0, SS_UINT8);    ssSetOutputPortComplexSignal(S, 0, OUTPUT_0_COMPLEX);    /* Output Port 1 */    outputDimsInfo.width = OUTPUT_1_WIDTH;    ssSetOutputPortDimensionInfo(S, 1, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,1, OUTPUT_1_WIDTH, OUTPUT_DIMS_1_COL);    ssSetOutputPortFrameData(S, 1, OUT_1_FRAME_BASED);    ssSetOutputPortDataType(S, 1, SS_UINT8);    ssSetOutputPortComplexSignal(S, 1, OUTPUT_1_COMPLEX);    /* Output Port 2 */    outputDimsInfo.width = OUTPUT_2_WIDTH;    ssSetOutputPortDimensionInfo(S, 2, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,2, OUTPUT_2_WIDTH, OUTPUT_DIMS_2_COL);    ssSetOutputPortFrameData(S, 2, OUT_2_FRAME_BASED);    ssSetOutputPortDataType(S, 2, SS_UINT8);    ssSetOutputPortComplexSignal(S, 2, OUTPUT_2_COMPLEX);    /* Output Port 3 */    outputDimsInfo.width = OUTPUT_3_WIDTH;    ssSetOutputPortDimensionInfo(S, 3, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,3, OUTPUT_3_WIDTH, OUTPUT_DIMS_3_COL);    ssSetOutputPortFrameData(S, 3, OUT_3_FRAME_BASED);    ssSetOutputPortDataType(S, 3, SS_UINT16);    ssSetOutputPortComplexSignal(S, 3, OUTPUT_3_COMPLEX);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, (SS_OPTION_EXCEPTION_FREE_CODE |		     SS_OPTION_WORKS_WITH_CODE_REUSE));}
开发者ID:Adeange1,项目名称:roboboat2015,代码行数:59,


示例26: mdlInitializeSizes

static void mdlInitializeSizes(SimStruct *S){    const real_T  *P1  = mxGetData(PARAM_DEF3(S));    const real_T  *P2  = mxGetData(PARAM_DEF2(S));    DECL_AND_INIT_DIMSINFO(outputDimsInfo);    ssSetNumSFcnParams(S, NPARAMS);  /* Number of expected parameters */      #if defined(MATLAB_MEX_FILE)	if (ssGetNumSFcnParams(S) == ssGetSFcnParamsCount(S)) {	  if (ssGetErrorStatus(S) != NULL) {	    return;	  }	 } else {	   return; /* Parameter mismatch will be reported by Simulink */	 }      #endif    ssSetNumContStates(S, NUM_CONT_STATES);    ssSetNumDiscStates(S, NUM_DISC_STATES);    if (!ssSetNumInputPorts(S, NUM_INPUTS)) return;    if (!ssSetNumOutputPorts(S, NUM_OUTPUTS)) return;    /* Output Port 0 */    outputDimsInfo.width = *P1;             ssSetOutputPortDimensionInfo(S, 0, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,0, *P1, *P2);    ssSetOutputPortFrameData(S, 0, OUT_0_FRAME_BASED);    ssSetOutputPortDataType(S, 0, SS_UINT8);    ssSetOutputPortComplexSignal(S, 0, OUTPUT_0_COMPLEX);    /* Output Port 1 */    outputDimsInfo.width = *P1;    ssSetOutputPortDimensionInfo(S, 1, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,1, *P1, *P2);    ssSetOutputPortFrameData(S, 1, OUT_1_FRAME_BASED);    ssSetOutputPortDataType(S, 1, SS_UINT8);    ssSetOutputPortComplexSignal(S, 1, OUTPUT_1_COMPLEX);    /* Output Port 2 */    outputDimsInfo.width = *P1;    ssSetOutputPortDimensionInfo(S, 2, &outputDimsInfo);    ssSetOutputPortMatrixDimensions( S ,2, *P1, *P2);    ssSetOutputPortFrameData(S, 2, OUT_2_FRAME_BASED);    ssSetOutputPortDataType(S, 2, SS_UINT8);    ssSetOutputPortComplexSignal(S, 2, OUTPUT_2_COMPLEX);    ssSetNumSampleTimes(S, 1);    ssSetNumRWork(S, 0);    ssSetNumIWork(S, 0);    ssSetNumPWork(S, 0);    ssSetNumModes(S, 0);    ssSetNumNonsampledZCs(S, 0);    /* Take care when specifying exception free code - see sfuntmpl_doc.c */    ssSetOptions(S, (SS_OPTION_EXCEPTION_FREE_CODE |		     SS_OPTION_WORKS_WITH_CODE_REUSE));}
开发者ID:Adeange1,项目名称:roboboat2015,代码行数:55,



注:本文中的ssSetNumInputPorts函数示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


C++ ssSetNumModes函数代码示例
C++ ssSetNumIWork函数代码示例
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。