E.V.E
v2023.02.15
 
Loading...
Searching...
No Matches

◆ ellint_rg

auto eve::ellint_rg = functor<ellint_rg_t>
inlineconstexpr

Header file

#include <eve/module/elliptic.hpp>

Callable Signatures

namespace eve
{
// Regular overload
constexpr auto ellint_rg(floating_value auto x, floating_value auto y, floating_value auto z) noexcept; // 1
// Lanes masking
constexpr auto ellint_rg[conditional_expr auto c](floating_value auto x, floating_value auto y,
floating_value auto z) noexcept; // 2
constexpr auto ellint_rg[logical_value auto m](floating_value auto x, floating_value auto y,
floating_value auto z) noexcept; // 2
}
Specifies that a type is a Conditional Expression.
Definition conditional.hpp:28
The concept floating_value<T> is satisfied if and only if T satisfies eve::value and the element type...
Definition value.hpp:116
The concept logical_value<T> is satisfied if and only if T satisfies eve::value and the element type ...
Definition value.hpp:132
constexpr auto ellint_rg
Computes the Carlson's elliptic integral .
Definition ellint_rg.hpp:90
EVE Main Namespace.
Definition abi.hpp:18

Parameters

Return value

  1. the value of the \(\mathbf{R}_\mathbf{G}\) Carlson elliptic integral: \(\frac1{4\pi} \int_{0}^{2\pi}\int_{0}^{\pi} \scriptstyle\sqrt{x\sin^2\theta\cos^2\phi +y\sin^2\theta\sin^2\phi +z\cos^2\theta} \scriptstyle\;\mathrm{d}\theta\;\mathrm{d}\phi\) is returned:
  2. The operation is performed conditionnaly

External references

Example

// revision 1
#include <eve/module/elliptic.hpp>
#include <iostream>
eve::wide pf{1.0f, 0.0f, 1.5f, 3.0f};
eve::wide qf{1.0f, 4.0f, 0.2f, 0.5f};
eve::wide rf{2.0f, 1.0f, 0.1f, 0.4f};
int main()
{
std::cout << "<- pf = " << pf << "\n";
std::cout << "<- qf = " << qf << "\n";
std::cout << "<- rf = " << rf << "\n";
std::cout << "-> ellint_rg(pf, qf, rf) = " << eve::ellint_rg(pf, qf, rf) << "\n";
std::cout << "-> ellint_rg[ignore_last(2)](pf, qf, rf)= " << eve::ellint_rg[eve::ignore_last(2)](pf, qf, rf) << "\n";
std::cout << "-> ellint_rg[qf != 4.0f](pf, qf, rf) = " << eve::ellint_rg[qf != 4.0f](pf, qf, rf) << "\n";
}
Conditional expression ignoring the k last lanes from a eve::simd_value.
Definition conditional.hpp:332
Wrapper for SIMD registers.
Definition wide.hpp:89