集成电路技术分享

 找回密码
 我要注册

QQ登录

只需一步,快速开始

搜索
查看: 2239|回复: 7

源码分享:出租车计费器的 FPGA Verilog源代码

[复制链接]
晓灰灰 发表于 2018-9-7 14:10:52 | 显示全部楼层 |阅读模式
module fp50m(clk,reset,newclk,newclk1);

input clk,reset;output newclk,newclk1;

reg newclk,newclk1;reg [31:0] count,count1;

always@(posedge clk or negedge reset)

begin

if(!reset)

begin

newclk<=1'd0;

count<=32'd0;

end

else if(count==32'd25000000)

begin

count<=32'd0;

newclk<=~newclk;

end//end begin

else count<=count+1'd1;

end

always@(posedge clk or negedge reset)

begin

if(!reset)

begin

newclk1<='d0;

count1<=32'd0;

end

else if(count1==32'd100000)

begin

count1<=32'd0;

newclk1<=~newclk1;

end

else

count1<=count1+1'd1;

endendmodule

module distance(clk,start,reset,run,distance,distance_enable);

input clk,start,reset,run;

output [7:0] distance;

reg [7:0] distance;

output distance_enable;

reg distance_enable;

always@(posedge clk or negedge reset)

begin

if(!reset)

distance<=8'd0;

else if(!start) distance<=8'd0;

else

begin if (run)

begin if(distance[3:0]==9)//判断distance的低四位记到了9没

begin distance[3:0]<=4'd0;//记到则清零

if(distance[7:4]==9) //判断高四位记到9没

distance[7:4]<=4'd0;// 记到则清零

else distance[7:4]<=distance[7:4]+1'd1;// distance的高四位没有记到9则加1

end//end else

distance[3:0]<=distance[3:0]+1'd1;// distance的低四位没有记到9则加1

end//end always

end

always@(posedge clk or negedge reset)

begin

if(!reset)

begin

distance_enable<=1'd0;

end

else if(distance>8'd1)

begin

distance_enable<=1'd1;

end//end begin

end//end always

endmodule

module wait_time(clk,reset,start,run,s,m);

input clk,reset,run,start;

output [7:0] s;

output [7:0] m;

reg [7:0] s;

reg [7:0] m;

always@(posedge clk or negedge reset)

begin

if(!reset)

begin

s<=8'd0; m<=8'd0;

end

else if(!start)

begin

s<=8'd0; m<=8'd0;

end

else if(run)

begin

s<=8'd0; m<=8'd0;

end

else

begin

if(s[3:0]==9)// 秒的低四位是9

begin

s[3:0]<=4'd0;//清零

if(s[7:4]==5) // 秒的高四位是5

begin

s[7:4]<=4'd0; //清零

if(m[3:0]==9) // 分的低四位是9

begin

m[3:0]<=4'd0; //清零

if(m[7:4]==9) // 分的高四位是9

m[7:4]<=4'd0; //清零

else m[7:4]<=m[7:4]+1'd1; // 分的高四位不是9加1

end

else

m[3:0]<=m[3:0]+1'd1; //分的低四位不是9加1

end

else s[7:4]<=s[7:4]+1'd1; // 秒的高四位不是5加1

end

else s[3:0]<=s[3:0]+1'd1; //秒的低四位不是9加1

end

end//end always

endmodule

module charge(clk, //50MHz run, distance_enable, day_enable,start, //启动reset,distance, //里程wait_time, //等待时间charge );

input clk,day_enable,distance_enable,run;input start,reset;

wire [3:0] price_day_time,price_day_distance,price_night_time,price_night_distance,fee;

wire [3:0] one_price_day,one_price_night;

input [7:0] distance;input [7:0] wait_time;

output [15:0] charge;reg [7:0] one_price;

wire [7:0] wait_time;reg [7:0] cnt1; //白天短里程

reg [6:0] cnt2; //白天长里程

reg [6:0] cnt3; //晚上短里程

reg [5:0] cnt4; //晚上长里程

wire [15:0] charge;

assign price_day_time=1;

assign price_day_distance=2;

assign price_night_time=2;

assign price_night_distance=4;

assign one_price_day=5;

assign one_price_night=7;

assign fee=4;

assign charge=one_price+cnt1*price_day_time+cnt2*price_day_distance+cnt3*price_night_time+cnt4*price_night_distance+fee;

always@(posedge clk or negedge reset)

begin

if(!reset) //清零

begin

cnt1<=0;cnt2<=0;cnt3<=0;

cnt4<=0;

one_price<=0;

end

else begin

if(!start)

begin

cnt1<=0;

cnt2<=0;

cnt3<=0;

cnt4<=0;

one_price<=0;

end

else

begin

if(day_enable)

one_price<=one_price_day;

else

one_price<=one_price_night;

begin

if(day_enable && run==1'b0)

begin

if(!run)

begin

cnt1<=wait_time;

end

if(distance_enable)

cnt2<=distance-3'd3;

end

else

begin

if(!run)

cnt3<=wait_time;

if(distance_enable)

cnt4<=distance-3;

end

end

end

end

end

endmodule

module seg(clk,data_in,data_out,addr_out);

input clk;

input [15:0] data_in;

output [7:0] data_out;

output [3:0] addr_out;

wire [7:0] n4,n3,n2,n1;

reg [7:0]data;

reg [6:0] data_out,code=0;reg [3:0] addr,addr_out;

reg [1:0] flag=0;

assign n4=data_in[15:12];

assign n3=data_in[11:8];

assign n2=data_in[7:4];

assign n1=data_in[3:0];

always @(posedge clk)

begin

case(flag)

2'd3:

begin data<=n4;

addr<=4'b0111;

end

2'd2:

begin data<=n3;

addr<=4'b1011;

end

2'd1:

begin

data<=n2;

addr<=4'b1101;

end

2'd0:

begin data<=n1;

addr<=4'b1110;

end

endcase

flag<=flag+1'b1;

if(flag>3)

flag<=0;

case(data)

8'd0: code<=7'b1111110;

8'd1: code<=7'b0110000;

8'd2: code<=7'b1101101;

8'd3: code<=7'b1111001;

8'd4: code<=7'b0110011;

8'd5: code<=7'b1011011;

8'd6: code<=7'b1011111;

8'd7: code<=7'b1110000;

8'd8: code<=7'b1111111;

8'd9: code<=7'b1111011;

endcase

data_out<=~code;

addr_out<=addr;

end

endmodule

module control(clk_50M, reset,start,run,day_enable,duan,wei,key1,key2);

input clk_50M,reset,start,run;

input day_enable,key1,key2;

wire [7:0] distance,s,m;

wire [15:0]charge;

wire clk,distance_enable,time_enable,newclk1;

output [7:0] duan;

output [3:0] wei;

reg [15:0] data;

always@(posedge clk or negedge reset)

begin

if(!reset)

data<=16'd0;

else

begin

if(!start)

data<=16'd0;

else

begin

if(key1)

begin

data <= distance;

end

else

if(key2)

begin

data[15:8] <= m; data[7:0] <= s;

end

else

data <=charge;

end

end

end

taxitop c1(clk_50M, reset,start,run,distance,s,m,charge,clk,day_enable,distance_enable,newclk1);

seg u1(newclk1,data,duan,wei);

endmodule

module taxitop(clk_50M, reset,start,run,distance,s,m,charge,clk,day_enable,distance_enable,newclk1);

input clk_50M,reset,start,day_enable,run;

output[7:0] s,m,charge,distance;

output clk,distance_enable,newclk1;

wire [7:0]distance;wire [7:0] s;

wire [7:0] m;

wire [15:0] charge;

wire[7:0] price_day_time,price_day_distance,price_night_time,price_night_distance, price_wait_time,one_price_day,one_price_night,fee;

wire distance_enable;

wire day_enable;

wire clk,newclk1;

fp50m u1(.clk(clk_50M),.reset(reset),.newclk(clk),.newclk1(newclk1));

distance u2(clk,start,reset,run,distance,distance_enable);

wait_time u3(clk,reset,start,run,s,m);charge u5(clk_50M,run,distance_enable,day_enable,start,reset,distance,m,charge);

endmodule
 楼主| 晓灰灰 发表于 2018-9-7 14:11:03 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
zhangyukun 发表于 2018-9-8 09:14:20 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
 楼主| 晓灰灰 发表于 2018-9-10 11:15:26 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
 楼主| 晓灰灰 发表于 2018-9-17 10:41:50 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
 楼主| 晓灰灰 发表于 2018-10-5 10:25:01 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
 楼主| 晓灰灰 发表于 2018-10-8 10:44:22 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
大鹏 发表于 2022-6-16 11:55:47 | 显示全部楼层
源码分享:出租车计费器的 FPGA Verilog源代码
您需要登录后才可以回帖 登录 | 我要注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

QQ|小黑屋|手机版|Archiver|fpga论坛|fpga设计论坛 ( 京ICP备20003123号-1 )

GMT+8, 2024-11-1 13:35 , Processed in 0.076108 second(s), 19 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表