<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: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;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:#0563C1;
text-decoration:underline;}
span.EmailStyle19
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
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">I assume your question is actually “when will we get fcmp ogt and when will we get fcmp ugt?”<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Most languages prescribe that their comparisons are all ordered. So when lowering an operation like a < b, the front-end will generate a fcmp olt. The C language does not prescribe any way to get an unordered comparison, and so the frontend
will never directly generate an unordered operation.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Where unordered floating-point comparisons are generated is most frequently by optimizations. Note that there are four possible states for comparing floating point numbers: unordered, equal, less-than, or greater-than. The fcmp instruction
has 16 possible comparisons, which will return true for a certain subset of those comparisons (with there being a useless fcmp true and fcmp false variant that unconditionally returns true or false). Negating an fcmp instruction is equivalent to using an fcmp
comparison that flips the true/false state: if you negate a fcmp that returns true for only the less-than state, that is equivalent to an fcmp that returns true for unordered, equal, or greater-than. In other words, not (fcmp olt) is equivalent to fcmp uge.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Your mention of setogt/setule makes me think that you are interested in the interaction with SelectionDAG. SelectionDAG actually supports
<i>three</i> different floating-point comparison types: ordered, unordered, and don’t-care. The latter class appears when the fcmp instruction has the nnan fast-math flag set, appears as a setgt SDNode instead of setogt or setugt, and can validly be implemented
by either an unordered or ordered comparison instruction, whichever is less expensive to implement in hardware. If you’re implementing a backend, carefully check the documentation of your hardware to see what the behavior of instructions is when presented
with NaNs.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span style="mso-fareast-language:ZH-CN">From:</span></b><span style="mso-fareast-language:ZH-CN"> llvm-dev <llvm-dev-bounces@lists.llvm.org>
<b>On Behalf Of </b>?? via llvm-dev<br>
<b>Sent:</b> Monday, January 4, 2021 7:39<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></span></p>
</div>
</div>
<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>
</div>
</body>
</html>