Forum Replies Created

Viewing 6 posts - 1 through 6 (of 6 total)
  • Author
    Posts
  • in reply to: ToPoliNano Import #1484
    peyman safiripeyman safiri
    Participant

    I atached it.

    Attachments:
    in reply to: ToPoliNano Import #1475
    peyman safiripeyman safiri
    Participant

    hi , I updated magcad software and exported topolinano testbench but another erroe apeared , I atached my testbench and screenshot.
    my testbench :

    --------------------------------------------------------------------------------
    -- Testbench automatically generated by MagCAD                         --
    -- Date: 02/05/2018                                                           --
    -- Time: 13:07:21                                                             --
    --------------------------------------------------------------------------------
    -- Entity: iNML/xor/xor
    --------------------------------------------------------------------------------
    -- DO NOT MODIFY THIS TB, EXCEPT THE INPUT STIMULI PROCESS
    --------------------------------------------------------------------------------
    
    library ieee;
    use ieee.std_logic_1164.all;
    use ieee.numeric_std.all;
    
    entity tb_iNML_xor_xor is
    end tb_iNML_xor_xor;
    
    architecture Behavioural of tb_iNML_xor_xor is
    
    signal A :std_logic;
    signal BN :std_logic;
    signal B :std_logic;
    signal NA :std_logic;
    signal o :std_logic;
    
    component iNML_xor_xor is
    port(
    A: in std_logic;
    BN: in std_logic;
    B: in std_logic;
    NA: in std_logic;
    o: out std_logic);
    end component;
    
    begin
    
    DUT : iNML_xor_xor port map(A => A,
    BN => BN,
    B => B,
    NA => NA,
    o => o);
    --------------------------------------------------------------------------------
    -- PLEASE, DO NOT MODIFY BEFORE THIS POINT
    -- USE THIS PROCESS TO INSERT INPUT STIMULI
    -- Please use the following example as a reference:
    -- input_proc: process
    -- begin
    -- in1<='0';
    -- in2<='0';
    -- wait for 30 ns;
    -- in1<='0';
    -- in2<='1';
    -- wait for 30 ns;
    -- in1<='1';
    -- in2<='1';
    -- wait for 30 ns;
    -- in1<='1';
    -- in2<='0';
    -- wait for 100 us;
    -- process input_proc;
    --
    --
    --------------------------------------------------------------------------------
    
    input_proc: process
    begin
     BN <='1';
     NA <='1';
     B <='0';
     A <='0';
     wait for 95 ns;
     BN <='0';
     NA <='1';
     B <='1';
     A <='0';
     wait for 95 ns;
     BN <='1';
     NA <='0';
     B <='0';
     A <='1';
     wait for 95 ns;
     BN <='0';
     NA <='0';
     B <='1';
     A <='1';
    
    wait for 100 ns;
    end process input_proc;
    
    end Behavioural;
    • This reply was modified 6 years, 8 months ago by UmbertoUmberto.
    Attachments:
    in reply to: ToPoliNano Import #1446
    peyman safiripeyman safiri
    Participant

    my testbench code :

    --------------------------------------------------------------------------------
    -- Testbench automatically generated by MagCAD                         --
    -- Date: 15/04/2018                                                           --
    -- Time: 22:27:17                                                             --
    --------------------------------------------------------------------------------
    -- Entity: iNML/xor1/xor
    --------------------------------------------------------------------------------
    -- DO NOT MODIFY THIS TB, EXEPT THE INPUT STIMULI PROCESS
    --------------------------------------------------------------------------------
    
    library ieee;
    use ieee.std_logic_1164.all;
    use ieee.numeric_std.all;
    use work.NML_definitions.all;
    use work.NML_components.all;
    
    entity tb_iNML_xor1_xor is
    GENERIC
    	(
    		phases: natural := 3;
    		period: time	:= 10 ns
    	);
    end tb_iNML_xor1_xor;
    
    architecture Behavioural of tb_iNML_xor1_xor is
    
    signal A :std_logic;
    signal A_param : param_data := (others => 0.0);
    signal BN :std_logic;
    signal BN_param : param_data := (others => 0.0);
    signal B :std_logic;
    signal B_param : param_data := (others => 0.0);
    signal NA :std_logic;
    signal NA_param : param_data := (others => 0.0);
    signal xorout :std_logic;
    signal xorout_param : param_data := (others => 0.0);
    
    component iNML_xor1_xor is
    port(
    	A: in std_logic;
    	A_param: in param_data := (others => 0.0);
    	BN: in std_logic;
    	BN_param: in param_data := (others => 0.0);
    	B: in std_logic;
    	B_param: in param_data := (others => 0.0);
    	NA: in std_logic;
    	NA_param: in param_data := (others => 0.0);
    	xorout: out std_logic;
    	xorout_param: out param_data := (others => 0.0);
    	
    end component;
    
    begin
    
    DUT : iNML_xor1_xor port map(A => A, A_param => A_param, 
    BN => BN, BN_param => BN_param, 
    B => B, B_param => B_param, 
    NA => NA, NA_param => NA_param, 
    xorout => xorout, xorout_param => xorout_param);
    
      
    --------------------------------------------------------------------------------
    -- PLEASE, DO NOT MODIFY BEFORE THIS POINT
    -- USE THIS PROCESS TO INSERT INPUT STIMULI
    -- Please use the following example as a reference:
    -- input_proc: process
    -- begin
    -- in1<='0';
    -- in2<='0';
    -- wait for 30 ns;
    -- in1<='0';
    -- in2<='1';
    -- wait for 30 ns;
    -- in1<='1';
    -- in2<='1';
    -- wait for 30 ns;
    -- in1<='1';
    -- in2<='0';
    -- wait for 100 us;
    -- process input_proc;
    --
    --
    --------------------------------------------------------------------------------
    
    input_proc: process
    begin
     --insert your input stimuli here 
     
     BN <='0';
     B <='1';
     NA <='0';
     A <='1';
     wait for 50 ns;
     BN <='1';
     B <='0';
     NA <='0';
     A <='1';
     wait for 50 ns;
    
    end process input_proc;
    
    end Behavioural;
    • This reply was modified 6 years, 8 months ago by FabrizioFabrizio. Reason: Please paste code within code tags
    in reply to: ToPoliNano Import #1444
    peyman safiripeyman safiri
    Participant

    hi , I atached my testbench and screenshot from parser erros in topoli nano

    Attachments:
    in reply to: ToPoliNano Import #1434
    peyman safiripeyman safiri
    Participant

    Hi , I imported my layout and testbench without clock proccess, but when I click on simulate log message say “Select an input waveform”
    I atachetd the screenshot

    Attachments:
    in reply to: Error in VHDL Simulation of iNML wire #1254
    peyman safiripeyman safiri
    Participant

    my vhdl codes :

    
    --------------------------------------------------------------------------------
    -- VHDL description automatically generated by MagCAD                         --
    -- Date: 29/01/2018                                                           --
    -- Time: 18:55:01                                                             --
    --------------------------------------------------------------------------------
    -- Entity: iNML/custom/New_1
    --------------------------------------------------------------------------------
    
    library ieee;
    use ieee.std_logic_1164.all;
    use ieee.numeric_std.all;
    use work.NML_definitions.all;
    use work.NML_components.all;
    
    entity iNML_custom_New_1 is
    port(
    	b: out std_logic;
    	b_param: out param_data := (others => 0.0);
    	A: in std_logic;
    	A_param: in param_data := (others => 0.0);
    	CLK: in std_logic_vector(0 to 2));
    end iNML_custom_New_1;
    
    architecture struct of iNML_custom_New_1 is
    for cell3_0: NML_cell use entity work.NML_cell(NML_baseCell);
    signal ls3_0o : std_logic;
    signal ls3_0o_param : param_data := (others => 0.0);
    for cell2_0: NML_cell use entity work.NML_cell(NML_baseCell);
    signal ls2_0o : std_logic;
    signal ls2_0o_param : param_data := (others => 0.0);
    for cell1_0: NML_cell use entity work.NML_cell(NML_baseCell);
    signal ls1_0o : std_logic;
    signal ls1_0o_param : param_data := (others => 0.0);
    for cell0_0: NML_cell use entity work.NML_cell(NML_baseCell);
    signal ls0_0o : std_logic;
    signal ls0_0o_param : param_data := (others => 0.0);
    signal ls4o : std_logic;
    signal ls4o_param : param_data := (others => 0.0);
    begin
    b <= ls3_0o;
    b_param <= ls3_0o_param;
    cell3_0: NML_cell generic map(NInput => 1,NOutput => 1, inputMode => NORMAL)
    	port map(CELL_IN(0) => ls2_0o, PARAM_IN(0) => ls2_0o_param,CELL_OUT(0) => ls3_0o, PARAM_OUT(0) => ls3_0o_param);
    cell2_0: NML_cell generic map(NInput => 1,NOutput => 1, inputMode => NORMAL)
    	port map(CELL_IN(0) => ls1_0o, PARAM_IN(0) => ls1_0o_param,CELL_OUT(0) => ls2_0o, PARAM_OUT(0) => ls2_0o_param);
    cell1_0: NML_cell generic map(NInput => 1,NOutput => 1, inputMode => NORMAL)
    	port map(CELL_IN(0) => ls4o, PARAM_IN(0) => ls4o_param,CELL_OUT(0) => ls1_0o, PARAM_OUT(0) => ls1_0o_param);
    cell0_0: NML_cell generic map(NInput => 1,NOutput => 1, inputMode => NORMAL)
    	port map(CELL_IN(0) => A, PARAM_IN(0) => A_param,CELL_OUT(0) => ls0_0o, PARAM_OUT(0) => ls0_0o_param);
    reg4: nml_reg generic map(WireDirection => FORWARD)
    	port map(REG_IN => ls0_0o, REG_PARAM_IN => ls0_0o_param,REG_OUT => ls4o, REG_PARAM_OUT => ls4o_param, CLK => CLK(0));
    end struct;
    

    and my test bench codes :

    
    --------------------------------------------------------------------------------
    -- Testbench automatically generated by MagCAD                         --
    -- Date: 29/01/2018                                                           --
    -- Time: 18:55:01                                                             --
    --------------------------------------------------------------------------------
    -- Entity: iNML/custom/New_1
    --------------------------------------------------------------------------------
    
    library ieee;
    use ieee.std_logic_1164.all;
    use ieee.numeric_std.all;
    use work.NML_definitions.all;
    use work.NML_components.all;
    
    entity tb_iNML_custom_New_1 is
    GENERIC
    	(
    		phases: natural := 3;
    		period: time	:= 10 ns
    	);
    end tb_iNML_custom_New_1;
    
    architecture Behavioural of tb_iNML_custom_New_1 is
    
    signal base_clk_i : std_logic;
    signal clk_i : std_logic_vector (0 to phases-1);
    signal b :std_logic;
    signal b_param : param_data := (others => 0.0);
    signal A :std_logic;
    signal A_param : param_data := (others => 0.0);
    
    component iNML_custom_New_1 is
    port(
    	b: out std_logic;
    	b_param: out param_data := (others => 0.0);
    	A: in std_logic;
    	A_param: in param_data := (others => 0.0);
    	CLK: in std_logic_vector(0 to 2));
    end component;
    
    begin
    
    DUT : iNML_custom_New_1 port map(b => b, b_param => b_param, 
    A => A, A_param => A_param, 
    CLK => clk_i);
    
    base_clk_proc: process
    begin
    	if (base_clk_i = 'U') then
    	  base_clk_i <= '0';
    	else
    	  base_clk_i <= not(base_clk_i);
    	end if;
    	wait for period/2;
    end process base_clk_proc;
    
    out_clk_proc: process(base_clk_i)
    begin
        -- Clear undefined states
        for i in 0 to phases-1 loop
        	if (clk_i(i) = 'U') then
                	clk_i <= (others => '0'); -- Reset signal
    		clk_i(0) <= '1';
            	exit; -- Force quit
    
            -- Act as shift register on edge of internal clock
        	elsif (base_clk_i'event AND base_clk_i='1') then
                	if (i = 0) then
                    		clk_i(0) <= clk_i(phases-1);
                	else
                    		clk_i(i) <= clk_i(i-1);
                	end if;
        	end if;
        end loop;
    end process out_clk_proc;
      
    input_proc: process
    begin
     --insert your input stimuli here 
    
    A <='1'
    
    end process input_proc;
    
    end Behavioural;
    
    • This reply was modified 6 years, 11 months ago by FabrizioFabrizio.
    • This reply was modified 6 years, 11 months ago by FabrizioFabrizio. Reason: please use the code tag when posting vhdl code and post the whole code in a single reply
    • This reply was modified 6 years, 10 months ago by FabrizioFabrizio.
Viewing 6 posts - 1 through 6 (of 6 total)