paradiseo/trunk/paradiseo-eo/doc/html/t-eoinsertion_8cpp-source.html
legrand c3aec878e5 Paradiseo-eo sources added
git-svn-id: svn://scm.gforge.inria.fr/svnroot/paradiseo@40 331e1502-861f-0410-8da2-ba01fb791d7f
2006-12-12 14:49:08 +00:00

123 lines
7.4 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>EO: t-eoinsertion.cpp Source File</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.3.9.1 -->
<div class="qindex"> <form class="search" action="search.php" method="get">
<a class="qindex" href="main.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="namespaces.html">Namespace List</a> | <a class="qindex" href="hierarchy.html">Class&nbsp;Hierarchy</a> | <a class="qindex" href="classes.html">Alphabetical&nbsp;List</a> | <a class="qindex" href="annotated.html">Class&nbsp;List</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="namespacemembers.html">Namespace&nbsp;Members</a> | <a class="qindex" href="functions.html">Class&nbsp;Members</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a> | <span class="search"><u>S</u>earch&nbsp;for&nbsp;<input class="search" type="text" name="query" value="" size="20" accesskey="s"/></span></form></div>
<div class="nav">
<a class="el" href="dir_000002.html">test</a></div>
<h1>t-eoinsertion.cpp</h1><div class="fragment"><pre class="fragment">00001 <span class="comment">//-----------------------------------------------------------------------------</span>
00002 <span class="comment">// t-eoinsertion.cpp</span>
00003 <span class="comment">//-----------------------------------------------------------------------------</span>
00004
00005 <span class="preprocessor">#include &lt;eo&gt;</span> <span class="comment">// eoBin, eoPop, eoInsertion</span>
00006
00007 <span class="comment">//-----------------------------------------------------------------------------</span>
00008
00009 <span class="keyword">typedef</span> eoBin&lt;float&gt; Chrom;
00010
00011 <span class="comment">//-----------------------------------------------------------------------------</span>
00012
00013 <span class="keywordtype">void</span> binary_value(Chrom&amp; chrom)
00014 {
00015 <span class="keywordtype">float</span> sum = 0;
00016 <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> i = 0; i &lt; chrom.size(); i++)
00017 <span class="keywordflow">if</span> (chrom[i])
00018 sum += pow(2, chrom.size() - i - 1);
00019 chrom.fitness(sum);
00020 }
00021
00022 <span class="comment">//-----------------------------------------------------------------------------</span>
00023
00024 main()
00025 {
00026 <span class="keyword">const</span> <span class="keywordtype">unsigned</span> CHROM_SIZE = 4;
00027 <span class="keywordtype">unsigned</span> i;
00028
00029 eoBinRandom&lt;Chrom&gt; random;
00030
00031 <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> POP_SIZE = 4; POP_SIZE &lt;=6; POP_SIZE++)
00032 {
00033 <a class="code" href="classeo_pop.html">eoPop&lt;Chrom&gt;</a> pop;
00034
00035 <span class="keywordflow">for</span> (i = 0; i &lt; POP_SIZE; i++)
00036 {
00037 Chrom chrom(CHROM_SIZE);
00038 random(chrom);
00039 binary_value(chrom);
00040 pop.push_back(chrom);
00041 }
00042
00043 <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> POP2_SIZE = 4; POP2_SIZE &lt;=6; POP2_SIZE++)
00044 {
00045 <a class="code" href="classeo_pop.html">eoPop&lt;Chrom&gt;</a> pop2, pop3, pop4, pop5, popx;
00046
00047 <span class="keywordflow">for</span> (i = 0; i &lt; POP2_SIZE; i++)
00048 {
00049 Chrom chrom(CHROM_SIZE);
00050 random(chrom);
00051 binary_value(chrom);
00052 pop2.push_back(chrom);
00053 }
00054
00055 std::cout &lt;&lt; <span class="stringliteral">"--------------------------------------------------"</span> &lt;&lt; std::endl
00056 &lt;&lt; <span class="stringliteral">"breeders \tpop"</span> &lt;&lt; std::endl
00057 &lt;&lt; <span class="stringliteral">"--------------------------------------------------"</span> &lt;&lt; std::endl;
00058 <span class="keywordflow">for</span> (i = 0; i &lt; max(pop.size(), pop2.size()); i++)
00059 {
00060 <span class="keywordflow">if</span> (pop.size() &gt; i)
00061 std::cout &lt;&lt; pop[i] &lt;&lt; <span class="stringliteral">" "</span> &lt;&lt; pop[i].fitness() &lt;&lt; <span class="stringliteral">" \t"</span>;
00062 <span class="keywordflow">else</span>
00063 std::cout &lt;&lt; <span class="stringliteral">"\t\t"</span>;
00064 <span class="keywordflow">if</span> (pop2.size() &gt; i)
00065 std::cout &lt;&lt; pop2[i] &lt;&lt; <span class="stringliteral">" "</span> &lt;&lt; pop2[i].fitness();
00066 std::cout &lt;&lt; std::endl;
00067 }
00068
00069 eoInsertion&lt;Chrom&gt; insertion(0.75);
00070 popx = pop;
00071 pop3 = pop2;
00072 insertion(popx, pop3);
00073
00074 eoInsertion&lt;Chrom&gt; insertion2;
00075 popx = pop;
00076 pop4 = pop2;
00077 insertion2(popx, pop4);
00078
00079 eoInsertion&lt;Chrom&gt; insertion3(1.5);
00080 popx = pop;
00081 pop5 = pop2;
00082 insertion3(popx, pop5);
00083
00084 std::cout &lt;&lt; std::endl
00085 &lt;&lt; <span class="stringliteral">"0.75 \t\t1.0 \t\t1.5"</span> &lt;&lt; std::endl
00086 &lt;&lt; <span class="stringliteral">"---- \t\t--- \t\t---"</span> &lt;&lt; std::endl;
00087 <span class="keywordflow">for</span> (i = 0; i &lt; pop5.size(); i++)
00088 {
00089 <span class="keywordflow">if</span> (pop3.size() &gt; i)
00090 std::cout &lt;&lt; pop3[i] &lt;&lt; <span class="stringliteral">" "</span> &lt;&lt; pop3[i].fitness() &lt;&lt; <span class="stringliteral">" \t"</span>;
00091 <span class="keywordflow">else</span>
00092 std::cout &lt;&lt; <span class="stringliteral">" \t\t"</span>;
00093 <span class="keywordflow">if</span> (pop4.size() &gt; i)
00094 std::cout &lt;&lt; pop4[i] &lt;&lt; <span class="stringliteral">" "</span> &lt;&lt; pop4[i].fitness() &lt;&lt; <span class="stringliteral">" \t"</span>;
00095 <span class="keywordflow">else</span>
00096 std::cout &lt;&lt; <span class="stringliteral">" \t\t"</span>;
00097 <span class="keywordflow">if</span> (pop5.size() &gt; i)
00098 std::cout &lt;&lt; pop5[i] &lt;&lt; <span class="stringliteral">" "</span> &lt;&lt; pop5[i].fitness();
00099 std::cout &lt;&lt; std::endl;
00100 }
00101 }
00102 }
00103
00104 <span class="keywordflow">return</span> 0;
00105 }
00106
00107 <span class="comment">//-----------------------------------------------------------------------------</span>
00108
</pre></div><hr size="1"><address style="align: right;"><small>Generated on Thu Oct 19 05:06:43 2006 for EO by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.3.9.1 </small></address>
</body>
</html>