Files
2025-02-Numerical/lib/nr/cpp/recipes/ellpi.cpp
2025-09-12 18:55:25 +09:00

15 lines
259 B
C++

#include <cmath>
#include "nr.h"
using namespace std;
DP NR::ellpi(const DP phi, const DP en, const DP ak)
{
DP cc,enss,q,s;
s=sin(phi);
enss=en*s*s;
cc=SQR(cos(phi));
q=(1.0-s*ak)*(1.0+s*ak);
return s*(rf(cc,q,1.0)-enss*rj(cc,q,1.0,1.0+enss)/3.0);
}