<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic dpc++ optimizing too much and producing wrong result in Intel® oneAPI DPC++/C++ Compiler</title>
    <link>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1341513#M1723</link>
    <description>&lt;P&gt;With O2 optimization, it produces wrong result whereas Intel 19.1 compiler produces correct result.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;////////////////////////////////////////////////////&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;std::vector&amp;lt;SMDBL&amp;gt; dWdLambda(3,0.);&lt;BR /&gt;MATRIX2DZERO(d2Wd2Lambda, SMDBL, 3, 3);&lt;BR /&gt;for(INTL1 k=0; k&amp;lt;numMu_; k++){&lt;BR /&gt;SMDBL jInvAlpha = std::pow(jvalue,-alpha_[k]/3.);&lt;BR /&gt;SMDBL factor = jInvAlpha*mu_[k]/3.;&lt;BR /&gt;// factor *= &lt;BR /&gt;dWdLambda[0] += (factor/lambda[0])*(+2*std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k])&lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;dWdLambda[1] += (factor/lambda[1])*(-std::pow(lambda[0],alpha_[k]) + 2.*std::pow(lambda[1],alpha_[k])&lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;dWdLambda[2] += (factor/lambda[2])*(-std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k])&lt;BR /&gt;+ 2.*std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;if(elPtr!=NULL){&lt;BR /&gt;if(elPtr-&amp;gt;getUserID()==-99999999){&lt;BR /&gt;// NOTE: This is to avoid a bug in intel dpc++ compiler bug in O2 optimization(release module)&lt;BR /&gt;// Compiler is optimizing too much causing dWdLambda to be infinite.&lt;BR /&gt;// (probably compilier is doing some optimization). To remove this, please test with&lt;BR /&gt;// release module and dpc++ comiler.&lt;BR /&gt;PRINT_DIAG(ASSEMBLY_DIAG,0,"dWdLambda",&amp;amp;dWdLambda[0],3);&lt;BR /&gt;}&lt;BR /&gt;}&lt;/P&gt;
&lt;P&gt;SMDBL factor2 = alpha_[k]*factor/3.; // alpha_[k]*mu(J^-alpha/3)/9&lt;BR /&gt;d2Wd2Lambda[0][0] += (factor2/lambda2[0])*(&lt;BR /&gt;4.*std::pow(lambda[0],alpha_[k])+std::pow(lambda[1],alpha_[k])+std::pow(lambda[2],alpha_[k])) &lt;BR /&gt;- (factor/lambda2[0])*(+2*std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k]) &lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;d2Wd2Lambda[0][1] += (factor2/(lambda[0]*lambda[1]))*(&lt;BR /&gt;-2.*std::pow(lambda[0],alpha_[k]) - 2.*std::pow(lambda[1],alpha_[k]) + std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;d2Wd2Lambda[0][2] += (factor2/(lambda[0]*lambda[2]))*(&lt;BR /&gt;-2.*std::pow(lambda[0],alpha_[k]) + std::pow(lambda[1],alpha_[k]) - 2*std::pow(lambda[2],alpha_[k]));&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;d2Wd2Lambda[1][1] += (factor2/lambda2[1])*(&lt;BR /&gt;std::pow(lambda[0],alpha_[k])+4.*std::pow(lambda[1],alpha_[k])+std::pow(lambda[2],alpha_[k])) &lt;BR /&gt;- (factor/lambda2[1])*(-std::pow(lambda[0],alpha_[k]) + 2.*std::pow(lambda[1],alpha_[k]) &lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;d2Wd2Lambda[1][2] += (factor2/(lambda[1]*lambda[2]))*(&lt;BR /&gt;+ std::pow(lambda[0],alpha_[k]) - 2.*std::pow(lambda[1],alpha_[k]) - 2*std::pow(lambda[2],alpha_[k]));&lt;/P&gt;
&lt;P&gt;d2Wd2Lambda[2][2] += (factor2/lambda2[2])*(&lt;BR /&gt;std::pow(lambda[0],alpha_[k])+std::pow(lambda[1],alpha_[k])+4.*std::pow(lambda[2],alpha_[k])) &lt;BR /&gt;- (factor/lambda2[2])*(-std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k]) &lt;BR /&gt;+ 2.*std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;}&lt;/P&gt;
&lt;P&gt;///////////////////////////////////////////////////&lt;/P&gt;</description>
    <pubDate>Sun, 05 Dec 2021 07:11:28 GMT</pubDate>
    <dc:creator>SUKLA</dc:creator>
    <dc:date>2021-12-05T07:11:28Z</dc:date>
    <item>
      <title>dpc++ optimizing too much and producing wrong result</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1341513#M1723</link>
      <description>&lt;P&gt;With O2 optimization, it produces wrong result whereas Intel 19.1 compiler produces correct result.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;////////////////////////////////////////////////////&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;std::vector&amp;lt;SMDBL&amp;gt; dWdLambda(3,0.);&lt;BR /&gt;MATRIX2DZERO(d2Wd2Lambda, SMDBL, 3, 3);&lt;BR /&gt;for(INTL1 k=0; k&amp;lt;numMu_; k++){&lt;BR /&gt;SMDBL jInvAlpha = std::pow(jvalue,-alpha_[k]/3.);&lt;BR /&gt;SMDBL factor = jInvAlpha*mu_[k]/3.;&lt;BR /&gt;// factor *= &lt;BR /&gt;dWdLambda[0] += (factor/lambda[0])*(+2*std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k])&lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;dWdLambda[1] += (factor/lambda[1])*(-std::pow(lambda[0],alpha_[k]) + 2.*std::pow(lambda[1],alpha_[k])&lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;dWdLambda[2] += (factor/lambda[2])*(-std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k])&lt;BR /&gt;+ 2.*std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;if(elPtr!=NULL){&lt;BR /&gt;if(elPtr-&amp;gt;getUserID()==-99999999){&lt;BR /&gt;// NOTE: This is to avoid a bug in intel dpc++ compiler bug in O2 optimization(release module)&lt;BR /&gt;// Compiler is optimizing too much causing dWdLambda to be infinite.&lt;BR /&gt;// (probably compilier is doing some optimization). To remove this, please test with&lt;BR /&gt;// release module and dpc++ comiler.&lt;BR /&gt;PRINT_DIAG(ASSEMBLY_DIAG,0,"dWdLambda",&amp;amp;dWdLambda[0],3);&lt;BR /&gt;}&lt;BR /&gt;}&lt;/P&gt;
&lt;P&gt;SMDBL factor2 = alpha_[k]*factor/3.; // alpha_[k]*mu(J^-alpha/3)/9&lt;BR /&gt;d2Wd2Lambda[0][0] += (factor2/lambda2[0])*(&lt;BR /&gt;4.*std::pow(lambda[0],alpha_[k])+std::pow(lambda[1],alpha_[k])+std::pow(lambda[2],alpha_[k])) &lt;BR /&gt;- (factor/lambda2[0])*(+2*std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k]) &lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;d2Wd2Lambda[0][1] += (factor2/(lambda[0]*lambda[1]))*(&lt;BR /&gt;-2.*std::pow(lambda[0],alpha_[k]) - 2.*std::pow(lambda[1],alpha_[k]) + std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;d2Wd2Lambda[0][2] += (factor2/(lambda[0]*lambda[2]))*(&lt;BR /&gt;-2.*std::pow(lambda[0],alpha_[k]) + std::pow(lambda[1],alpha_[k]) - 2*std::pow(lambda[2],alpha_[k]));&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;d2Wd2Lambda[1][1] += (factor2/lambda2[1])*(&lt;BR /&gt;std::pow(lambda[0],alpha_[k])+4.*std::pow(lambda[1],alpha_[k])+std::pow(lambda[2],alpha_[k])) &lt;BR /&gt;- (factor/lambda2[1])*(-std::pow(lambda[0],alpha_[k]) + 2.*std::pow(lambda[1],alpha_[k]) &lt;BR /&gt;- std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;d2Wd2Lambda[1][2] += (factor2/(lambda[1]*lambda[2]))*(&lt;BR /&gt;+ std::pow(lambda[0],alpha_[k]) - 2.*std::pow(lambda[1],alpha_[k]) - 2*std::pow(lambda[2],alpha_[k]));&lt;/P&gt;
&lt;P&gt;d2Wd2Lambda[2][2] += (factor2/lambda2[2])*(&lt;BR /&gt;std::pow(lambda[0],alpha_[k])+std::pow(lambda[1],alpha_[k])+4.*std::pow(lambda[2],alpha_[k])) &lt;BR /&gt;- (factor/lambda2[2])*(-std::pow(lambda[0],alpha_[k]) - std::pow(lambda[1],alpha_[k]) &lt;BR /&gt;+ 2.*std::pow(lambda[2],alpha_[k]));&lt;BR /&gt;}&lt;/P&gt;
&lt;P&gt;///////////////////////////////////////////////////&lt;/P&gt;</description>
      <pubDate>Sun, 05 Dec 2021 07:11:28 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1341513#M1723</guid>
      <dc:creator>SUKLA</dc:creator>
      <dc:date>2021-12-05T07:11:28Z</dc:date>
    </item>
    <item>
      <title>Re:dpc++ optimizing too much and producing wrong result</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1341718#M1724</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;/P&gt;&lt;P&gt;Thanks for reaching out to us.&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;/P&gt;&lt;P&gt;Could you please provide the&amp;nbsp;following information?&lt;/P&gt;&lt;P&gt;1)DPC++ version and OS you are using.&lt;/P&gt;&lt;P&gt;2)The complete&amp;nbsp;sample reproducer code(The above provided code is not sufficient for analyzing your issue).&lt;/P&gt;&lt;P&gt;3)The compilation and execution command for reproducing this issue.&lt;/P&gt;&lt;P&gt;4)Screenshots&amp;nbsp;for correct and incorrect results with respect to Intel compiler(19.1) and DPC++.&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;/P&gt;&lt;P&gt;Thanks &amp;amp; Regards,&lt;/P&gt;&lt;P&gt;Hemanth.&lt;/P&gt;&lt;BR /&gt;</description>
      <pubDate>Mon, 06 Dec 2021 11:41:42 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1341718#M1724</guid>
      <dc:creator>HemanthCH_Intel</dc:creator>
      <dc:date>2021-12-06T11:41:42Z</dc:date>
    </item>
    <item>
      <title>Re:dpc++ optimizing too much and producing wrong result</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1343642#M1742</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;/P&gt;&lt;P&gt;We haven't heard back from you. Could you please provide the above requested details?&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;/P&gt;&lt;P&gt;Thanks &amp;amp; Regards,&lt;/P&gt;&lt;P&gt;Hemanth.&lt;/P&gt;&lt;BR /&gt;</description>
      <pubDate>Mon, 13 Dec 2021 12:36:20 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1343642#M1742</guid>
      <dc:creator>HemanthCH_Intel</dc:creator>
      <dc:date>2021-12-13T12:36:20Z</dc:date>
    </item>
    <item>
      <title>Re: dpc++ optimizing too much and producing wrong result</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1345358#M1753</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;We have not heard back from you. This thread will no longer be monitored by Intel. If you need further assistance, please post a new question.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thanks &amp;amp; Regards,&lt;/P&gt;
&lt;P&gt;Hemanth.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 20 Dec 2021 12:17:11 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-DPC-C-Compiler/dpc-optimizing-too-much-and-producing-wrong-result/m-p/1345358#M1753</guid>
      <dc:creator>HemanthCH_Intel</dc:creator>
      <dc:date>2021-12-20T12:17:11Z</dc:date>
    </item>
  </channel>
</rss>

