我为检测特定序列的 Mealy 状态机定义了一个模块。我没有像通常那样对状态进行编码,因为我想以另一种方式进行编码(我在一本书中看到了一个类似的例子,但代码是 VHDL 格式的)。
module seq_detector(y_out,Clk,x_in);
output y_out;
reg y_out;
input x_in, Clk;
reg Q1,Q2,Q3,Q4;
always @(posedge Clk)
Q1 <= (Q1&&(!Q3))||((!Q1)&&Q2;&&(!Q3)&&(!Q4)&&(x_in));
Q2 <= ((!Q3)&&Q4;&&(!x_in))||(Q1&&Q2;&&(!Q3)&&(!Q4)&&x_in);
Q3 <= Q1&&Q2;&&(!Q3)&&(x_in);
Q4 <= (Q1&&Q2;&&(x_in))||(Q1&&(!Q4)&&(!x_in))||((!Q1)&&(!Q2)&&(Q4)&&(!x_in))||((!Q1)&&(!Q2)&&(x_in))||((!Q1)&&(!Q3)&&Q4;&&x_in)||(Q1&&Q2;&&(!Q4)&&x_in);
always @(x_in or Q1 or Q2 or Q3 or Q4)
y_out <= Q3||(Q2&&(!Q4)&&x_in);
endmodule
在编译代码时,我收到以下错误。
mini_project.v:8: syntax error
mini_project.v:8: error: Invalid module instantiation
mini_project.v:9: error: Invalid module instantiation
mini_project.v:10: error: Invalid module instantiation
我无法弄清楚错误消息的任何内容。有人可以解释错误消息并建议如何更正吗?