What is the exact equivalent of “Matlab besselk(x,y,1)” in c++?

依然范特西╮ 提交于 2019-12-06 09:49:14

问题


I have tried boost::math::cyl_bessel_k(x,y) * exp(y). In most cases, this is equal to Matlab's scaled besselk(x,y,1). But in some cases (e.g., x=1, y=2000) when both besselk(x,y)=0 and boost::math::cyl_bessel_k(x,y)=0, Matlab's scaled version besselk(x,y,1) gives me different values varies around 10^-3. But boost::math::cyl_bessel_k(x,y) * exp(y) returns -nan. I'd like to find an equivalent statement for Matlab's besselk(x,y,1). How can I handle this?


回答1:


I'm not seeing anything in Boost that does what you need (though you might be able to implement it yourself by using lower-level functions). As you've found out, the scaled Bessel functions are not computed simply by multiplying exp(z). The GSL appears to have incorporated this functionality, e.g., gsl_sf_bessel_Knu_scaled. For an "exact equivalent," you might look at the paper and code by Amos, e.g., CBESK. Both Matlab and Octave appear to use this implementation. However, the code is written in Fortran, so you'd need to translate it or put a wrapper around it (this project appears to have done that so it might be useful – there are others out there too).

You may also be able to use Matlab's Coder and codegen to output something as well.



来源:https://stackoverflow.com/questions/24615876/what-is-the-exact-equivalent-of-matlab-besselkx-y-1-in-c

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!