虫虫首页| 资源下载| 资源专辑| 精品软件
登录| 注册

飞思<b>卡尔</b>

  • 429总线协议说明

    ARINC429总线协议是美国航空电子工程委员会(Airlines Engineering Committee)于1977年7月提出的,并于同年发表并获得批准使用,它的全称是数字式信息传输系统(Digital Information Transmission System ) 。协议标准规定了航空电子设备及有关系统间的数字信息传输要求。ARINC429广泛应用在先进的民航客机中,如B-737、B-757、B-767,俄制军用飞机也选用了类似的技术。 ARINC429总线结构简单、性能稳定,抗干扰性强。最大的优势在于可靠性高。飞机上的ARINC429数据总线,用于在系统和设备之间传送上千种不同类型的参数,如航向、真空速、马赫数等。

    标签: 429总线协议

    上传时间: 2016-08-17

    上传用户:w50403

  • 12345

    /****************temic*********t5557***********************************/    #include   <at892051.h>     #include   <string.h>    #include   <intrins.h>     #include   <stdio.h>     #define    uchar    unsigned char     #define    uint     unsigned int     #define    ulong    unsigned long     //STC12C2051AD的SFR定义     sfr  WDT_CONTR = 0xe1;//stc2051的看门狗??????     /**********全局常量************/    //写卡的命令     #define    write_command0       0//写密码     #define    write_command1       1//写配置字     #define    write_command2       2//密码写数据     #define    write_command3       3//唤醒     #define    write_command4       4//停止命令     #define    TRUE       1     #define    FALSE      0     #define    OK         0     #define    ERROR      255     //读卡的时间参数us     #define ts_min          250//270*11.0592/12=249//取近似的整数     #define ts_max          304//330*11.0592/12=304     #define t1_min          73//90*11.0592/12=83:-10调整     #define t1_max          156//180*11.0592/12=166     #define t2_min          184//210*11.0592/12=194     #define t2_max          267//300*11.0592/12=276     //***********不采用中断处理:采用查询的方法读卡时关所有中断****************/     sbit p_U2270B_Standby = P3^5;//p_U2270B_Standby PIN=13     sbit p_U2270B_CFE = P3^3;//p_U2270B_CFE     PIN=6     sbit p_U2270B_OutPut = P3^7;//p_U2270B_OutPut  PIN=2     sbit wtd_sck = P1^7;//SPI总线     sbit wtd_si = P1^3;    sbit wtd_so = P1^2;    sbit iic_data = P1^2;//lcd IIC     sbit iic_clk = P1^7;    sbit led_light = P1^6;//测试绿灯     sbit led_light1 = P1^5;//测试红灯     sbit led_light_ok  = P1^1;//读卡成功标志     sbit fengmingqi = P1^5;    /***********全局变量************************************/       uchar data Nkey_a[4] = {0xA0, 0xA1, 0xA2, 0xA3};//初始密码             //uchar idata card_snr[4];   //配置字     uchar data bankdata[28] = {1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7};     //存储卡上用户数据(1-7)7*4=28     uchar data cominceptbuff[6] = {1,2,3,4,5,6};//串口接收数组ram     uchar command; //第一个命令     uchar command1;//     //uint  temp;     uchar j,i;    uchar myaddr = 8;    //uchar ywqz_count,time_count;             //ywqz jishu:     uchar bdata DATA;    sbit BIT0 = DATA^0;    sbit BIT1 = DATA^1;    sbit BIT2 = DATA^2;    sbit BIT3 = DATA^3;    sbit BIT4 = DATA^4;    sbit BIT5 = DATA^5;    sbit BIT6 = DATA^6;    sbit BIT7 = DATA^7;    uchar bdata DATA1;    sbit BIT10 = DATA1^0;    sbit BIT11 = DATA1^1;    sbit BIT12 = DATA1^2;    sbit BIT13 = DATA1^3;    sbit BIT14 = DATA1^4;    sbit BIT15 = DATA1^5;    sbit BIT16 = DATA1^6;    sbit BIT17 = DATA1^7;    bit i_CurrentLevel;//i_CurrentLevel  BIT 00H(Saves current level of OutPut pin of U2270B)     bit timer1_end;    bit read_ok = 0;    //缓存定时值,因用同一个定时器     union HLint { uint W;    struct   {    uchar H;uchar L;   }   B; };//union HLint idata a     union HLint data a;    //缓存定时值,因用同一个定时器     union HLint0 { uint W;    struct {   uchar H;   uchar L; } B; };//union HLint idata a     union HLint0 data b;    /**********************函数原型*****************/    //读写操作     void f_readcard(void);//全部读出1~7 AOR唤醒     void f_writecard(uchar x);//根据命令写不同的内容和操作     void f_clearpassword(void);//清除密码     void f_changepassword(void);//修改密码     //功能子函数     void write_password(uchar data *data p);//写初始密码或数据     void write_block(uchar x,uchar data *data p);//不能用通用指针     void write_bit(bit x);//写位     /*子函数区*****************************************************/    void delay_2(uint x)    //延时,时间x*10us@12mhz,最小20us@12mhz     {    x--; x--;    while(x)    {      _nop_();      _nop_();      x--;    }    _nop_();//WDT_CONTR=0X3C;不能频繁的复位     _nop_();    }    /////////////////////////////////////////////////////////////////////     void initial(void)    {    SCON = 0x50; //串口方式1,允许接收     //SCON  =0x50;     //01010000B:10位异步收发,波特率可变,SM2=0不用接收到有效停止位才RI=1,     //REN=1允许接收     TMOD = 0x21; //定时器1 定时方式2(8位),定时器0 定时方式1(16位)     TCON = 0x40; //设定时器1 允许开始计时(IT1=1)     TH1 = 0xfD;  //FB 18.432MHz 9600 波特率     TL1 = 0xfD;  //fd 11.0592 9600     IE = 0X90;     //EA=ES=1     TR1 = 1;     //启动定时器     WDT_CONTR = 0x3c;//使能看门狗     p_U2270B_Standby = 0;//单电源     PCON = 0x00;    IP = 0x10;//uart you xian XXXPS PT1 PX1 PT0 PX0     led_light1 = 1;    led_light = 0;    p_U2270B_OutPut = 1;    }    /************************************************/    void f_readcard()//读卡     {    EA = 0;//全关,防止影响跳变的定时器计时     WDT_CONTR = 0X3C;//喂狗     p_U2270B_CFE = 1;//      delay_2(232);  //>2.5ms            /*   //   aor    用唤醒功能来防碰撞   p_U2270B_CFE = 0; delay_2(18);//start gap>150us   write_bit(1);//10=操作码读0页   write_bit(0);       write_password(&bankdata[24]);//密码block7   p_U2270B_CFE =1 ;//    delay_2(516);//编程及确认时间5.6ms   */    WDT_CONTR = 0X3C;//喂狗     led_light = 0;    b.W = 0;    while(!(read_ok == 1))    {             //while(p_U2270B_OutPut);//等一个稳定的低电平?超时判断?              while(!p_U2270B_OutPut);//等待上升沿的到来同步信号检测1       TR0 = 1;      //deng xia jiang       while(p_U2270B_OutPut);//等待下降沿       TR0 = 0;   a.B.H = TH0;   a.B.L = TL0;   TH0 = TL0 = 0;   TR0 = 1;//定时器晚启动10个周期       //同步头       if((324 < a.W) && (a.W < 353)) ;//检测同步信号1                  else     {     TR0 = 0;     TH0 = TL0 = 0;     goto read_error;    }      //等待上升沿        while(!p_U2270B_OutPut);   TR0 = 0;   a.B.H = TH0;   a.B.L = TL0;   TH0 = TL0 = 0;   TR0 = 1;//b.N1<<=8;            if(a.B.L < 195);//0.5p       else     {     TR0 = 0;     TH0 = TL0 = 0;     goto read_error;    }      //读0~7块的数据       for(j = 0;j < 28;j++)      {       //uchar i;                  for(i = 0;i < 16;i++)//8个位        {        //等待下降沿的到来         while(p_U2270B_OutPut);                TR0 = 0;     a.B.H = TH0;     a.B.L = TL0;     TH0 = TL0 = 0;     TR0 = 1;              if(t2_max < a.W/*)&&(a.W < t2_max)*/)//1P          {         b.W >>= 2;//先左移再赋值          b.B.L += 0xc0;                             i++;        }        else if(t1_min < a.B.L/*)&&(a.B.L < t1_max)*/)//0.5p         {         b.W >>= 1;         b.B.L += 0x80;                           }        else      {      TR0 = 0;      TH0 = TL0 = 0;      goto read_error;     }        i++;        while(!p_U2270B_OutPut);//上升                   TR0 = 0;     a.B.H = TH0;     a.B.L = TL0;     TH0 = TL0 = 0;     TR0 = 1;                      if(t2_min < a.W/*)&&(a.W < t2_max)*/)//1P          {         b.W >>= 2;         i++;        }        else if(t1_min < a.B.L/*a.W)&&(a.B.L < t1_max)*/)//0.5P         //else if(!(a.W==0))         {         b.W >>= 1;         //temp+=0x00;          //led_light1=0;led_light=1;delay_2(40000);         }        else      {      TR0 = 0;      TH0 = TL0 = 0;      goto read_error;     }        i++;       }       //取出奇位        DATA = b.B.L;       BIT13 = BIT7;    BIT12 = BIT5;    BIT11 = BIT3;    BIT10 = BIT1;       DATA = b.B.H;       BIT17 = BIT7;    BIT16 = BIT5;    BIT15 = BIT3;    BIT14 = BIT1;       bankdata[j] = DATA1;      }              read_ok = 1;//读卡完成了     read_error:    _nop_();    }       }    /***************************************************/    void f_writecard(uchar x)//写卡     {    p_U2270B_CFE = 1;    delay_2(232);  //>2.5ms            //psw=0 standard write     if (x == write_command0)//写密码:初始化密码     {      uchar i;      uchar data *data p;      p = cominceptbuff;      p_U2270B_CFE = 0;   delay_2(31);//start gap>330us       write_bit(1);//写操作码1:10       write_bit(0);//写操作码0       write_bit(0);//写锁定位0       for(i = 0;i < 35;i++)      {       write_bit(1);//写数据位1       }      p_U2270B_CFE = 1;      led_light1 = 0;   led_light = 1;   delay_2(40000);//测试使用       //write_block(cominceptbuff[4],p);       p_U2270B_CFE = 1;      bankdata[20] = cominceptbuff[0];//密码存入       bankdata[21] = cominceptbuff[1];      bankdata[22] = cominceptbuff[2];      bankdata[23] = cominceptbuff[3];    }    else if (x == write_command1)//配置卡参数:初始化     {      uchar data *data p;      p = cominceptbuff;      write_bit(1);//写操作码1:10       write_bit(0);//写操作码0       write_bit(0);//写锁定位0               write_block(cominceptbuff[4],p);      p_U2270B_CFE=  1;    }    //psw=1  pssword mode     else if(x == write_command2)  //密码写数据    {      uchar data*data p;      p = &bankdata[24];      write_bit(1);//写操作码1:10       write_bit(0);//写操作码0       write_password(p);//发口令       write_bit(0);//写锁定位0       p = cominceptbuff;      write_block(cominceptbuff[4],p);//写数据            }    else if(x == write_command3)//aor    //唤醒 {      //cominceptbuff[1]操作码10 X xxxxxB       uchar data *data p;      p = cominceptbuff;      write_bit(1);//10       write_bit(0);             write_password(p);//密码       p_U2270B_CFE = 1;//此时数据不停的循环传出     }    else //停止操作码     {      write_bit(1);//11       write_bit(1);             p_U2270B_CFE = 1;         }    p_U2270B_CFE = 1;    delay_2(560);//5.6ms     }    /************************************/    void f_clearpassword()//清除密码     {    uchar data *data p;    uchar i,x;          p = &bankdata[24];//原密码     p_U2270B_CFE = 0; delay_2(18);//start gap>150us     //操作码10:10xxxxxxB     write_bit(1);    write_bit(0);              for(x = 0;x < 4;x++)//发原密码     {             DATA = *(p++);      for(i = 0;i < 8;i++)      {       write_bit(BIT0);       DATA >>= 1;      }    }    write_bit(0);//锁定位0:0     p = &cominceptbuff[0];    write_block(0x00,p);//写新配置参数:pwd=0             //密码无效:即清除密码     DATA = 0x00;//停止操作码00000000B     for(i = 0;i < 2;i++)    {    write_bit(BIT7);    DATA <<= 1;    }    p_U2270B_CFE = 1;       delay_2(560);//5.6ms     }    /*********************************/    void f_changepassword()//修改密码            {       uchar data *data p;    uchar i,x,addr;    addr = 0x07;//block7     p = &Nkey_a[0];//原密码     DATA = 0x80;//操作码10:10xxxxxxB     for(i = 0;i < 2;i++)    {      write_bit(BIT7);      DATA <<= 1;    }    for(x = 0;x < 4;x++)//发原密码     {             DATA = *(p++);      for(i = 0;i < 8;i++)      {       write_bit(BIT7);       DATA >>= 1;      }    }    write_bit(0);//锁定位0:0     p = &cominceptbuff[0];    write_block(0x07,p);//写新密码     p_U2270B_CFE = 1;    bankdata[24] = cominceptbuff[0];//密码存入     bankdata[25] = cominceptbuff[1];    bankdata[26] = cominceptbuff[2];    bankdata[27] = cominceptbuff[3];    DATA = 0x00;//停止操作码00000000B     for(i = 0;i < 2;i++)    {      write_bit(BIT7);      DATA <<= 1;    }    p_U2270B_CFE = 1;       delay_2(560);//5.6ms     }    /***************************子函数***********************************/    void write_bit(bit x)//写一位     {    if(x)    {      p_U2270B_CFE = 1;   delay_2(32);//448*11.0592/120=42延时448us       p_U2270B_CFE = 0;   delay_2(28);//280*11.0592/120=26写1     }    else    {      p_U2270B_CFE = 1;   delay_2(92);//192*11.0592/120=18       p_U2270B_CFE = 0;   delay_2(28);//280*11.0592/120=26写0     }    }    /*******************写一个block*******************/    void write_block(uchar addr,uchar data *data p)    {    uchar i,j;        for(i = 0;i < 4;i++)//block0数据     {             DATA = *(p++);      for(j = 0;j < 8;j++)      {       write_bit(BIT0);       DATA >>= 1;      }    }    DATA = addr <<= 5;//0地址     for(i = 0;i < 3;i++)    {      write_bit(BIT7);      DATA <<= 1;    }                   }    /*************************************************/    void write_password(uchar data *data p)    {    uchar i,j;        for(i = 0;i < 4;i++)//     {             DATA = *(p++);      for(j = 0;j < 8;j++)      {       write_bit(BIT0);       DATA >>= 1;      }    }        }   /*************************************************/   void main()    {    initial();    TI = RI = 0;    ES = 1;    EA = 1;  delay_2(28);   //f_readcard();     while(1) {   f_readcard();      //读卡   f_writecard(command1);  //写卡    f_clearpassword();   //清除密码     f_changepassword();    //修改密码 } }

    标签: 12345

    上传时间: 2017-10-20

    上传用户:my_lcs

  • 三维直角坐标系下卡尔曼滤波CV模型

    三维情况直角坐标系下的卡尔曼滤波matlab实现,采用CV模型

    标签: 坐标系 卡尔曼滤波 模型

    上传时间: 2018-05-10

    上传用户:无丶心灬

  • 基于IMM的卡尔曼滤波跟踪算法

    恒定转弯率与速度模型的扩展卡尔曼交互式多模型的滤波跟踪算法。

    标签: IMM 卡尔曼滤波 跟踪算法

    上传时间: 2021-07-22

    上传用户:迷途在北极的鱼

  • VIP专区-嵌入式/单片机编程源码精选合集系列(156)

    VIP专区-嵌入式/单片机编程源码精选合集系列(156)资源包含以下内容:1. 《嵌入式应用程序开发综合试验9例》含有9个嵌入式应用实践源程序。.2. NiosII NiosII!! SOPC CRC32 SOPC SOPC 自定义外设.3. 一个电话本的程序.4. 嵌入式minigui 中自定义控件的应用实例。不下后悔!.5. minigui 时间控件的使用方法.6. 嵌入式linux 设备驱动程序.7. uart-I2C, working on PIC18F2420.8. 基于mips cpu,在u-boot系统下磁盘驱动程序。.9. 可以应用到IAR EWARM-EV V5.20破解 使用方法: 1:首先用iarid.exe产生ID 2:使用iarkg.exe产生lic文件.10. 嵌入式开发前景和趋势.11. 嵌入式视频有下载器下载方法及一些基本的调试技巧。.12. 同济大学嵌入式学习文档.13. 转载其他网站的资料与大家分享.14. LED点阵显示屏扫描程序.15. altera公司开发销售的DE2开发平台原理图.16. 基于飞斯卡尔MC9S08QG8的基本程序开发代码.17. 本程序中用到DS1302以及液晶等模块.18. 一个垃圾压缩车的PLC程序。采用X端口作为模拟量转换后的数据量输入口。这种方法不需要买模拟量模块.19. 这是一个信号发生器得程序.20. 这个程序可以用作寄存器的使用.21. FAT32文件应用.22. 电源管理代码 基于linux2.6.10!apm方式的电源管理!很好的资料!做arm平台使用.23. I2C zongxian 总线 亲自编译.24. 用Verilog 实现将比特流数据转化为SPI协议数据的适配器.25. 最新F2系列的部分外围模块中文PDF,来自USER GUIDE的翻译.26. 单词计算器,可以统计你输入的单词的字母数有多少个等多个程序.27. FIBER AND wire product designed guider..28. xilin,ise_9.01的使用.29. ISE、Keil_C.30. 一本不错的数字图像处理书(冈萨雷斯中文版)总共有三个压缩文件需要放在一起解压缩.31. miniARM嵌入式web主程序,需要在运行miniarm.32. 单片机操作ocmj12232c-1屏的源代码.33. ISP1582 原理图.34. x-wrt is the GUI config tool for openwrt,which is a open project about wireless Router.35. 首先介绍了合成孔径雷达(SAR)的特点.36. tms320vc5509a usb boot.37. 基于Altera fpga 的软核 nios2的串口调试代码.38. cip51 i2c.39. 此源码为ocm12864系列字符液晶显示模块KEIL uVision3 for ARM.40. 此源码为KEIL uVision3 for ARM 的ocm12864系列字符液晶显示模块。.

    标签: 工业接口 通讯

    上传时间: 2013-06-27

    上传用户:eeworm

  • 四轴飞行器制作的教程、资料汇总整理,5.14G

    四轴制作 四轴从入门到稳飞全教程 狼族四轴AVR 蜂鸟 新版四轴资料.rar 四旋翼飞行器结构和原理.rar 匿名四轴飞行器资料.rar 烈火微型四轴V5.0.pdf 飞行器.rar KK四轴资料.zip crazyflie国外开源微型四轴所有资料.rar 四轴飞行器.zip 四元数与欧拉角之间的转换.pdf 四旋翼资料.zip 全角度姿态角解算方法研究与仿真.pdf 匿名小四轴代码.zip 匿名四轴飞行器资料.rar 领航者资料包-20170730.rar 卡尔曼滤波器介绍.pdf 基于STM32F4的四轴飞行器控制系统_论文.doc ………………

    标签: Visual_C 数字图像处理 典型 算法

    上传时间: 2013-07-24

    上传用户:eeworm

  • 变压器绕组参数辨识研究.rar

    电力变压器是电力系统中及其重要的电气设备,它的安全运行直接关系到电力系统的稳定。变压器长期在电网中运行会发生各种故障和事故,一旦遭到破坏,损失巨大。通过预防性试验和油中溶解气体的气相色谱分析结果判断变压器的绝缘状况,对防止事故的发生有很大作用,但定期的预防性试验可能出现过多的维修和不必要的停机,又不能及时发现故障;而变压器在线监测可以及早发现变压器故障,避免事故的发生,而且可以降低维护成本。 变压器中最常发生故障的部位是绕组,它的损坏率约占整个变压器故障的60%~70%。诊断绕组变形的方法中,频率响应法、阻抗分析法、低压脉冲法虽然有可取之处,但是都属于离线方法,不能及时发现变压器的故障,不适于在线测量;通过实时计算变压器绕组短路电抗来在线诊断变压器故障是一种有效的在线监测方法。 本文根据变压器绕组的短路电抗在正常运行时不发生变化,而在变压器内部故障时要发生变化的特性,应用辩识理论,利用变压器三相电压、电流的测量值来辨识绕组的短路电抗。把辨识结果对比正常时的三相绕组的短路电抗,可以发现绕组是否异常及故障发生的部位,保证变压器元件得到及时更换,防止变压器非正常退出运行。 本文采用傅立叶算法来计算变压器三相电压、电流采样信号的基波分量的幅值与相角,实现变压器绕组的参数辨识,此时并没有考虑衰减直流分量。经过分析,当采样信号中存在衰减直流分量时傅立叶算法就会产生误差,而递推最小二乘法和卡尔曼滤波效果很好。 最后本文介绍了变压器绕组参数辨识的实际应用与误差分析,分析了系统中软件、硬件方面的问题对测量短路电抗造成的影响;以及参数辨识的软件设计和运行试验,验证了方案的可行性。

    标签: 变压器绕组 参数辨识

    上传时间: 2013-07-29

    上传用户:xyipie

  • 电机传动系统参数辨识方法的研究.rar

    在早期阶段,直流调速系统在传动领域中占统治地位。然而,从60年代后期开始,交流电动机在工业应用领域正在取代直流电动机,交流传动变得越来越经济和受欢迎。永磁交流伺服系统作为电气传动领域的重要组成部分,在工业、农业、航空航天等领域发挥越来越重大的作用。永磁同步电动机以其特点广泛应用于中小功率传动场合,成为研究的重要领域。然而,永磁同步电动机具有较大的转动脉动,而对于这些应用场合,转矩平滑通常是基本要求。因此,对永磁交流伺服系统的应用,必须考虑其转矩脉动的抑制问题。本文针对电机传动系统中参数变化对电机性能的影响,以永磁同步电机为例,围绕如何通过参数辨识来提高永磁同步电动机的控制性能,借助自行开发的全数字永磁交流伺服系统平台,对永磁同步电动机的磁场定向控制,参数辨识,神经网络和扩展卡尔曼滤波在控制系统中的应用,抑制转矩脉动,提高系统性能几个方面展开深入的研究。 本文从永磁同步电动机及其控制系统的基本结构出发,对通过参数辨识抑制转矩脉动进行了较为细致的分析。针对不同情况,通过改进电机的控制系统,提出了多种参数辨识方法。主要内容如下: 1、基于定子磁链方程,建立了永磁同步电动机的一般数学模型。经坐标变换,得出在静止两相(α—β)坐标系和旋转两相(d—q)坐标系下永磁同步电动机电压方程和转矩方程。 2、分析了永磁同步电动机id=0矢量控制系统的工作原理,介绍了永磁同步电动基于磁场定向的矢量控制的基本概念。经对永磁同步电动机系统进行分析,推导并建立了id=0控制时整个电机系统的数学模型。 3、基于超稳定性理论的模型参考自适应控制原理,设计了一种模型参考自适应控制系统,考虑电机参数的时变性,对永磁交流伺服系统的绕组电阻和电机负载转矩辨识进行了研究,以保持系统的动态性能。利用Matlab/Simulink建立仿真模型,对控制性能进行了验证,仿真实验证明这种方法的可行性。 4、人工神经网络具有很强的学习性能,经过训练的多层神经网络能以任意精度逼近非线性函数,因此为非线性系统辨识提供了一个强有力的工具。本章针对永磁同步电机提出了一种以电机输出转速为目标函数的神经网络控制方案,同时应用人工神经网络理论建立和设计了负载转矩扰动辨识的算法以及相应的控制系统的补偿方法,并应用MATLAB软件进行了计算机仿真,仿真证明和传统的控制方法相比,以电机输出转速为指导值和目标函数的神经网络控制方案能有效地提高神经网络的收敛速度,能有效地改善控制系统的动态响应,具有跟踪性能好和鲁棒性较强等优点。 5、电机的参数会随着温升和磁路饱和发生变化,需进行在线实时辨识。本文利用电机的定子电流、电压和转速,采用递推最小二乘法进行在线参数辨识,该方法不需要观测的磁链信号,消除了磁链观测和参数辨识的耦合。电机状态方程由于存在状态变量的乘积项,对电机参数辨识以后,仍然是非线性方程,为了对电机状态方程进行状态估计,得到电机的参数辨识值,本文采用扩展卡尔曼滤波进行状态估计,对以上方法的仿真实验得到了满意的结果。 6、本文基于数字电机控制专用DSP自行开发了全数字永磁交流伺服系统平台,通过软件实现扩展卡尔曼滤波对电阻和磁链的估计,以及基于磁场定向的空间矢量控制算法,获得了令人满意的实验结果,证明扩展卡尔曼滤波算法对电阻和磁链的实时估计是很准确的,由此构成的永磁交流伺服系统具有良好的静、动态性能。

    标签: 电机 传动系统 参数辨识

    上传时间: 2013-07-28

    上传用户:凤临西北

  • 纯电动汽车电池管理系统的研究.rar

    随着社会的发展以及能源、环保等问题的日益突出,纯电动汽车以其零排放,噪声低等优点越来越受到世界各国的重视,被称作绿色环保车。作为发展电动车的关键技术之一的电池管理系统(BMS),是电动车产业化的关键。本课题配合“基于开关磁阻电机的电动汽车的研制”,研制适用于纯电动汽车的电池管理系统。 电池管理系统直接检测及管理电动汽车的储能电池运行的全过程,包括电池基本信息测量、电量估计、单体电池间的均衡、电池故障诊断几个方面。 本论文主要工作是研制适用于纯电动汽车的蓄电池管理系统。研究铅酸蓄电池二阶模型的建立与剩余容量的卡尔曼滤波估算方法。分析铅酸蓄电池的基本工作原理和影响蓄电池组剩余容量SOC(state of charge)的主要因素。 介绍了基于DSP2407的蓄电池组控制器的硬件平台,完成DSP小系统、电池数据采集电路、信号调理电路、CAN总线相关电路等硬件电路设计、调试、完善。独立完成系统所有软件设计,包括:主程序设计,电池基本信息检测子程序设计,电池剩余电量卡尔曼滤波估算程序设计,电池状态检测子程序设计,CAN收发子程序设计,EEPROM读写子程序设计。 最后,在电动汽车上搭建实验平台,将铅酸蓄电池组与设计的软硬件系统联合进行调试、试验。测得了相关数据。试验结果表明,本文介绍的电池管理系统硬件电路可靠、经济、抗干扰能力强。可以实现:电池电压、电流、温度的模拟量采集;剩余电量的计算和电池状态的判断;实时显示,故障时报警等BMS相关功能。

    标签: 纯电动汽车 电池管理系统

    上传时间: 2013-06-11

    上传用户:hustfanenze

  • 基于FPGA的数字信号发生器.rar

    数字信号发生器是数字信号处理中不可缺少的调试设备。在某工程项目中,为了提供特殊信号,比如雷达信号,就需要设计专用的数字信号发生器,用以达到发送雷达信号的要求。在本文中提出了使用PCI接口的专用数字信号发生器方案。 该方案的目标是能够采录雷达信号,把信号发送到主机作为信号文件存储起来,然后对这个信号文件进行航迹分离,得到需要的航迹信号文件。同时,信号发生器具有发送信号的功能,可以把不同形式的信号文件发送到检测端口,用于设备调试。 在本文中系统设计主要分为硬件和软件两个方面来介绍: 硬件部分采用了FPGA逻辑设计加上外围电路来实现的。在硬件设计中,最主要的是FPGA逻辑设计,包括9路主从SPI接口信号的逻辑控制,片外SDRAM的逻辑控制,PCI9054的逻辑控制,以及这些逻辑模块间信号的同步、发送和接收。在这个过程中信号的方向是双向的,所选用的芯片都具有双向数据的功能。 在本文中软件部分包括驱动软件和应用软件。驱动软件采用PLXSDK驱动开发,通过控制PCI总线完成数据的采录和发送。应用软件中包括数据提取和数据发送,采用卡尔曼滤波器等方法。 通过实验证明该方案完全满足数据传输的要求,达到SPI传输的速度要求,能够完成航迹提取,以及数据传输。

    标签: FPGA 数字信号发生器

    上传时间: 2013-07-14

    上传用户:脚趾头