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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pid_pmsm32.asm

?? 無刷直流電機的無傳感器控制TI程序
?? ASM
字號:
;============================================================
; Filename:		pid.asm
; Module names:	pid_reg_id, pid_reg_iq
; Initialization routines: pid_reg_id_init, pid_reg_iq_init
; Originator:	Digital control systems Group
;			Texas Instruments
;
; Description:	PI current regulator with integral correction
;			for d and q axes
;		    |~~~~~~~~~~~~|
; i_fdb o------>|		     |
; i_ref o------>|  pid_reg   |----->o  u_out
; u_int o------>|		     |
; Kp            |            |
; Ki    o------>|____________|
; Kc
;
; Target dependency: 'c2xx core only
;=====================================================================================
; History:
;-------------------------------------------------------------------------------------
; 9-15-2000	Release	Rev 1.0	

*************************************************************
* D-Axis PI Current Regulator
*************************************************************
;------------------------------------------------------------
; Reference/Prototype
;------------------------------------------------------------
;		.ref	pid_reg_id,pid_reg_id_init	; function call
;		.ref	id_fdb,id_ref,Kp_d,Ki_d,Kc_d	; Inputs
;		.ref	ud_int				; Input
;		.ref	ud_out				; Outputs

;------------------------------------------------------------
; Global Definitions
;------------------------------------------------------------
		.def	pid_reg_id,pid_reg_id_init	; function call
		.def	id_fdb,id_ref,Kp_d,Ki_d,Kc_d	; Inputs
		.def	ud_int				; Input
		.def	ud_out				; Outputs

;------------------------------------------------------------
; Variable Definitions
;------------------------------------------------------------
id_fdb	.usect "pid",1		; current feedback
id_ref	.usect "pid",1		; current reference
ud_out	.usect "pid",1		; control voltage output

ud_int	.usect "pid",1		; error integral
uintlo_d	.usect "pid",1

Kp_d		.usect "pid",1		; proportional gain
Ki_d		.usect "pid",1		; integral gain
Kc_d		.usect "pid",1		; integral correction gain

id_error	.usect "pid",1		; current error
uprsat_d	.usect "pid",1		; control voltage prio saturation
saterr_d	.usect "pid",1		; saturation error
tmp_d		.usect "pid",1		; temp scrach

;------------------------------------------------------------
; Default parameters
; Parameter spreadsheet: pid.xls
;------------------------------------------------------------
Kp_d_		.set	388			; Q11, proportional gain
Ki_d_		.set	1271			; Q25, integral gain
Kc_d_		.set	32767			; Q14, saturation correction gain

Umax_d_	.set	07000h		; maximum U
Umin_d_	.set	08FFFh		; minimum U

;------------------------------------------------------------
; Initialization
;------------------------------------------------------------
pid_reg_id_init
      ldp	#Kp_d				;
	SPLK	#Kp_d_,Kp_d          	;
      SPLK  #Ki_d_,Ki_d        	;
      SPLK  #Kc_d_,Kc_d       	;
	SPLK	#0,ud_int			; zero integral term
      SPLK	#0,uintlo_d
	RET

;------------------------------------------------------------
; Routine
;------------------------------------------------------------
pid_reg_id
	setc	SXM           		; Allow sign extension
	setc	OVM				; Set overflow protection mode

      ldp	#id_ref			;
      LACC	id_ref,16			; Use ACCH for OV protection
      SUB   id_fdb,16			;
      SACH  id_error			; Q15 id_ref - id_fdb

	lacl	uintlo_d			;
	add	ud_int,16			; 32-bit Q30
      spm	2				; product l/s 4 for accumulation
	LT	id_error			;
      mpy	Kp_d	                	; Q15*Q11 -> 32-bit Q26
	apac					; 32-bit Q30 uint + id_error*Kp_d
      SACH	uprsat_d			; save as Q14 uprsat_d
      sacl	tmp_d				;
      adds	tmp_d				;
	add	uprsat_d,16			; Q30 -> Q31 with OV protection
	sach	tmp_d				; save to tmp_d as Q15
		
	lacc	tmp_d				;
	sub	#Umin_d_			;
      bcnd	U_gmind,GEQ		  	; Continue if tmp_d>=U_min
      lacc	#Umin_d_			; otherwise, saturate
      B	Nextd            
U_gmind
	lacc	tmp_d				;		
	sub	#Umax_d_	        	;
      BCND	U_lmaxd,LEQ     		; Continue if tmp_d<=U_max
      lacc	#Umax_d_		      ; otherwise, saturate
	b	Nextd

U_lmaxd
	lacc	tmp_d				;
Nextd                            	
	sacl	ud_out			;

Int_termd
	lacc	ud_out,15			; Use ACCH for OV protection
	SUB	uprsat_d,16			;
	sach	saterr_d			; save as Q14 saterr_d = ud_out-uprsat_d

	lt	id_error			;
	mpy	Ki_d				; Q15*Q25 -> Q40
	pac					; Q40 -> Q44
	sach	tmp_d				; 
	lacc	tmp_d				; Q44 -> Q28 (r/s 16 bits)
		
	LT	saterr_d           	;
      MPY	Kc_d             	 	; Q14*Q14 -> Q28 saterr_d * Kc_d
	APAC                     	; Q28 Ki_d*id_error + Kc_d*saterr_d

	norm	*				;
	norm	*				; Q28 -> Q30 (with OV protection)

	ADDS	uintlo_d
	ADD	ud_int,16        		; uint + saterr_d*Kc_d + id_error*Ki_d
      SACH  ud_int
	SACL	uintlo_d             	; save as 32-bit Q30

	RET

***END D-Axis PI Current Regulator

		
*************************************************************
* Q-Axis PI Current Regulator
*************************************************************
;------------------------------------------------------------
; Reference/Prototype
;------------------------------------------------------------
;	.ref	pid_reg_iq,pid_reg_iq_init	; function call
;	.ref	iq_fdb,iq_ref,Kp_q,Ki_q,Kc_q	; Inputs
;	.ref	uq_int				; Input
;	.ref	uq_out				; Outputs

;------------------------------------------------------------
; Global Definitions
;------------------------------------------------------------
	.def	pid_reg_iq,pid_reg_iq_init	; function call
	.def	iq_fdb,iq_ref,Kp_q,Ki_q,Kc_q	; Inputs
	.def	uq_int				; Input
	.def	uq_out				; Outputs

;------------------------------------------------------------
; Variable Definitions
;------------------------------------------------------------
iq_fdb	.usect "pid",1		; current feedback
iq_ref	.usect "pid",1		; current reference
uq_out	.usect "pid",1		; control voltage output
                                    
uq_int	.usect "pid",1		; error integral
uintlo_q	.usect "pid",1

Kp_q		.usect "pid",1		; proportional gain
Ki_q		.usect "pid",1		; integral gain
Kc_q		.usect "pid",1		; integral correction gain

iq_error	.usect "pid",1		; current error
uprsat_q	.usect "pid",1		; control voltage prio saturation
saterr_q	.usect "pid",1		; saturation error
tmp_q		.usect "pid",1		; temp scrach

;------------------------------------------------------------
; Default parameters
; Parameter spreadsheet: pid.xls
;------------------------------------------------------------
Kp_q_		.set	776			; Q11, proportional gain
Ki_q_		.set	1907			; Q25, integral gain
Kc_q_		.set	24576			; Q14, saturation correction gain

Umax_q_	.set	07000h		; maximum U
Umin_q_	.set	08FFFh		; minimum U

;------------------------------------------------------------
; Initialization
;------------------------------------------------------------
pid_reg_iq_init
	ldp	#Kp_q				;
	SPLK	#Kp_q_,Kp_q          	;
      SPLK  #Ki_q_,Ki_q        	;
      SPLK  #Kc_q_,Kc_q       	;
	SPLK	#0,uq_int			; zero integral term
      SPLK	#0,uintlo_q
	RET

;------------------------------------------------------------
; Routine
;------------------------------------------------------------
pid_reg_iq
	setc	SXM           		; Allow sign extension
	setc	OVM				; Set overflow protection mode

      ldp	#iq_ref			;
      LACC	iq_ref,16			; Use ACCH for OV protection
      SUB   iq_fdb,16			;
      SACH  iq_error			; Q15 iq_ref - iq_fdb

	lacl	uintlo_q			;
	add	uq_int,16			; 32-bit Q30
      spm	2				; product l/s 4 before accumulation
	LT	iq_error			;
      mpy	Kp_q	                	; Q15*Q11 -> 32-bit Q26
	apac					; 32-bit Q30 uint + iq_error*Kp_q
      SACH	uprsat_q			; save as Q14 uprsat_q
      sacl	tmp_q				;
      adds	tmp_q				;
	add	uprsat_q,16			; Q30 -> Q31 with OV protection
	sach	tmp_q				; save to tmp_q as Q15
		
	lacc	tmp_q				;
	sub	#Umin_q_			;
      bcnd	U_gminq,GEQ		  	; Continue if tmp_q>=U_min
      lacc	#Umin_q_			; otherwise, saturate
      B	Nextq            
U_gminq
	lacc	tmp_q				;		
	sub	#Umax_q_	        	;
      BCND	U_lmaxq,LEQ     		; Continue if tmp_q<=U_max
      lacc	#Umax_q_		      ; otherwise, saturate
      b	Nextq

U_lmaxq
	lacc	tmp_q				;
Nextq                            	
	sacl	uq_out			;

Int_termq
	lacc	uq_out,15			; Use ACCH for OV protection
	SUB	uprsat_q,16			;
      sach	saterr_q			; save as Q14 saterr_q = uq_out-uprsat_q

	lt	iq_error			;
	mpy	Ki_q				; Q15*Q26 -> Q40
	pac					; Q40 -> Q44
	sach	tmp_q				;
	lacc	tmp_q				; Q44 -> Q28 (r/s 16 bits)
		
	LT	saterr_q           	;
      MPY	Kc_q             	 	; Q14*Q14 -> Q28 saterr_q * Kc_q
	APAC                     	; Q28 Ki_q*iq_error + Kc_q*saterr_q

	norm	*				;
	norm	*				; Q28 -> Q30 (with OV protection)

	ADDS	uintlo_q
	ADD	uq_int,16        		; uint + saterr_q*Kc_q + iq_error*Ki_q
      SACH 	uq_int
	SACL	uintlo_q             	; save as 32-bit Q30

	RET

***END Q-Axis PI Current Regulator

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美韩国日本一区| 欧美日韩国产另类不卡| 色综合久久久久网| 91精品国产91久久综合桃花| 国产亚洲一二三区| 日韩国产精品91| 日本韩国精品在线| 日本一区二区在线不卡| 久久精品国产成人一区二区三区 | 色综合 综合色| 精品三级在线看| 亚洲国产精品一区二区www在线| 国产成人aaa| 精品少妇一区二区| 老司机一区二区| 欧美乱妇20p| 亚洲宅男天堂在线观看无病毒| 国产suv一区二区三区88区| 日韩一卡二卡三卡| 亚洲福利一二三区| 日本道色综合久久| 亚洲精品日日夜夜| 91蜜桃网址入口| 国产精品免费av| 成人午夜免费视频| 欧美国产日韩在线观看| 懂色av中文一区二区三区| 国产日产精品一区| 成人永久aaa| 欧美国产日韩亚洲一区| 国产69精品久久久久777| 国产人成亚洲第一网站在线播放| 狠狠v欧美v日韩v亚洲ⅴ| 久久一区二区三区国产精品| 久久99久久久久| 欧美成人一区二区三区片免费| 男男成人高潮片免费网站| 91精品久久久久久久久99蜜臂| 午夜在线成人av| 日韩久久久久久| 韩国成人福利片在线播放| 久久久久国产成人精品亚洲午夜| 国产米奇在线777精品观看| 久久久国产精品麻豆| 国产69精品久久久久777| 亚洲欧洲日韩女同| 在线视频欧美精品| 日韩国产欧美三级| 久久久国产精品午夜一区ai换脸| 成人动漫中文字幕| 亚洲一级二级在线| 日韩欧美中文一区| 成人av资源站| 亚洲午夜免费电影| 精品国产乱码久久久久久1区2区 | 欧美二区乱c少妇| 蜜桃免费网站一区二区三区| 久久综合久久综合九色| 成人免费视频免费观看| 亚洲一区二区成人在线观看| 精品国产一区久久| 成人永久看片免费视频天堂| 亚洲国产毛片aaaaa无费看| 欧美精品一区二区三区高清aⅴ| 国产成人精品三级| 亚洲成人777| 国产亚洲精品资源在线26u| 在线观看欧美精品| 经典一区二区三区| 亚洲码国产岛国毛片在线| 日韩一级在线观看| 成人av在线影院| 青青草精品视频| **性色生活片久久毛片| 欧美一区二区久久| 成人av网站大全| 美日韩一级片在线观看| 亚洲人成网站色在线观看| 欧美不卡一区二区三区| 91精品福利在线| 国产高清在线观看免费不卡| 亚洲v日本v欧美v久久精品| 国产精品三级av| 日韩视频免费直播| 一本久久a久久精品亚洲| 激情综合色综合久久| 亚洲综合一区二区精品导航| 久久久久成人黄色影片| 69久久夜色精品国产69蝌蚪网| 成人午夜av在线| 久久99久久精品| 日韩国产欧美一区二区三区| 一区二区三区欧美在线观看| 国产欧美一区二区精品仙草咪| 日韩一本二本av| 欧美精品xxxxbbbb| 在线观看亚洲一区| 色中色一区二区| av资源站一区| 成人18视频日本| 国产成人免费在线观看不卡| 精品影院一区二区久久久| 亚洲影院理伦片| 亚洲一区在线观看网站| 亚洲欧美偷拍卡通变态| 国产精品乱码一区二三区小蝌蚪| 国产亚洲一二三区| 日本一区二区三区视频视频| 精品国产乱码久久久久久久| 日韩精品最新网址| 欧美大片免费久久精品三p| 欧美喷水一区二区| 欧美日韩国产电影| 欧美影视一区二区三区| 欧美色图激情小说| 欧美午夜精品免费| 欧美日韩极品在线观看一区| 欧美日韩在线免费视频| 欧美午夜寂寞影院| 欧美日韩在线播放一区| 欧美日韩国产电影| 日韩色视频在线观看| 日韩天堂在线观看| 日韩免费视频一区| www国产成人| 欧美国产国产综合| 亚洲视频每日更新| 亚洲午夜私人影院| 另类调教123区| 国产福利一区在线| 99re8在线精品视频免费播放| 99精品欧美一区二区蜜桃免费| 91黄色在线观看| 91精品久久久久久蜜臀| 精品国产91久久久久久久妲己 | 亚洲成av人影院| 三级亚洲高清视频| 国内一区二区在线| av一区二区三区四区| 在线中文字幕一区| 日韩欧美久久一区| 国产日韩精品一区| 亚洲五月六月丁香激情| 老色鬼精品视频在线观看播放| 国产精品66部| 在线一区二区视频| 精品久久99ma| 亚洲人成小说网站色在线 | 成人深夜福利app| 欧美色国产精品| 久久婷婷色综合| 亚洲午夜精品在线| 国产成人av网站| 欧美日韩国产电影| 国产精品视频免费看| 偷拍与自拍一区| 国产99久久精品| 欧美精选一区二区| 国产精品视频第一区| 热久久国产精品| 色综合亚洲欧洲| 久久婷婷国产综合精品青草| 一区二区三区日本| 国产91色综合久久免费分享| 欧美日韩国产成人在线91| 中文字幕不卡三区| 男女男精品视频网| 91成人国产精品| 国产精品女主播在线观看| 奇米影视在线99精品| 欧美专区在线观看一区| 国产欧美一区二区精品婷婷| 日韩不卡一区二区| 91激情五月电影| 亚洲欧洲日韩一区二区三区| 国产精品主播直播| 欧美一区二区三区日韩| 亚洲精品成人天堂一二三| 国产盗摄一区二区三区| 日韩欧美成人一区二区| 午夜精品福利久久久| 91免费看视频| 中文字幕日韩一区二区| 国产精品资源网| 国产亚洲精品7777| 久久99国产精品久久| 91精品欧美久久久久久动漫 | 欧美性受xxxx| 日韩欧美资源站| 亚洲综合色网站| 色婷婷激情综合| 中文字幕视频一区二区三区久| 国产老女人精品毛片久久| 日韩欧美国产精品| 三级成人在线视频| 欧美日韩国产高清一区二区三区| 亚洲国产精品一区二区久久恐怖片| 成人黄色免费短视频| 国内一区二区视频| 久久你懂得1024|