4363|11

82

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

这个小程序有问题吗? [复制链接]

#include
__CONFIG (INTRC & PROTECT & MCLREN & WDTEN);
const unsigned char cs @ 0x1FF;
void DelayUs( int  x)    // 32US
{while(--x!=0)
  { CLRWDT();
    NOP();
    unsigned char k=2;
   while(--k!=0)
   {}
  }
}
void main(void)
{       //OSCCAL =cs;      
        OPTION=68;
        TRIS=29;
        GPIO=63;
volatile  unsigned int tmp0,tmp1,tmp2,tmp3,tmp4,m,y;
volatile int n;
           while(GP4==0)
           { ; }
           CLRWDT();
              y=300;
              m=0;
              for(;--y>200; )
              {
               n=y;
              while(GP4==1)
              {}
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
             while(GP4==0)
              {}         
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
              }
              for(m=9;--m; )
              {
              while(GP4==1)
              {}
              DelayUs(n);
              CLRWDT();
              GP5=1;

              TMR0=0;
              while(GP2==0)
              {}
              tmp0=TMR0;
              DelayUs(10);
              GP5=0;
             while(GP4==0)
              {}         
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
              }
            do{
              while(GP4==1)
              {}
              DelayUs(n);
              CLRWDT();
              GP5=1;
              TMR0=0;
              while(GP2==0)
              {}
              tmp1=TMR0;
              DelayUs(10);
              GP5=0;
             while(GP4==0)
              {}         
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
              if(tmp0>tmp1)
              {tmp2=tmp0-tmp1;
               n-=tmp2;
               tmp0=tmp1;
               if(n<=0)
               { m++;
                 tmp3=tmp1;
                 tmp3>>=1;
                 tmp4=tmp1;
               }
               else if((n<=0)&&(m>1))
                {   if(tmp3<=(tmp2-tmp4))
                     {
                       do{ GP5=0;
                       CLRWDT();
                        }while(1);
                      }
                     else
                        n=0;
                        m=1;
                }
              }
              else
              {tmp2=tmp1-tmp0;
               n+=tmp2;
               tmp0=tmp1;
               if(n>200)
               { n=200;
               }
              }
            }while(1);

}

最新回复

我试试看,差不多可以把,我再修改一下  详情 回复 发表于 2010-1-5 15:07
点赞 关注

回复
举报

74

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
没人给看一下吗?
 
 

回复

74

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
1 你先简单描述一下功能,还是要大家告诉你什么功能?
2 用在哪个处理器上
 
 
 

回复

86

帖子

0

TA的资源

一粒金砂(初级)

4
 
程序可够乱得,估计看完非吐不可。。。
 
 
 

回复

78

帖子

0

TA的资源

一粒金砂(初级)

5
 
#include
__CONFIG (INTRC & PROTECT & MCLREN & WDTEN);
const unsigned char cs @ 0x1FF;
void DelayUs( int  x)    // 32US
{while(--x!=0)
  { CLRWDT();
    NOP();
    unsigned char k=2;
   while(--k!=0)
   {}
  }
}
void main(void)
{       OSCCAL =cs;         //初始化
        OPTION=68;
        TRIS=29;
        GPIO=63;
volatile  unsigned int tmp0,tmp1,tmp2,tmp3,tmp4,m,y;   
volatile int n;
           while(GP4==0)                           //过零 软启动
           { ; }
           CLRWDT();
              y=300;
              m=0;
              for(;--y>200; )
              {
               n=y;
              while(GP4==1)
              {}
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
             while(GP4==0)
              {}         
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
              }
              for(m=100;--m; )                 //延时电机转速稳定 读取基准TMPO(空载)
              {
              while(GP4==1)
              {}
              DelayUs(n);
              CLRWDT();
              GP5=1;

              TMR0=0;
              while(GP2==0)
              {}
              tmp0=TMR0;
              DelayUs(10);
              GP5=0;
             while(GP4==0)
              {}         
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
              }
            do{                                       // 循环工作
              while(GP4==1)
              {}
              DelayUs(n);
              CLRWDT();
              GP5=1;
              TMR0=0;
              while(GP2==0)
              {}
              tmp1=TMR0;
              DelayUs(10);
              GP5=0;
             while(GP4==0)
              {}         
              DelayUs(n);
              CLRWDT();
              GP5=1;
              DelayUs(10);
              GP5=0;
              if(tmp0>tmp1)                          // 判断对电容的重放电的快慢来调整导通角【在电动工具负载情况下对电容的充电时间tmpi】
              {tmp2=tmp0-tmp1;
               n-=tmp2;                              //调整导通角
               tmp0=tmp1;
               if((n<=0)&&(m==0))                    //判断是否需要过流保护的基点---导通延时时间为零时候,也就是说电压无法增大的时候的电流为基点,超过50%保护
               { m++;
                 tmp3=tmp1;
                 tmp3>>=1;
                 tmp4=tmp1;
               }
               else if((n<=0)&&(m>1))                 //判断是否需要保护
                {   if(tmp3<=(tmp2-tmp4))
                     {
                       do{ GP5=0;                      //进行保护,关闭可控硅导通角   
                       CLRWDT();
                        }while(1);
                      }
                     else                               //不需要保护
                        n=0;
                        m=1;
                }
              }
              else                                      //负载取消,导通角调回到初值
              {tmp2=tmp1-tmp0;
               n+=tmp2;
               tmp0=tmp1;
               if(n>200)
               { n=200;
               }
              }
            }while(1);

}



是电动工具调速,用的是PIC12C508 GP5控制可控硅导通角,GP2是电容充放电是否达到高电平。GP4是过零判断。 通过测电机电流来控制导通角达到调速的目的(非常小的电阻串接在电动工具上,电压进行放大之后对电容充放电来监测电动工具的电流)。电动工具在空载情况下电流是一个定制,如果加负载,转速下降,电流增大,通过导通角增加电压,转速上升,电流下降。达到调速的目的。大致就这样。
 
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

6
 
我把原理和目的以及注释都标上了,各位高人看看,指导一下。我瞎琢磨的。
 
 
 

回复

83

帖子

0

TA的资源

一粒金砂(初级)

7
 
没看明白~~~看样子我技术还不到家~~~努力中
 
 
 

回复

74

帖子

0

TA的资源

一粒金砂(初级)

8
 
最好不要这样写程序,这样不好调试,建议将过零检测放入中断中。实时性会稍好些!
 
 
 

回复

90

帖子

0

TA的资源

一粒金砂(初级)

9
 
引用 7 楼 galle 的回复:
最好不要这样写程序,这样不好调试,建议将过零检测放入中断中。实时性会稍好些!


可是PIC12C508没中断功能.
 
 
 

回复

72

帖子

0

TA的资源

一粒金砂(初级)

10
 
对不起没有仔细的看型号!对pic的单片机没有多少了解!呵呵!不过不知到他的管脚改变功能可否借用做中断??
 
 
 

回复

67

帖子

0

TA的资源

一粒金砂(初级)

11
 
多谢指教,我看看
 
 
 

回复

69

帖子

0

TA的资源

一粒金砂(初级)

12
 
引用 9 楼 galle 的回复:
对不起没有仔细的看型号!对pic的单片机没有多少了解!呵呵!不过不知到他的管脚改变功能可否借用做中断??

我试试看,差不多可以把,我再修改一下
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条
报名最后一周!2025 英飞凌消费、计算与通讯创新大会-北京站
会议时间:3月18日(周二)09:30签到
参会奖励:电动螺丝刀套装、户外登山包、京东卡

查看 »

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表