[libc-commits] [libc] [libc][complex] Implement different flavors of the `conj` function (PR #118671)

via libc-commits libc-commits at lists.llvm.org
Fri Dec 6 06:59:25 PST 2024


================
@@ -0,0 +1,25 @@
+//===-- Implementation of conjf16 function --------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "src/complex/conjf16.h"
+#if defined(LIBC_TYPES_HAS_CFLOAT16)
+
+#include "src/__support/CPP/bit.h"
+#include "src/__support/common.h"
+#include "src/__support/complex_type.h"
+
+namespace LIBC_NAMESPACE_DECL {
+
+LLVM_LIBC_FUNCTION(cfloat16, conjf16, (cfloat16 x)) {
+  Complex<float16> x_c = cpp::bit_cast<Complex<float16>>(x);
+  return (x_c.real - x_c.imag * (cfloat16)1.0i);
----------------
lntue wrote:

I don't think we should use complex arithmetic here.  Probably something like:
```
x_c.imag = -x_c.imag;
return cpp::bit_cast<cfloat16>(x_c);
```
Also this will be used quite a lot.  Feel free to add it to some support template.

https://github.com/llvm/llvm-project/pull/118671


More information about the libc-commits mailing list