kyosu v0.1.0
Complex Without Complexes
Loading...
Searching...
No Matches

◆ acosh

auto kyosu::acosh = eve::functor<acosh_t>
inlineconstexpr

Computes the inverse hyperbolic cosine of the argument.

Header file

#include <kyosu/functions.hpp>

Callable Signatures

namespace kyosu
{
// regular call
constexpr auto acos( acosh(Z z) noexcept;
constexpr auto acos(cayley_dickson_like z, eve::value k) noexcept;
// semantic modifyers
constexpr auto acosh[real_only](concepts::real z) noexcept;
}
General real concept.
Definition concepts.hpp:48
constexpr auto k
Computes the complex number k i.e. quaternion(0, 0, 0, 1) in the chosen type.
Definition k.hpp:74
constexpr auto acosh
Computes the inverse hyperbolic cosine of the argument.
Definition acosh.hpp:100
constexpr auto acos
Computes the arc cosine of the argument.
Definition acos.hpp:109
Main KYOSU namespace.
Definition cinf.hpp:13

Parameters

  • z: Value to process.

Return value

  • A real input z is treated as if complex(z) was entered unless the option real_only is used in which case the parameter must be a floating_value, the result will the same as an eve::acosh implying a Nan result if the theoretical result is not real.
  • For complex input, returns the complex inverse hyperbolic cosine of z, in the range of a strip unbounded along the imaginary axis and in the interval \([0,\pi]\) along the real axis.
    • for every z: acosh(conj(z)) ==conj(acosh(z))
    • If z is \(\pm0\), the result is \(+0+i\pi/2\)
    • If z is \(x+i\infty\) (for any finite x), the result is \(\infty+i\pi/2\)
    • If z is \(x+i \textrm{NaN}\) (for any finite non zero x), the result is \(\textrm{NaN}+i\textrm{NaN}\).
    • If z is \(i \textrm{NaN}\) the result is \(\textrm{NaN}+i\pi/2\).
    • If z is \(-\infty,y\) (for any positive finite y), the result is \(+\infty,\pi\)
    • If z is \(+\infty,y\) (for any positive finite y), the result is \(+\infty+i 0\)
    • If z is \(-\infty+i \infty\), the result is \(+\infty,3\pi/4\)
    • If z is \(\pm\infty+i \textrm{NaN}\), the result is \(+\infty+i \textrm{NaN}\)
    • If z is \(\textrm{NaN},y\) (for any finite y), the result is \(\textrm{NaN}+i \textrm{NaN}\).
    • If z is \(\textrm{NaN}+i \infty\), the result is \(+\infty+i \textrm{NaN}\)
    • If z is \(\textrm{NaN}+i \textrm{NaN}\), the result is \(\textrm{NaN}+i \textrm{NaN}\)
  • For general cayley_dickson input, returns \(\log(z+\sqrt{z+1}\sqrt{z-1})\).
  • For two parameters returns the kth branch of acos. If k is not a flint it is truncated before use.

External references

Example

#include <eve/wide.hpp>
#include <iostream>
#include <kyosu/kyosu.hpp>
int main()
{
using wide_ft = eve::wide<float, eve::fixed<4>>;
wide_ft ref1 = {3.0f, 2.0f, 1.0f, 0.5f};
wide_ft imf1 = {2.0f, -1.0, -5.0, 0.0};
wide_ft ref2 = {0.0, 1.0, 2.0, 3.0};
auto zc = kyosu::complex_t<wide_ft>(ref1, imf1);
std::cout << "---- simd" << std::endl
<< "<- zc = " << zc << std::endl
<< "-> acosh(zc) = " << kyosu::acosh(zc) << std::endl
<< "-> acosh(ref2) = " << kyosu::acosh(ref2) << std::endl;
return 0;
}
as_cayley_dickson_n_t< 2, T > complex_t
Type alias for complex numbers.
Definition complex.hpp:27