// JK flip-flop module
module jkff ( j, k, clk, preset, clear, q, q_bar );
input j, k, clk, preset, clear;
output q, q_bar;
reg q, q_bar;
always @ (posedge clk or preset or clear )
begin
if ( clear == 1 ) begin
q <= 1'b0;
q_bar <= 1'b1;
end else if ( preset == 1 ) begin
q <= 1'b1;
q_bar <= 1'b0;
end else if ( j == 1 && k == 0 ) begin
q <= 1'b1;
q_bar <= 1'b0;
end else if ( j == 0 && k == 1 ) begin
q <= 1'b0;
q_bar <= 1'b1;
end else if ( j == 1 && k == 1 ) begin
q <= q_bar;
q_bar <= q;
end else if ( j == 0 && k == 0 ) begin
q <= q;
q_bar <= q_bar;
end
end
endmodule
// MOD 3 module
module mod3 (clk, in, a, b);
input clk, j1, k1, j2, k2, in;
output a, b, q1, q1bar, q2, q2bar;
wire a, b;
wire j1, k1, j2, k2, in;
wire q1, q1bar, q2, q2bar;
assign j1 = ((in & q2bar) | (~in & q2));
assign k1 = 1;
assign j2 = (q1 & ~in);
assign k2 = (~in);
jkff ff1
(
.clk(clk),
.preset(0),
.clear(0),
.j (j1),
.k (k1),
.q (q1),
.q_bar (q1bar)
);
jkff ff2
(
.clk (clk),
.preset (0),
.clear (0),
.j (j2),
.k (k2),
.q (q2),
.q_bar (q2bar)
);
assign a = q1;
assign b = q2;
endmodule