<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-2022-jp">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"MS Mincho";
        panose-1:2 2 6 9 4 2 5 8 3 4;}
@font-face
        {font-family:SimSun;
        panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:"\@SimSun";
        panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
        {font-family:"\@MS Mincho";
        panose-1:2 2 6 9 4 2 5 8 3 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:JA;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:#1F497D;
        font-weight:normal;
        font-style:normal;
        text-decoration:none none;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal"><span style="color:#1F497D">Hi Lijia,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">IEEE 754 standard has a strict definition on comparison predicates. In short, symbol “<=” is not the flip of “>”. There’s no such symbol in C language currently (Maybe in draft, I’m not sure), but LLVM IR does
 support all predicates. So the opposition of predicates ogt (“>” is C) is ule and the opposition of predicates ole (“<=” is C) is ugt.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">That’s why you get opposite results from cmp1 and cmp2. The equivalent to cmp1 in IR is:<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D;mso-fareast-language:ZH-CN">define zeroext i1 @_Z4cmp2f(float %a) {<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D;mso-fareast-language:ZH-CN">entry:<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D;mso-fareast-language:ZH-CN">  %cmp = fcmp ule float %a, 0.000000e+00<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D;mso-fareast-language:ZH-CN">  %not = xor i1 %cmp, -1<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D;mso-fareast-language:ZH-CN">  ret i1 %not<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D;mso-fareast-language:ZH-CN">}<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">Thanks<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">Pengfei<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><b>From:</b> llvm-dev <llvm-dev-bounces@lists.llvm.org> <b>On Behalf Of
</b>?? via llvm-dev<br>
<b>Sent:</b> Monday, January 4, 2021 8:39 PM<br>
<b>To:</b> llvm-dev <llvm-dev@lists.llvm.org><br>
<b>Subject:</b> [llvm-dev] Floating point ordered and unordered comparisons<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Hi All,<o:p></o:p></p>
</div>
<div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I have some questions about Floating point ordered and unordered comparisons,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">I did some searching and found link below<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><a href="http://lists.llvm.org/pipermail/llvm-dev/2013-July/063571.html">http://lists.llvm.org/pipermail/llvm-dev/2013-July/063571.html</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">But I still don't quite understand Floating point ordered and unordered<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">comparisons. For example, the following code<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">```<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">bool cmp1(float a) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  if (a > 0.0)<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">   return true;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  else<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">   return false;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">bool cmp2(float a) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  if (!(a <= 0.0))<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">   return true;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  else<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">   return false;<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">```<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">The generated ir code is similar to the following:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">```<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">define zeroext i1 @_Z4cmp1f(float %a) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">entry:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  %cmp = fcmp ogt float %a, 0.000000e+00<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  ret i1 %cmp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">define zeroext i1 @_Z4cmp2f(float %a) {<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">entry:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  %cmp = fcmp ugt float %a, 0.000000e+00<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">  ret i1 %cmp<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">}<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">```<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">If the parameter passed is NaN in this example, the result of cmp1 is false and<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">the result of cmp2 is true. In this case, the result is completely opposite.
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">When will we get 'fcmp ugt' and when will we get 'fcmp ugt' ? When comparing<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">ordered and unorder can be converted ? Such as converting an ordered less than<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">"setolt" into unordered greater than "setuge" operation. <o:p>
</o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Thanks in advance,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">Lijia He<o:p></o:p></p>
</div>
</div>
</div>
</body>
</html>