📄 2007-3-5-pwm+fuzzy.txt
字号:
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 + -