實驗20:步進電機2
實驗目的
實驗任務
本實驗的任務設計一個步進電機運行控制電路,A、B、C、D分別表示步進電機的四相繞組,步進電機按四相四拍的方式運行。如要求電機正傳時,控制端T=1,電機的四相繞組的通電順序為AC—DA—BD—CB—AC……如要求電機反傳時,控制端T=0,電機的四相繞組的通電順序為AC—CB—BD—DA—AC……。
本文引用地址:http://cafeforensic.com/article/202310/451510.htm實驗原理
為了實現(xiàn)上述設計要求,我們可以將T作為判斷電機正轉和反轉的條件。
當T = 1時,電機的四相繞組的通電順序為AC(1010)—DA(1001)—BD(0101)—CB(0110)—AC(1010)。
當T = 0時,電機的四相繞組的通電順序為AC(1010)—CB(0110)—BD(0101)—DA(1001)—AC(1010)。由此我們可以認為四相的順序為A-C-B-D
Verilog HDL建模描述
設計文件 stepmotor2.v
module stepmotor2(input wire clk,rst,input wire dir, //控制端 1:正轉 0:反轉output wire [3:0] led //四相控制對應的led,A(led[0]),B(led[1]),C(led[2]),D(led[3]));wire clk1h; //1秒時鐘reg [3:0] ctrl; //DCBA四相控制 parameter S1 = 2'b00, //電機步進狀態(tài) AC S2 = 2'b01, //DA S3 = 2'b10, //BD S4 = 2'b11; //CB reg [1:0] cur_state,next_state; divide #( //產(chǎn)生1秒時鐘信號.WIDTH(24),.N(12000000)) u1(.clk(clk),.rst_n(rst),.clkout(clk1h));always@(posedge clk1h or negedge rst) //第一段 if(!rst) cur_state <= S1; else cur_state <= next_state;always@(cur_state or rst or dir) //第二段,狀態(tài)轉移,dir控制方向 if(!rst) begin next_state = S1; end else begin if(dir) //當控制端為1,正轉 case(cur_state) S1:next_state = S2; //正轉S1-S2-S3-S4-S1 S2:next_state = S3; S3:next_state = S4; S4:next_state = S1; endcase else //當控制端為0,反轉 case(cur_state) S1:next_state = S4; //反轉S1-S4-S3-S2-S1 S2:next_state = S1; S3:next_state = S2; S4:next_state = S3; endcase endalways@(posedge clk1h or negedge rst) //第三段,當前狀態(tài)輸出 if(!rst) begin ctrl <= 4'b0101; end else begin case(next_state) S1: ctrl <= 4'b0101; //AC S2: ctrl <= 4'b1001; //DA S3: ctrl <= 4'b1010; //DB S4: ctrl <= 4'b0110; //CB default: ctrl <= 4'b0101; endcase endassign led = ctrl; //狀態(tài)輸出動作對應的ledendmodule
實驗步驟
當撥碼開關M7置1時,會按照ABCD按照10101001010101101010的順序正向循環(huán)。
當撥碼開關M7置0時,會按照ABCD按照10100110010110011010的順序反向循環(huán)。
當任一時刻,rst所連接的按鍵開關置0,則回到1010狀態(tài),正向或反向則取決于此刻的M7值。
評論