亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? svgen.s

?? Sensorless Field Oriented Control of PMSM Motors
?? S
字號:
;*******************************************************************
; SVGen
;  
;Description:  Calculate and load SVGen PWM values.
;
;
;
;Functional prototype:
; 
; void CalcSVGen( void )
;
;On Entry:   SVGenParm structure must contain qVr1, qVr2, qVr3
;
;On Exit:    PWM registers loaded
;
;Parameters: 
; Input arguments: None
;
; Return:
;   Void
;
; SFR Settings required:
;         CORCON.SATA  = 0
;         CORCON.IF    = 0
;
; Support routines required: None
;
; Local Stack usage: 0
;
; Registers modified: w0,w2,w3,w4,w5,w6,AccA
;
; Timing: 34 instruction cycles
;
;*******************************************************************
; C-Version of code
;
;void CalcRefVec( void )
;{ 
;    if( Vr1 >= 0 )
;        {       
;        // (xx1)
;        if( Vr2 >= 0 )
;            {
;            // (x11)
;            // Must be Sector 3 since Sector 7 not allowed
;            // Sector 3: (0,1,1)  0-60 degrees
;            T1 = Vr2
;            T2 = Vr1
;            CalcTimes();
;            dPWM1 = Ta
;            dPWM2 = Tb
;            dPWM3 = Tc
;            }
;        else
;            {            
;            // (x01)
;            if( Vr3 >= 0 )
;                {
;                // Sector 5: (1,0,1)  120-180 degrees
;                T1 = Vr1
;                T2 = Vr3
;                CalcTimes();
;                dPWM1 = Tc
;                dPWM2 = Ta
;                dPWM3 = Tb
;
;                }
;            else
;                {
;                // Sector 1: (0,0,1)  60-120 degrees
;                T1 = -Vr2;
;                T2 = -Vr3;
;                CalcTimes();
;                dPWM1 = Tb
;                dPWM2 = Ta
;                dPWM3 = Tc
;                }
;            }
;        }
;    else
;        {
;        // (xx0)
;        if( Vr2 >= 0 )
;            {
;            // (x10)
;            if( Vr3 >= 0 )
;                {
;                // Sector 6: (1,1,0)  240-300 degrees
;                T1 = Vr3
;                T2 = Vr2
;                CalcTimes();
;                dPWM1 = Tb
;                dPWM2 = Tc
;                dPWM3 = Ta
;                }
;            else
;                {
;                // Sector 2: (0,1,0)  300-0 degrees
;                T1 = -Vr3
;                T2 = -Vr1
;                CalcTimes();
;                dPWM1 = Ta
;                dPWM2 = Tc
;                dPWM3 = Tb
;                }
;            }
;        else
;            {            
;            // (x00)
;            // Must be Sector 4 since Sector 0 not allowed
;            // Sector 4: (1,0,0)  180-240 degrees
;            T1 = -Vr1
;            T2 = -Vr2
;            CalcTimes();
;            dPWM1 = Tc
;            dPWM2 = Tb
;            dPWM3 = Ta
;
;            }
;        }
;}
;
;
;void CalcTimes(void)
;{
;    T1 = PWM*T1
;    T2 = PWM*T2
;    Tc = (PWM-T1-T2)/2
;    Tb = Ta + T1
;    Ta = Tb + T2
;}        
;
;
;*******************************************************************
;
          .include "general.inc"

; External references
          .include "Park.inc"
          .include "SVGen.inc"

; Register usage
                        
          .equ WorkW,     w1  ; Working register
                        
          .equ T1W,       w2
          .equ T2W,       w3
                        
          .equ WorkDLoW,  w4  ; double word (multiply results)
          .equ Vr1W,      w4
          .equ TaW,       w4
          .equ WorkDHiW,  w5  ; double word (multiply results)
          .equ Vr2W,      w5
          .equ TbW,       w5
          .equ Vr3W,      w6
          .equ TcW,       w6

        .equ dPWM1, PDC1
        .equ dPWM2, PDC2
        .equ dPWM3, PDC3

;=================== CODE =====================

          .section  .text
          .global   _CalcSVGen
          .global   CalcSVGen

_CalcSVGen:
CalcSVGen:

     ;; Get qVr1,qVr2,qVr3
          mov.w     _SVGenParm+SVGen_qVr1,Vr1W
          mov.w     _SVGenParm+SVGen_qVr2,Vr2W
          mov.w     _SVGenParm+SVGen_qVr3,Vr3W

     ;; Test Vr1
          cp0       Vr1W
          bra       LT,jCalcRef20       ; Vr1W < 0

     ;; Test Vr2
          cp0       Vr2W
          bra       LT,jCalcRef10       ; Vr2W < 0

     ;; Must be Sector 3 since Sector 7 not allowed
     ;; Sector 3: (0,1,1)  0-60 degrees

     ;; T1 = Vr2
     ;; T2 = Vr1
          mov.w     Vr2W,T2W
          mov.w     Vr1W,T1W
          rcall     CalcTimes

     ;; dPWM1 = Ta
     ;; dPWM2 = Tb
     ;; dPWM3 = Tc
          mov.w     TaW,dPWM1
          mov.w     TbW,dPWM2
          mov.w     TcW,dPWM3
          return

jCalcRef10:
     ;; Test Vr3
          cp0       Vr3W
          bra       LT,jCalcRef15       ; Vr3W < 0

     ;; Sector 5: (1,0,1)  120-180 degrees
     ;; T1 = Vr1
     ;; T2 = Vr3
          mov.w     Vr1W,T2W
          mov.w     Vr3W,T1W
          rcall     CalcTimes

     ;; dPWM1 = Tc
     ;; dPWM2 = Ta
     ;; dPWM3 = Tb
          mov.w     TcW,dPWM1
          mov.w     TaW,dPWM2
          mov.w     TbW,dPWM3
          return

jCalcRef15:

     ;; Sector 1: (0,0,1)  60-120 degrees
     ;; T1 = -Vr2
     ;; T2 = -Vr3
          neg.w     Vr2W,T2W
          neg.w     Vr3W,T1W
          rcall     CalcTimes

     ;; dPWM1 = Tb
     ;; dPWM2 = Ta
     ;; dPWM3 = Tc
          mov.w     TbW,dPWM1
          mov.w     TaW,dPWM2
          mov.w     TcW,dPWM3
          return

jCalcRef20:

     ;; Test Vr2
          cp0       Vr2W
          bra       LT,jCalcRef30       ; Vr2W < 0

     ;; Test Vr3
          cp0       Vr3W
          bra       LT,jCalcRef25       ; Vr3W < 0

     ;; Sector 6: (1,1,0)  240-300 degrees
     ;; T1 = Vr3
     ;; T2 = Vr2
          mov.w     Vr3W,T2W
          mov.w     Vr2W,T1W
          rcall     CalcTimes

     ;; dPWM1 = Tb
     ;; dPWM2 = Tc
     ;; dPWM3 = Ta
          mov.w     TbW,dPWM1
          mov.w     TcW,dPWM2
          mov.w     TaW,dPWM3
          return

jCalcRef25:
     ;; Sector 2: (0,1,0)  300-360 degrees
     ;; T1 = -Vr3
     ;; T2 = -Vr1
          neg.w     Vr3W,T2W
          neg.w     Vr1W,T1W
          rcall     CalcTimes

     ;; dPWM1 = Ta
     ;; dPWM2 = Tc
     ;; dPWM3 = Tb
          mov.w     TaW,dPWM1
          mov.w     TcW,dPWM2
          mov.w     TbW,dPWM3
          return

jCalcRef30:
     ;; Must be Sector 4 since Sector 0 not allowed
     ;; Sector 4: (1,0,0)  180-240 degrees

     ;; T1 = -Vr1
     ;; T2 = -Vr2
          neg.w     Vr1W,T2W
          neg.w     Vr2W,T1W
          rcall     CalcTimes

     ;; dPWM1 = Tc
     ;; dPWM2 = Tb
     ;; dPWM3 = Ta
          mov.w     TcW,dPWM1
          mov.w     TbW,dPWM2
          mov.w     TaW,dPWM3
          return

;*******************************************************************
; CalcTimes
;
;
;void CalcTimes(void)
;{
;    T1 = PWM*T1
;    T2 = PWM*T2
;    Tc = (PWM-T1-T2)/2
;    Tb = Ta + T1
;    Ta = Tb + T2
;}        
;
; Timing: 17instruction cycles
;
;*******************************************************************
CalcTimes:

     ;; T1 = PWM*T1

     ;; Since T1 is in 1.15 and PWM in integer we do multiply by
     ;; 2*PWM*T1 as integers and use upper word of results

     ;; Load PWMPeriod 
          sl.w      _SVGenParm+SVGen_iPWMPeriod,WREG	;Mul PWM * 2 to allow for full range of voltage
          mul.us    w0,T1W,WorkDLoW
          mov.w     WorkDHiW,T1W

     ;; T2 = PWM*T2
          mul.us    w0,T2W,WorkDLoW
          mov.w     WorkDHiW,T2W

     ;; Tc = (PWM-T1-T2)/2
          mov.w	    _SVGenParm+SVGen_iPWMPeriod,WREG				
          sub.w     w0,T1W,WorkW        ;PWM-T1
          sub.w     WorkW,T2W,WorkW     ; -T2
          asr.w     WorkW,WorkW         ; /2
          mov.w     WorkW,TcW           ; store Tc

     ;; Tb = Tc + T1
          add.w     WorkW,T1W,WorkW
          mov.w     WorkW,TbW


     ;; Ta = Tb + T2
          add.w     WorkW,T2W,WorkW
          mov.w     WorkW,TaW
          return




?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区影视| 三级影片在线观看欧美日韩一区二区| 国产精品美女www爽爽爽| 亚洲乱码国产乱码精品精小说| 日韩国产精品久久| 91一区二区三区在线观看| 欧美一区二区三区日韩视频| 自拍偷自拍亚洲精品播放| 蜜桃在线一区二区三区| 精品国产一区二区三区久久影院| 国内精品久久久久影院色| 欧美国产日韩亚洲一区| 91影院在线观看| 国产三级精品视频| 91在线小视频| 青青国产91久久久久久| 国产亚洲一本大道中文在线| 北条麻妃国产九九精品视频| 亚洲综合偷拍欧美一区色| 欧美一区二区三区日韩视频| 国产成人8x视频一区二区| 日韩伦理电影网| 91精品国产综合久久久久| 一区二区三区鲁丝不卡| 欧美一区二区三区婷婷月色| 床上的激情91.| 国产亚洲欧美色| 色综合久久久久久久久| 最新不卡av在线| 在线电影一区二区三区| 成人午夜在线视频| 天天综合色天天综合色h| 国产日韩三级在线| 成人一区二区三区| 国产亚洲婷婷免费| 国产福利一区二区三区在线视频| 亚洲女性喷水在线观看一区| 欧美va亚洲va| 国产在线日韩欧美| 亚洲综合一区二区精品导航| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 首页国产欧美日韩丝袜| 欧美艳星brazzers| 亚洲第一会所有码转帖| 欧美专区亚洲专区| 国产高清精品在线| 久久精品国产99国产| 亚洲美女视频在线观看| 国产婷婷色一区二区三区在线| 国产精品一区二区不卡| 国产欧美一区视频| 欧美一卡2卡三卡4卡5免费| 老司机精品视频导航| 亚洲黄色免费电影| 亚洲色图一区二区三区| 国产免费成人在线视频| 99久久精品久久久久久清纯| 亚洲欧美一区二区三区孕妇| 久久久精品黄色| 91老师国产黑色丝袜在线| 国产一区二区剧情av在线| 日韩在线卡一卡二| 亚洲bt欧美bt精品777| 亚洲激情男女视频| 国产精品久久久久一区二区三区| 色婷婷精品大在线视频| 日本不卡一区二区三区高清视频| 亚洲自拍都市欧美小说| 欧美一级一区二区| 欧美精品第一页| 在线播放91灌醉迷j高跟美女| 91精彩视频在线| 激情另类小说区图片区视频区| 国产色综合一区| 在线精品国精品国产尤物884a| 秋霞国产午夜精品免费视频| 五月激情六月综合| 丝袜脚交一区二区| 欧美激情一区三区| 国产精品久久影院| 中文字幕综合网| 亚洲欧美一区二区视频| 日韩欧美中文字幕精品| 日韩一区二区免费高清| 99久久综合色| 91精品一区二区三区久久久久久 | 91免费精品国自产拍在线不卡| 国产91富婆露脸刺激对白| 一级特黄大欧美久久久| 精品久久久久久综合日本欧美| 成人黄色综合网站| aaa欧美大片| 91成人国产精品| 国产精品538一区二区在线| 久久精品国产一区二区三区免费看 | 精品88久久久久88久久久| 久久久国产午夜精品| 国产精品第13页| 日韩亚洲国产中文字幕欧美| 日韩亚洲欧美在线| 国产日韩欧美精品综合| 亚洲天堂av老司机| 国产校园另类小说区| 中文字幕一区二区三区四区| 亚洲专区一二三| 久久精品国产秦先生| 国产成人午夜99999| 99久久99久久免费精品蜜臀| 国产一区二区三区免费在线观看| 午夜日韩在线电影| 国产伦精一区二区三区| 色综合天天综合网国产成人综合天| 色欧美88888久久久久久影院| 国产成人精品综合在线观看| 91久久精品网| 成人av免费在线| 国产成人午夜精品5599| 欧美四级电影在线观看| 久久久亚洲午夜电影| 精品粉嫩aⅴ一区二区三区四区| 国产农村妇女毛片精品久久麻豆 | 欧美成人aa大片| 亚洲啪啪综合av一区二区三区| 免费观看成人av| 91老师国产黑色丝袜在线| 欧美撒尿777hd撒尿| 久久久久久久久久久99999| 精品国产乱码久久久久久牛牛| 欧美一卡在线观看| 亚洲四区在线观看| 狠狠色伊人亚洲综合成人| 欧美视频一二三区| 色综合久久综合网97色综合| 欧美mv日韩mv| 日韩欧美国产麻豆| 亚洲成人动漫av| 日韩av电影免费观看高清完整版在线观看 | 欧美mv和日韩mv的网站| 2欧美一区二区三区在线观看视频| 亚洲丝袜自拍清纯另类| 一区二区三区精品视频| 一区二区欧美国产| 成人一道本在线| 日韩精品一区二区三区中文不卡 | 成人精品电影在线观看| 成人妖精视频yjsp地址| 99久久婷婷国产综合精品| 色悠久久久久综合欧美99| 成人av资源网站| 久久综合九色欧美综合狠狠| 亚洲一级二级在线| 91高清在线观看| 欧美自拍偷拍午夜视频| 欧美日韩国产一区二区三区地区| 中文字幕在线不卡国产视频| 午夜精品123| 欧美最新大片在线看| 一区二区三区在线播放| 蜜臀av一区二区在线免费观看 | 亚洲电影一区二区| 欧美性受极品xxxx喷水| 欧美女孩性生活视频| 精品免费国产一区二区三区四区| 日韩制服丝袜先锋影音| 国产成人精品一区二区三区四区 | 欧美日韩美女一区二区| 亚洲一区二区不卡免费| 一区二区三区不卡视频在线观看 | 国产区在线观看成人精品| 一区视频在线播放| av激情综合网| 亚洲视频网在线直播| 91久久精品网| 午夜视频一区二区| 欧美一区二区三区日韩| 精一区二区三区| 国产视频在线观看一区二区三区| 亚洲精品国产无天堂网2021 | 91精品1区2区| 三级一区在线视频先锋| 日韩欧美美女一区二区三区| 毛片av一区二区| 久久久午夜精品理论片中文字幕| 亚洲天堂网中文字| 日本精品一区二区三区高清| 亚洲午夜精品一区二区三区他趣| 久久国产精品一区二区| 久久你懂得1024| 91一区二区三区在线播放| 亚洲一区在线观看免费| 日韩欧美黄色影院| 成人高清视频在线| 亚洲一区二区精品视频| 3d成人动漫网站| 亚洲精品国产a久久久久久| 欧美高清一级片在线| 国产真实精品久久二三区| 欧美一区二区三区四区久久| 国产福利不卡视频| 亚洲一区二区三区四区五区黄|