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

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

?? flc_invp.c

?? 書籍代碼:遺傳演算法原理與應用_活用MATLAB(Source Code)
?? C
字號:
/*
 * File : flc_invp.c
 * Abstract:
 *       An example C-file S-function for linking Fuzzy Inference System,
 *       uk = fuzzy_controller(ek, dek)
 *
 * See simulink/src/sfuntmpl_doc.c
 *
 * Copyright 1990-2000 The MathWorks, Inc.
 * $Revision: 1.7 $
 * Written by Chou, Penchen, Aug. 3,2001
 * EE Dept., Da-Yeh University.
 * Execute mex flc_invp.c to get flc_invp.dll before Simulink simulation.
 */

#define S_FUNCTION_NAME  flc_invp
#define S_FUNCTION_LEVEL 2

#include "simstruc.h"

/*================*
 * Build checking *
 *================*/
#if !defined(MATLAB_MEX_FILE)
/*
 * This file cannot be used directly with the Real-Time Workshop. However,
 * this S-function does work with the Real-Time Workshop via
 * the Target Language Compiler technology. See 
 * matlabroot/toolbox/simulink/blocks/tlc_c/timestwo.tlc   for the C version
 * matlabroot/toolbox/simulink/blocks/tlc_ada/timestwo.tlc for the Ada version
 */
# error This_file_can_be_used_only_during_simulation_inside_Simulink
#endif

float fuzzy_controller(float, float);                 
#include<dos.h>
#include<math.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

#define MAX(i,j)  (i>=j)?i:j
#define MIN(i,j)  (i<=j)?i:j
#define NO_SECOND_INPUT 0
#define AND_OPERATOR    1
#define  OR_OPERATOR    2
/***************************************************************/

/***************************************************************
**          ==> USER CAN MODIFY THE FOLLOWING:         *********
****************************************************************/
#define N_rules 25   /* Total # of RULES          */
#define DA_bias 0    /* Bias appended to output for D/A conv. 
                        If you do not know, set DA_bias to zero*/
#define IN1_min -2.3562
#define IN1_max  2.3562
#define IN2_min -1.1781
#define IN2_max  1.1781
#define OUT_min -30.0
#define OUT_max  30.0

/*-----------------------------------------------------------*/
/*  Membership Functions */
/*  ===>Triangles with equal sides only<=== */
float x_membership[5][3]=  /* MB of input1 */
   {{-2.3562,-1.5708,-0.7850},
   {-1.5708,-0.7850,0},
   {-0.7850,0,0.7850},
   {0,0.7850,1.5708},
   {0.7850,1.5708,2.3562}};

float y_membership[5][3]=  /* MB of input2 */
   {{-1.1781,-0.7850,-0.3927},
   {-0.7850,-0.3927,0},
   {-0.3927,0,0.3927},
   {0,0.3927,0.7850},
   {0.3927,0.7850,1.1781}};

float z_membership[5][3]=  /* MB of output1 */
   {{-30,-20,-10},
   {-20,-10,0},
   {-10,0,10},
   {0,10,20},
   {10,20,30}};

/* RULES DEFINITION *
-----------------------------------------------------------------*/
/* ===>{1,1,1,2}, the last 2 is OR operation between two inputs.
		  Use 1 for AND.
-----------------------------------------------------------------*/
int Rule[N_rules][4]=
  {{1,1,5,1},
   {1,2,5,1},
   {1,3,5,1},
   {1,4,4,1},
   {1,5,3,1},
   {2,1,5,1},
   {2,2,4,1},
   {2,3,4,1},
   {2,4,3,1},
   {2,5,2,1},
   {3,1,5,1},
   {3,2,4,1},
   {3,3,3,1},
   {3,4,2,1},
   {3,5,1,1},
   {4,1,4,1},
   {4,2,3,1},
   {4,3,2,1},
   {4,4,2,1},
   {4,5,1,1},
   {5,1,2,1},
   {5,2,2,1},
   {5,3,1,1},
   {5,4,1,1},
   {5,5,1,1}};

/******************************************************************
**             [==> NO TOUCH in the following TO THE END.]      **
******************************************************************/

/* Global variables */
/* grade_reg array saves w1 and w2 of input x and y respectively.
   grade stores all min(w1,w2) in N_rules of locations.           */
float grade_reg[2], grade[N_rules];

float *ptr_MB;  /* membership functions (MB) pointer     */

/* 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, 2)) return;         /* 2-input */
    ssSetInputPortWidth(S, 0, DYNAMICALLY_SIZED);
    ssSetInputPortDirectFeedThrough(S, 0, 1);
    ssSetInputPortWidth(S, 1, DYNAMICALLY_SIZED);
    ssSetInputPortDirectFeedThrough(S, 1, 1);

    if (!ssSetNumOutputPorts(S,1)) return;
    ssSetOutputPortWidth(S, 0, DYNAMICALLY_SIZED);

    ssSetNumSampleTimes(S, 1);

    /* Take care when specifying exception free code - see sfuntmpl_doc.c */
    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE |
                 SS_OPTION_USE_TLC_WITH_ACCELERATOR);
}


/* Function: mdlInitializeSampleTimes =========================================
 * Abstract:
 *    Specifiy that we inherit our sample time from the driving block.
 */
static void mdlInitializeSampleTimes(SimStruct *S)
{
    ssSetSampleTime(S, 0, INHERITED_SAMPLE_TIME);
    ssSetOffsetTime(S, 0, 0.0);
}


/* Function: mdlOutputs =======================================================
 * Abstract:
 *    y = fuzzy_controller(u1,u2)
 */
static void mdlOutputs(SimStruct *S, int_T tid)
{
    int_T             i;
    InputRealPtrsType uPtrs1 = ssGetInputPortRealSignalPtrs(S,0); /* input #1 */
    InputRealPtrsType uPtrs2 = ssGetInputPortRealSignalPtrs(S,1); /* input #2 */
    real_T            *y    = ssGetOutputPortRealSignal(S,0);
    int_T             width = ssGetOutputPortWidth(S,0);

    for (i=0; i<width; i++) {
        /*
         * This example does not implement complex signal handling.
         * To find out see an example about how to handle complex signal in 
         * S-function, see sdotproduct.c for details.
         */
        *y++ = fuzzy_controller(*uPtrs1[i], *uPtrs2[i]); 
        
    }
}


/* Function: mdlTerminate =====================================================
 * Abstract:
 *    No termination needed, but we are required to have this routine.
 */
static void mdlTerminate(SimStruct *S)
{
}

#if defined(MATLAB_MEX_FILE)
#define MDL_RTW
/* Function: mdlRTW ===========================================================
 * Abstract:
 *	Since we've declared all are parameters as non-tunable, we need
 *	only provide this routine so that they aren't written to the model.rtw
 *	file. The values of the parameters are implicitly encoded in the
 *	sample times.
 */
static void mdlRTW(SimStruct *S)
{
}
#endif /* MDL_RTW */

#ifdef  MATLAB_MEX_FILE    /* Is this file being compiled as a MEX-file? */
#include "simulink.c"      /* MEX-file interface mechanism */
#else
#include "cg_sfun.h"       /* Code generation registration function */
#endif

/*****************************************************************
**                  FUNCTIONS DEFINITIONS                       **
******************************************************************
   [1]. COMPUTE WEIGHT OF INPUT                                 **
******************************************************************/
float compute_grade(float *MB, int set, float input_data)
  {
    float weight;

    if ((input_data< *(MB+3*set+0)) || (input_data>*(MB+3*set+2)))
	  weight=0;
    else
      if (input_data> *(MB+3*set+1))           /* ON THE RIGHT SIDE OF A TRIANGLE */
	     weight=(*(MB+3*set+2)-input_data)/
	     (*(MB+3*set+2)-*(MB+3*set+1));
      else
	     weight=(input_data-*(MB+3*set+0))/    /* ON THE LEFT SIDE OF A TRIANGLE */
		 (*(MB+3*set+1)-*(MB+3*set+0));
    //printf("weight=%.2f\n",weight);
    weight=MAX(0.0,weight);                /* MAKE SURE TO BE WITHIN 0 TO 1 */
    weight=MIN(1.0,weight);
    //printf("weight=%.2f\n",weight);
    return weight;
  }

/**************************************************************
  [2]. COMPUTE WEIGHTED AVERAGE(CENTROID) OF AREA MADE BY 
       OUTPUT FUZZY SET.     
***************************************************************/
float fuzzy_controller(float input1, float input2)
  {
    float accu_num,accu_den,output,signal;
    int which_rule, set;

    /* CLEAR VARIABLES */
    accu_num=0;accu_den=0;output=0;
    for (which_rule=0;which_rule<=N_rules-1;which_rule++)
      {
	    signal=input1;           /* Data in */
	    signal=MIN(signal, IN1_max);
	    signal=MAX(signal, IN1_min);
	    //printf("Data modified=%f\n",signal);
	    set=Rule[which_rule][0]-1; ptr_MB=&x_membership;
	    grade_reg[0]=compute_grade(ptr_MB,set,signal);  /* Save data in grade_reg[0] */
	    //printf("%2d, Grade1=%6.2f, ",n+1,grade_reg[0]);

	    signal=input2;
	    signal=MIN(signal, IN2_max);
	    signal=MAX(signal, IN2_min);
	    set=Rule[which_rule][1]-1; ptr_MB=&y_membership;
	    grade_reg[1]=compute_grade(ptr_MB,set,signal);  /* Save data in grade_reg[1] */
	    //printf("Grade2=%6.2f\n",grade_reg[1]);

	    /* Check and/or operator */
	    /* If the sencond input is empty (i.e. 0), then only one grade */
	    if (Rule[which_rule][1]==NO_SECOND_INPUT)
	       grade[which_rule]=grade_reg[0];
	    else
	       if (Rule[which_rule][3]==AND_OPERATOR)
		  grade[which_rule]=MIN(grade_reg[0],grade_reg[1]);
	       else   /* Otherwise, it is an OR_OPERATOR */
		  grade[which_rule]=MAX(grade_reg[0],grade_reg[1]);

	    /* ACCUMULATED GRADES AND AREA GRADES CALCULATIONS */
	    //printf("grade[%i]=%.2f\n",which_rule,grade[which_rule]);
	    accu_num=accu_num+(grade[which_rule]*z_membership[Rule[which_rule][2]-1][1]);
	    accu_den=accu_den+grade[which_rule];
	    //printf("num[%i]=%5.2f,den[%i]=%5.2f\n",which_rule,accu_num,which_rule,accu_den);
      }
    /* IN CASE, AVOIDING DIVIDED BY ZERO */
    if (fabs(accu_den)>0.001)
       output=accu_num/accu_den;
    else
       output=0.0;
    //printf("output=%f",output);
    output=MIN(output, OUT_max);    /* BOUNDED OUTPUT CHECK POINTS */
    output=MAX(output, OUT_min);

    return (output+DA_bias);
  }
/************************************************************************
	   END of FUNCTIONS in this file.
*************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频免费在线| 久久综合丝袜日本网| 粉嫩在线一区二区三区视频| 日韩国产欧美在线播放| 亚洲一区二区在线免费观看视频| 国产精品美女久久久久久久久| 欧美韩国日本一区| 国产精品欧美一级免费| 亚洲欧美日韩一区| 亚洲成人一区在线| 蜜桃一区二区三区在线观看| 久久福利视频一区二区| 国产激情精品久久久第一区二区| 国产成人综合精品三级| 成人aa视频在线观看| 色94色欧美sute亚洲线路二 | 国产午夜精品在线观看| 欧美激情在线一区二区| 91精品国产乱码久久蜜臀| 日韩一区二区免费高清| 久久蜜桃av一区精品变态类天堂| 欧美激情中文字幕一区二区| 亚洲精品欧美专区| 日韩中文字幕不卡| 国产v综合v亚洲欧| 欧洲视频一区二区| 欧美tickle裸体挠脚心vk| 久久久久青草大香线综合精品| 国产精品乱码一区二三区小蝌蚪| 一区二区日韩av| 男男gaygay亚洲| 高清久久久久久| 欧美在线播放高清精品| 精品国产91洋老外米糕| 亚洲欧洲av在线| 日韩精品乱码av一区二区| 成人avav在线| 欧美va日韩va| 亚洲激情在线播放| 国产综合色产在线精品| 欧美天堂一区二区三区| 久久久综合精品| 亚洲成av人片在线观看无码| 国产成人免费9x9x人网站视频| 欧美日韩国产高清一区二区三区| 久久亚洲春色中文字幕久久久| 一区二区三区日韩精品| 国产成人夜色高潮福利影视| 欧美一区二区三区影视| 中文字幕日韩一区| 国产一区二区毛片| 久久婷婷色综合| 亚洲一区欧美一区| 成人国产精品免费网站| 欧美大胆一级视频| 亚洲丶国产丶欧美一区二区三区| 成人午夜免费av| wwww国产精品欧美| 麻豆成人久久精品二区三区红| 91老师片黄在线观看| 日本一区二区在线不卡| 韩国中文字幕2020精品| 欧美高清www午色夜在线视频| 亚洲欧美在线aaa| www.亚洲色图| 亚洲国产精品二十页| 国产自产2019最新不卡| 日韩精品一区二区三区中文不卡| 日韩成人免费看| 91精品国产一区二区| 日韩精品午夜视频| 欧美精品日韩综合在线| 五月天一区二区三区| 欧美视频在线观看一区| 亚洲已满18点击进入久久| 色一情一乱一乱一91av| |精品福利一区二区三区| 国产不卡在线播放| 国产亚洲一本大道中文在线| 国产一区二区91| 久久久久高清精品| 国产成人av一区| 中文字幕一区二区不卡| 一本在线高清不卡dvd| 亚洲黄色免费网站| 欧美日韩在线播放三区| 蜜乳av一区二区| 久久久久久99久久久精品网站| 国产一区二区美女| 国产精品久久久久久久久免费丝袜 | 五月婷婷色综合| 91精品一区二区三区久久久久久| 亚洲一级二级三级| 欧美日韩精品专区| 另类中文字幕网| 久久久久国色av免费看影院| 懂色一区二区三区免费观看| 中文字幕字幕中文在线中不卡视频| 色一区在线观看| 青草国产精品久久久久久| 2020国产精品自拍| 91欧美一区二区| 日本视频在线一区| 国产日本欧洲亚洲| 日本高清免费不卡视频| 日本大胆欧美人术艺术动态| 久久蜜臀中文字幕| 日本韩国一区二区三区视频| 蜜桃视频在线一区| 亚洲视频一区二区免费在线观看| 在线免费av一区| 精品一区二区精品| 有码一区二区三区| 久久久久国产精品厨房| 91福利在线免费观看| 国产乱码精品一区二区三区av | 日韩精品亚洲一区二区三区免费| 久久久久久免费毛片精品| 色成人在线视频| 国产乱子轮精品视频| 亚洲线精品一区二区三区 | 亚洲免费毛片网站| 欧美大白屁股肥臀xxxxxx| 97久久精品人人爽人人爽蜜臀| 蜜乳av一区二区三区| 亚洲精品久久久蜜桃| 国产情人综合久久777777| 欧美视频一区二区三区在线观看 | 在线视频一区二区三| 风间由美一区二区三区在线观看| 亚洲不卡av一区二区三区| 国产精品传媒入口麻豆| 欧美tk—视频vk| 91精品在线观看入口| 91国产成人在线| av在线综合网| 国产98色在线|日韩| 久久超碰97中文字幕| 五月天网站亚洲| 一区二区三区小说| 国产精品沙发午睡系列990531| 精品国产精品一区二区夜夜嗨| 欧美日韩美女一区二区| 91丨九色丨蝌蚪富婆spa| 大美女一区二区三区| 国产成人免费av在线| 国产在线精品一区二区三区不卡 | 中文字幕一区日韩精品欧美| 久久久久综合网| 久久久久久免费网| 久久精品在线观看| 久久九九久久九九| 国产亚洲婷婷免费| 久久精品欧美日韩| 国产午夜精品久久久久久久 | 亚洲成人777| 亚洲成av人**亚洲成av**| 一区二区三区免费| 亚洲r级在线视频| 性欧美疯狂xxxxbbbb| 日韩不卡免费视频| 久久激情五月激情| 国产在线精品不卡| 顶级嫩模精品视频在线看| 国产.欧美.日韩| 白白色亚洲国产精品| 91免费国产视频网站| 91福利在线看| 69堂国产成人免费视频| 日韩精品一区二区三区四区视频 | 欧美精品一区二区精品网| 久久综合色8888| 国产三级欧美三级日产三级99| 中文字幕免费观看一区| 中文字幕亚洲电影| 天天综合色天天综合色h| 麻豆精品一区二区| 成人h精品动漫一区二区三区| 色就色 综合激情| 91麻豆精品国产91久久久久久 | 中文字幕欧美一| 婷婷开心久久网| 国产精品一二二区| 在线观看中文字幕不卡| 日韩欧美亚洲国产另类| 国产精品久久久久久久岛一牛影视| 亚洲精品成人少妇| 精品一区二区av| 色婷婷久久一区二区三区麻豆| 日韩视频123| 国产精品久久久久久久久免费丝袜| 亚洲人xxxx| 国产一区二区三区免费看| 色呦呦国产精品| 精品久久一区二区| 亚洲国产中文字幕在线视频综合| 久久精品国产免费看久久精品| 91蝌蚪porny| 久久美女高清视频| 天天av天天翘天天综合网|