📄 pid.c.bak
字号:
#include <dc.h>
#define r_Kp 1
#define r_Ki 1
#define r_Kd 1
sbit stop=P3^5;
sbit wire_dir=P4^7;
sbit wire_enable=P4^6;
sbit rot_dir=P4^4;
sbit rot_enable=P4^5;
sbit send_enable=P3^4;
sbit wire_over_i=P4^3;
xdata unsigned char rbuffer[55],sbuffer[6];
xdata unsigned char COMM,SLA,FF,GET,POINTER0,SSUM,POINTER1,RSUM,c_t1,s_byte_nums,r_byte_nums,pulse_num,
err,WIRE,S_ANSW,nonce_sec,work,p_sec,K21,K3,K31,tooth_num,
temp_pulse_num,pulse_num1,temp_pulse_num1,delt_state,rot_slope_delt,wire_slope_delt,
rp_sample_num,rb_sample_num,temp_rot_num[6],rp_num[6],rb_num[6];
xdata int rot_difference,rot_last_difference,rot_last_last_difference,rot_actual_difference,
rot_P,rot_I,rot_D;
unsigned int *point,rot_vp,temp_rot_vp,rot_vb,temp_rot_vb,wire_vp,temp_wire_vp,wire_vb,
temp_wire_vb,n_cm0,c_cm0,n_cm1,c_cm1,FINISH,temp_FINISH,delt_rot,delt_wire,motor_v;
unsigned int r,rot_num,new_rot_num,wire_pid_num,average_r_num,rp_academic_num,rb_academic_num;
unsigned long const1;
float temp_data0,const0,temp_data00;
bit send,overtime,start,decrease,urgent_stop,rot_front,rot_reverse,wire_add,
wire_dec,rot_ok,wire_ok,in_sector,receive_p_out,receive_p_in,demand,need_para,
rot_stop,rot_stop_ok,called,p_b,new_sector,start_rot,start_wire,stop_wire,r_slope_ok,
w_slope_ok,retract,return_ok,retract_ok,motor_stop,auto_return,resend,ans,
to_begin,noans_ok,ask_return_ok,k_r_p_add,k_r_b_add,k_r_p_dec,k_r_b_dec,k22,k33,k44;
bit kk,rw_err,err_ok,rot_pid_ok,wire_pid_ok;
void start_t2()
{
TM2CON=0x85; //16位溢出,分频系数2,f/12
EA=1;
TM2IR=0;
}
void ini_sbuf(unsigned char a,b,c,d,e,f)
{
sbuffer[0]=a;
sbuffer[1]=b;
sbuffer[2]=c;
sbuffer[3]=d;
sbuffer[4]=e;
sbuffer[5]=f;
}
unsigned char get_byte_nums(unsigned char type)
{
unsigned char numbers;
switch(type)
{
case infor_sec:
case command:
case program:
case answer: numbers=4;
break;
case err_infor:
case parameter1: numbers=5;
break;
case parameter:
case infor: numbers=6;
break;
case parameter2: numbers=7;
break;
case call_result: numbers=8;
break;
case p_out_sec: numbers=55;
break;
case p_in_sec: numbers=24;
break;
case edit_sec: numbers=64;
break;
default: break;
}
return numbers;
}
void TR_noans()
{
noans_ok=0;
POINTER0=0;
SSUM=0;
send=1;
c_t1=0;
send_enable=1; //开发送使能
TR1=1;
while(POINTER0<s_byte_nums);
TR1=0;
send_enable=0; //关发送使能
noans_ok=1;
}
void delay(unsigned char num)
{
unsigned char i,ii;
for(i=0;i<num;i++)
{
for(ii=0;ii<255;ii++);
}
}
void TR_ans()
{
ans=1;
REN=0;
POINTER1=0;
RSUM=0;
TB8=1;
POINTER0=0;
SSUM=0;
send=1;
c_t1=0;
send_enable=1; //开发送使能
TR1=1;
while(POINTER0<s_byte_nums);
TR1=0;
send_enable=0; //关发送使能
REN=1;
send=0;
c_t1=0;
// TR1=1;
while(POINTER1<r_byte_nums&&overtime==0);
TR1=0;
if(overtime==1)
{
err=2; //通信出错
overtime=0;
}
ans=0;
}
void com_type()
{
switch(rbuffer[2])
{
case com_calling: called=1;break;
case com_demand: {
if(demand==0)
demand=1;
}break;
case com_need_para: need_para=1;break;
case com_start: start=1;break;
case com_rot_front: { //正转
if(rot_front==0)
rot_front=1;
}break;
case com_rot_reverse: { //反转
if(rot_reverse==0)
rot_reverse=1;
}break;
case com_wire_add: { //送丝
if(work==0)
wire_add=1;
else if(work==3)
{
if(wire_add==0&&WIRE==ON&&pp.k3==ON)
wire_add=1;
}
}break;
case com_wire_dec: { //抽丝
if(work==0)
wire_dec=1;
else if(work==3)
{
if(wire_dec==0&&WIRE==ON&&pp.k3==ON)
wire_dec=1;
}
}break;
case com_motor_stop: { //停止点动
if(motor_stop==0)
motor_stop=1;
}break;
case com_pre_melt_ok: start_rot=1;break;
case com_decrease: decrease=1;break;
case com_decrease_ok: rot_stop=1;break;
case com_wire: start_wire=1;break;
case com_stopW: stop_wire=1;break;
case com_return: auto_return=1;break;
case com_return_ok: return_ok=1;break;
case com_goto_begin: to_begin=1;break;
case com_err_ok: err_ok=1;break;
default: break;
}
}
void data_type() //对接收到的数据分辨类型
{
switch(rbuffer[1])
{
case command: com_type();break;
case infor: {
switch(rbuffer[2])
{
case com_sector: {
nonce_sec=rbuffer[3];
in_sector=1;
new_sector=1;
}break;
case com_wire_on_off: WIRE=rbuffer[3];break;//送丝开关
case com_delt_switch: delt_state=rbuffer[3];break;
default: break;
}
}break;
case p_out_sec: receive_p_out=1;break;
case p_in_sec: {
nonce_sec=rbuffer[2];
receive_p_in=1;
}break;
case parameter1:FINISH=rbuffer[2]*256+rbuffer[3];break;
default: break;
}
}
void get_v_r()
{
switch(pp.rn/256)
{
case 1: {
motor_v=6600;
r=25;
}break;
case 2:
case 3:
case 4:
case 5:
case 6: {
motor_v=6600;
r=28;
}break;
case 7: {
motor_v=6600;
r=25;
}break;
case 8: {
motor_v=6600;
r=15;
}break;
case 9:
case 10:{
motor_v=6600;
r=16;
}break;
case 11:
case 12:
case 13:{
motor_v=6600;
r=176;
}break;
case 14:{
motor_v=6600;
r=55;
}break;
case 15:{
motor_v=6600;
r=103;
}break;
case 16:
case 17:
case 18:
case 19:{
motor_v=6600;
r=80;
}break;
case 20:
case 21:
case 22:
case 23:
case 24:{
motor_v=6600;
r=48;
}break;
case 25:
case 26:
case 27:
case 28:{
motor_v=6600;
r=37;
}break;
case 29:
case 30:
case 31:
case 32:{
motor_v=6600;
r=25;
}break;
case 33:{
motor_v=7184;
r=7;
}break;
case 34:{
motor_v=7480;
r=22;
}break;
case 35:{
motor_v=7440;
r=18;
}break;
case 36:{
motor_v=7480;
r=27;
}break;
case 37:{
motor_v=6510;
r=27;
}break;
case 38:{
motor_v=8380;
r=131;
}break;
default:{
motor_v=6600;
r=pp.rn;
}break;
}
}
void EX0_INT (void) interrupt 0 //急停
{
EX1=0;
send_enable=0; //关发送使能
POINTER0=0;
SSUM=0;
POINTER1=0;
RSUM=0;
r_byte_nums=4;
PWM0=0;
PWM1=0;
rot_enable=0;
wire_enable=0;
while(err_ok==0)
{
if(called==1)
{
if(rw_err==0)
{
ini_sbuf(M_main,answer,OK,0,0,0);
s_byte_nums=4;
TR_noans();
}
else
{
ini_sbuf(M_main,err_infor,M_RW,err,0,0);
s_byte_nums=5;
TR_noans();
rw_err=0;
err=0;
stop=1;
}
called=0;
}
}
urgent_stop=1;
}
void EX1_INT (void) interrupt 2
{
unsigned char get_err;
EX1=0;
if(limit==0)
err=11; //旋转限位
else if(wire_over_i==0)
err=10;
else
{
get_err=P5;
get_err=get_err&0x04;
if(get_err==0)
err=9;
}
if(err!=0)
{
rw_err=1;
stop=0;
}
else
EX1=1;
}
void T1_INT (void) interrupt 3
{
c_t1++;
if(send==1)
{
if(c_t1==7)
{
S0BUF=sbuffer[POINTER0];
c_t1=0;
}
}
else
{
if(c_t1==100)
{
TR1=0;
overtime=1;
}
}
}
void TR_INT (void) interrupt 4 //串行口中断
{
EA=0; //关中断
if(TI==1) //发送完成
{
TI=0;
POINTER0++; //发送缓冲指针加1
if(POINTER0<s_byte_nums-1)
SSUM=SSUM+sbuffer[POINTER0]; //6个数据字节求和
else
sbuffer[s_byte_nums-1]=SSUM+sbuffer[0]; //数据和加地址生成校验码
if(POINTER0==s_byte_nums)
REN=1;
}
if(RI==1) //接收完成
{
RI=0;
POINTER1++; //接收缓冲指针加1
rbuffer[POINTER1-1]=S0BUF; //从接收缓冲读出数据
if(rbuffer[0]==M_RW||rbuffer[0]==M_ALL||rbuffer[0]==M_current_RW)
{
SM2=0;
if(POINTER1==2) //获取字节个数
r_byte_nums=get_byte_nums(rbuffer[1]);
if(POINTER1<r_byte_nums)
RSUM=RSUM+rbuffer[POINTER1-1]; //生成校验码
else
{
SM2=1;
if(RSUM==rbuffer[r_byte_nums-1])
{
if(ans==0)
{
POINTER1=0;
RSUM=0;
}
S_ANSW=OK;
data_type();
}
else
{
S_ANSW=FAIL;
if(resend==0)
resend=1;
}
}
}
else
POINTER1=0;
}
EA=1; //开中断
}
void CT0_int (void) interrupt 6 //焊接角度
{
CTI0=0;
rot_num++;
if(auto_return==0)
{
if(FINISH<=50000)
{
temp_pulse_num++;
temp_pulse_num1++;
if(temp_pulse_num1==pulse_num1)
{
temp_FINISH++;
FINISH=temp_FINISH*10;
temp_pulse_num1=0;
}
if(temp_pulse_num==pulse_num)
{
FINISH++;
temp_pulse_num=0;
}
}
else
{
IEN1=IEN1&0XFE; //CT0
temp_pulse_num=0;
}
}
else
{
if(FINISH>10)
{
temp_pulse_num++;
if(temp_pulse_num==pulse_num1)
{
FINISH=FINISH-10;
temp_pulse_num=0;
}
}
else
{
if(FINISH>0)
{
temp_pulse_num++;
if(temp_pulse_num>=pulse_num)
{
FINISH--;
temp_pulse_num=0;
}
}
else
{
PWM0=0;
rot_enable=0;
IEN1=IEN1&0XFE; //CT0
}
}
}
}
void CT1_int (void) interrupt 7
{
CTI1=0;
wire_pid_num++;
}
void CT3_int (void) interrupt 9 //电流脉冲
{
CTI3=0;
CTCON=CTCON&0X3F;
IEN1=IEN1&0XF7; //CT3
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -