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

📄 2007-3-5-pwm+fuzzy.txt

📁 运用模糊算法和PID调节控制开关磁阻电机的调速。采用的单片机是Intel的80c196KB,编程语言为PL/M.
💻 TXT
📖 第 1 页 / 共 2 页
字号:
         HSO_COMMAND=06H;
         HSO_TIME=TIMER1+02H;
         R0=0;
         R0=0;
      END;
    END;
    ENABLE;
END START;

/*高速输入中断程序*/
HSI_INT:PROCEDURE INTERRUPT 2 ;
  DECLARE STATUS BYTE;
  DECLARE IOS BYTE;
  DECLARE T1 BYTE;
  declare (SUM,temp) word;
  DISABLE;
  IOS=IOS1;
  IF BITTST(.IOS,7) THEN DO;
    STATUS=HSI_STATUS;
    TM2=HSI_TIME;
    T1=T1OVER;
    T1OVER=0;
    IF BITTST(.STATUS,0) THEN DO;
      IF BITTST(.STATUS,1) THEN ORDER=0;
      ELSE ORDER=2;
    END;
    ELSE IF BITTST(.STATUS,2) THEN DO;
      IF BITTST(.STATUS,3) THEN ORDER=1;
      ELSE ORDER=3;
    END;
    IF T1<15 THEN DO;
      T_SPAN=(T1*65536+TM2)-TM1;
      temp=1875000/T_SPAN;
    END;
    ELSE TEMP=0;
    TM1=TM2;
  END;
  sum=run_spd*23+temp;
  run_spd=sum/24;
  ENABLE;
  IF START_SIGN=1 THEN  CALL HSO_PROCESS;
  ELSE  CALL STOP;
END HSI_INT;

/*高速输出处理程序*/
HSO_PROCESS:PROCEDURE;/*两相定角度开通角-7.5,关断角22.5*/
  DISABLE;
  IF DIRECT=1 THEN DO;/*逆时针*/
TURNON=T_SPAN/2;
TURNOFF=T_SPAN/2;
DO CASE ORDER;
T00:DO;/*P=1,Q=0*/
  HSO_COMMAND=03H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=21H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
TO1:DO;/*P=1,Q=1*/
  HSO_COMMAND=00H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=22H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
TO2:DO;/*P=0,Q=1*/
  HSO_COMMAND=01H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=23H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
TO3:DO;/*P=0,Q=0*/
  HSO_COMMAND=02H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=20H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
END;
END;
ELSE DO;/*顺时针*/
TURNON=T_SPAN/2;
TURNOFF=T_SPAN/2;
DO CASE ORDER;
T10:DO;/*P=1,Q=1*/
  HSO_COMMAND=03H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=21H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
T11:DO;/*P=0,Q=1*/
  HSO_COMMAND=00H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=22H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
T12:DO;/*P=0,Q=0*/
  HSO_COMMAND=01H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=23H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
T13:DO;/*P=1,Q=0*/
  HSO_COMMAND=02H;
  HSO_TIME=TIMER1+TURNOFF;
  R0=0;
  R0=0;
  HSO_COMMAND=20H;
  HSO_TIME=TIMER1+TURNON;
  R0=0;
  R0=0;
 END;
END;
END;
  ENABLE;
END HSO_PROCESS;

T1_INT:PROCEDURE INTERRUPT 0;
  T1OVER=T1OVER+1;
  IF T1OVER>50000 THEN T1OVER=0;
END T1_INT;

STOP:PROCEDURE;
DISABLE;
     IOC2=80H;
     HSO_COMMAND=25H;                /*hso_command=05H; */
     HSO_TIME=TIMER1+04H;
     R0=0;
     R0=0;
     HSO_COMMAND=06H;
     HSO_TIME=TIMER1+04H;
     R0=0;
     R0=0;
     HSO_COMMAND=07H;
     HSO_TIME=TIMER1+04H;
     R0=0;
     R0=0;
ENABLE;
END STOP;


PWMTIME:PROCEDURE;
  IOC2=0C0H;
  HSO_COMMAND=0CEH;
  HSO_TIME=150;
  R0=0;
  R0=0;
  HSO_COMMAND=0C5H;  /*hso_command=0E5H;*/
  HSO_TIME=150;
  R0=0;
  R0=0;
  CALL PWM_OUT;
END PWMTIME;

HSO_INT:PROCEDURE INTERRUPT 3;
    KK=KK+1;
      IF RUN_SPD<300 THEN DO;
        IF KK>1500 THEN DO;/*每隔0.3s变换一次pwm占空比*/
          KK=1;
          CALL PWM;
        END;
        ELSE CALL PWM_OUT;
      END;
      ELSE IF AIM_SPD>2000 THEN DO;
        IF RUN_SPD<(AIM_SPD-300) THEN DO;
          IF KK>250 THEN DO;/*每隔0.05s变换一次pwm占空比*/
            KK=1;
            CALL PWM;
          END;
          ELSE CALL PWM_OUT;
        END;
        ELSE DO;/*run_spd>1700*/
          IF KK>500 THEN DO;/*每隔0.1s变换一次pwm占空比*/
            KK=1;
            CALL PWM;
          END;
          ELSE CALL PWM_OUT;
        END;
      END;
      ELSE DO;
        IF KK>1000 THEN DO;/*每隔0.2s变换一次pwm占空比*/
            KK=1;
            CALL PWM;
        END;
        ELSE CALL PWM_OUT;
      END;
END HSO_INT;

PWM:PROCEDURE;/*每次pwm宽度增加2*/
DISABLE;
IF START_SIGN=0 THEN DO;
   PWM_WIDTH=PWM_WIDTH-1;
   IF T_SPAN>10000 THEN PWM_WIDTH=2;/*run_spd<187.5*/
   ELSE IF T1OVER>15 THEN PWM_WIDTH=2;
   IF PWM_WIDTH<2 THEN PWM_WIDTH=2;
END;
ELSE DO;
IF (AIM_SPD-RUN_SPD)>100 THEN PWM_WIDTH=PWM_WIDTH+1;/*只考虑aim大于run转速100*/
ELSE CALL FUZZYCONTROL;
  END;
  IF PWM_WIDTH>20 THEN  PWM_WIDTH=20;
  IF PWM_WIDTH<2 THEN  PWM_WIDTH=2;
CALL PWM_OUT;
ENABLE;
END PWM;


FUZZYCONTROL:PROCEDURE;
DECLARE(GE,GEC) BYTE;
DECLARE EE1 INTEGER;
DISABLE;
/*E0 前次误差 E1 本次误差 EC 本次误差的变化率*/
    E1=SIGNED(AIM_SPD-RUN_SPD);
    EE1=E1;
    IF IABS(EE1)>42 THEN DO;
      IF AIM_SPD>RUN_SPD THEN EE1=42;
      ELSE EE1=-42;
    END;
    GE=UNSIGN(EE1/6+7);
    EC=E1-E0;
    IF IABS(EC)>7 THEN DO;
      IF E1>E0 THEN EC=7;
      ELSE EC=-7;
    END;
    GEC=UNSIGN(EC+7);
    PWM_WIDTH=PWM_WIDTH+FUZZY(GE*15+GEC);
    PWM_WIDTH=PWM_WIDTH-7;
    IF PWM_WIDTH>100 THEN PWM_WIDTH=100;
    IF PWM_WIDTH<2 THEN PWM_WIDTH=2;
    E0=E1;
ENABLE;
END FUZZYCONTROL;


PWM_OUT:PROCEDURE;
DISABLE;
    HSO_COMMAND=75H;       /*hso_command=55H;*/
    HSO_TIME=PWM_WIDTH;
    R0=0;
    R0=0;
ENABLE;
R0=0;              /*MORE*/
R0=0;              /*MORE*/
END PWM_OUT;

/***主过程***/
MAINPROC:DO;
CALL TIME(500);
DISABLE;
  IOC0=05H;
  IOC1=66H;
  IOC2=80H;
  SP=0C0H;
  INT_MASK=2DH;
  INT_MASK1=23H;
  INT_PENDING=00H;
  INT_PEND1=00H;
  HSI_MODE=0FH;
  IOPORT1=0FFH;
  IOPORT2=0;

  COMM_8279=2FH;
  R0=0;
  R0=0;
  COMM_8279=01H;
  R0=0;
  R0=0;
  COMM_8279=0D3H;
  R0=0;
  R0=0;
  HSO_COMMAND=25H;    /*HSO5=1*/
  HSO_TIME=TIMER1+02H;
  R0=0;
  R0=0;

  START_SIGN=0;
  AIM_SPD=0;
  DIRECT=0;
  FAULT=1FH;
  PWM_WIDTH=0;
  E0=0;
  E1=0;
  EC=0;
  DISP_STATUS=0;
  SPD_STEP=100;
  RUN_SPD=0;
  CONV_SPD=0;
  KK=0;
  DO II=0 TO 7;
    TM1=HSI_TIME;
    R0=0;
    R0=0;
  END;
ENABLE;

MAINLOOP:
DO;
     CALL BITCPL(.IOPORT2,5);
  IF START_SIGN=0 THEN DO;
    IF T_SPAN>100000 THEN DO;
       PWM_WIDTH=2;
       RUN_SPD=0;
    END;
    ELSE IF T1OVER>5 THEN DO;
       PWM_WIDTH=2;
       RUN_SPD=0;
    END;
  END;
  IF BID=1 THEN DO;
   IF RUN_SPD=0 THEN DO;
     IF DIRECT=1 THEN DIRECT=0;
     ELSE DIRECT=1;
     BID=0;
     AIM_SPD=DEFAULT_SPD;
     CALL START;
   END;
  END;
  CALL DISPLAY;
END;
GOTO MAINLOOP;
END MAINPROC;
END MAIN;
EOF;
    /*modified by kaka*/


⌨️ 快捷键说明

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