<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>https://www.verific.com/faq/index.php?action=history&amp;feed=atom&amp;title=Statically_elaborate_with_different_values_of_parameters</id>
		<title>Statically elaborate with different values of parameters - Revision history</title>
		<link rel="self" type="application/atom+xml" href="https://www.verific.com/faq/index.php?action=history&amp;feed=atom&amp;title=Statically_elaborate_with_different_values_of_parameters"/>
		<link rel="alternate" type="text/html" href="https://www.verific.com/faq/index.php?title=Statically_elaborate_with_different_values_of_parameters&amp;action=history"/>
		<updated>2026-05-02T12:42:50Z</updated>
		<subtitle>Revision history for this page on the wiki</subtitle>
		<generator>MediaWiki 1.26.3</generator>

	<entry>
		<id>https://www.verific.com/faq/index.php?title=Statically_elaborate_with_different_values_of_parameters&amp;diff=748&amp;oldid=prev</id>
		<title>Hoa at 19:38, 27 October 2021</title>
		<link rel="alternate" type="text/html" href="https://www.verific.com/faq/index.php?title=Statically_elaborate_with_different_values_of_parameters&amp;diff=748&amp;oldid=prev"/>
				<updated>2021-10-27T19:38:51Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class='diff diff-contentalign-left'&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;tr style='vertical-align: top;' lang='en'&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Revision as of 19:38, 27 October 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l16&quot; &gt;Line 16:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 16:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;int main(&lt;del class=&quot;diffchange diffchange-inline&quot;&gt;int argc, char **argv&lt;/del&gt;)&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;int main()&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;{&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;{&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#160;&amp;#160; &amp;#160; const char *file_name = &amp;quot;test.sv&amp;quot; ;&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#160;&amp;#160; &amp;#160; const char *file_name = &amp;quot;test.sv&amp;quot; ;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Hoa</name></author>	</entry>

	<entry>
		<id>https://www.verific.com/faq/index.php?title=Statically_elaborate_with_different_values_of_parameters&amp;diff=366&amp;oldid=prev</id>
		<title>Hoa: Created page with &quot;C++:  &lt;nowiki&gt; #include &quot;VeriCopy.h&quot;       // Make class VeriMapForCopy available #include &quot;Map.h&quot;            // Make class Map available #include &quot;Message.h&quot;        // Make m...&quot;</title>
		<link rel="alternate" type="text/html" href="https://www.verific.com/faq/index.php?title=Statically_elaborate_with_different_values_of_parameters&amp;diff=366&amp;oldid=prev"/>
				<updated>2019-03-04T23:48:41Z</updated>
		
		<summary type="html">&lt;p&gt;Created page with &amp;quot;C++:  &amp;lt;nowiki&amp;gt; #include &amp;quot;VeriCopy.h&amp;quot;       // Make class VeriMapForCopy available #include &amp;quot;Map.h&amp;quot;            // Make class Map available #include &amp;quot;Message.h&amp;quot;        // Make m...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;C++:&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;&lt;br /&gt;
#include &amp;quot;VeriCopy.h&amp;quot;       // Make class VeriMapForCopy available&lt;br /&gt;
#include &amp;quot;Map.h&amp;quot;            // Make class Map available&lt;br /&gt;
#include &amp;quot;Message.h&amp;quot;        // Make message handlers available&lt;br /&gt;
#include &amp;quot;veri_file.h&amp;quot;      // Make verilog reader available&lt;br /&gt;
#include &amp;quot;VeriModule.h&amp;quot;     // Definition of a VeriModule and VeriPrimitive&lt;br /&gt;
#include &amp;quot;VeriLibrary.h&amp;quot;&lt;br /&gt;
#include &amp;quot;Array.h&amp;quot;          // Make class Array available&lt;br /&gt;
#include &amp;quot;VeriId.h&amp;quot;         // Definitions of all verilog identifier nodes&lt;br /&gt;
#include &amp;quot;Strings.h&amp;quot;        // Definition of class to manipulate copy, concatenate, create etc...&lt;br /&gt;
&lt;br /&gt;
#ifdef VERIFIC_NAMESPACE&lt;br /&gt;
using namespace Verific ;&lt;br /&gt;
#endif&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
int main(int argc, char **argv)&lt;br /&gt;
{&lt;br /&gt;
    const char *file_name = &amp;quot;test.sv&amp;quot; ;&lt;br /&gt;
   &lt;br /&gt;
    if (!veri_file::Analyze(file_name, veri_file::SYSTEM_VERILOG)) return 1 ;&lt;br /&gt;
    &lt;br /&gt;
    // Get all the top level modules&lt;br /&gt;
    Array *all_top_modules = veri_file::GetTopModules(&amp;quot;work&amp;quot;) ;&lt;br /&gt;
&lt;br /&gt;
    Map *param_map = new Map(STRING_HASH) ;&lt;br /&gt;
    // Apply set only module 'top1'&lt;br /&gt;
    (void) param_map-&amp;gt;Insert(&amp;quot;top1/p&amp;quot;, &amp;quot;8&amp;quot;) ;&lt;br /&gt;
&lt;br /&gt;
    // Pass parameter map to set new value to parameter 'p' of module 'top1' only &lt;br /&gt;
    if (!veri_file::ElaborateMultipleTopStatic(all_top_modules, param_map)) {&lt;br /&gt;
        delete param_map ;&lt;br /&gt;
        return 1 ;&lt;br /&gt;
    }&lt;br /&gt;
    delete all_top_modules ;&lt;br /&gt;
    param_map-&amp;gt;Reset() ;&lt;br /&gt;
                    &lt;br /&gt;
    veri_file::PrettyPrint(&amp;quot;test1_se_pp.v.golden.new&amp;quot;, 0, 0) ;&lt;br /&gt;
    veri_file::ResetParser() ;&lt;br /&gt;
&lt;br /&gt;
    if (!veri_file::Analyze(file_name, veri_file::SYSTEM_VERILOG)) return 1 ;&lt;br /&gt;
    &lt;br /&gt;
    // Get all the top level modules&lt;br /&gt;
    all_top_modules = veri_file::GetTopModules(&amp;quot;work&amp;quot;) ;&lt;br /&gt;
&lt;br /&gt;
    // Apply to all top level modules&lt;br /&gt;
    (void) param_map-&amp;gt;Insert(&amp;quot;p&amp;quot;, &amp;quot;18&amp;quot;) ;&lt;br /&gt;
&lt;br /&gt;
    // Pass parameter map to set new value to parameter 'p' of module 'top1' and 'top2' &lt;br /&gt;
    if (!veri_file::ElaborateMultipleTopStatic(all_top_modules, param_map)) {&lt;br /&gt;
        delete param_map ;&lt;br /&gt;
        return 1 ;&lt;br /&gt;
    }&lt;br /&gt;
    delete all_top_modules ;&lt;br /&gt;
                    &lt;br /&gt;
    veri_file::PrettyPrint(&amp;quot;test2_se_pp.v.golden.new&amp;quot;, 0, 0) ;&lt;br /&gt;
    delete param_map ;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
    return 0 ;&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
input test.sv:&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;&lt;br /&gt;
module top1 ;&lt;br /&gt;
  parameter p = 1 ;&lt;br /&gt;
&lt;br /&gt;
endmodule&lt;br /&gt;
&lt;br /&gt;
module top2 ;&lt;br /&gt;
  parameter p = 1 ;&lt;br /&gt;
endmodule&lt;br /&gt;
 &amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
output test1_se_pp.v.golden.new&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;&lt;br /&gt;
module top1 /* mod = work.top1 */ ;&lt;br /&gt;
    parameter p = 1 ; &lt;br /&gt;
endmodule&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
module top2 /* mod = work.top2 */ ;&lt;br /&gt;
    parameter p = 1 ; &lt;br /&gt;
endmodule&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
module \top1(p=8)  /* mod = work.top1(p=8) */ ;&lt;br /&gt;
    parameter p = 8 ; &lt;br /&gt;
endmodule&lt;br /&gt;
 &amp;lt;/nowiki&amp;gt;&lt;br /&gt;
&lt;br /&gt;
output test2_se_pp.v.golden.new&lt;br /&gt;
 &amp;lt;nowiki&amp;gt;&lt;br /&gt;
module top1 /* mod = work.top1 */ ;&lt;br /&gt;
    parameter p = 1 ; &lt;br /&gt;
endmodule&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
module top2 /* mod = work.top2 */ ;&lt;br /&gt;
    parameter p = 1 ; &lt;br /&gt;
endmodule&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
module \top1(p=18)  /* mod = work.top1(p=18) */ ;&lt;br /&gt;
    parameter p = 18 ; &lt;br /&gt;
endmodule&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
module \top2(p=18)  /* mod = work.top2(p=18) */ ;&lt;br /&gt;
    parameter p = 18 ; &lt;br /&gt;
endmodule&lt;br /&gt;
 &amp;lt;/nowiki&amp;gt;&lt;/div&gt;</summary>
		<author><name>Hoa</name></author>	</entry>

	</feed>