有没有办法使用 cuda 在设备上计算 tgammaf(50)?
Is there a way to calculate tgammaf(50) on a device using cuda?
我正在使用斯特林近似来计算这个,但我在存储从斯特林近似中获得的巨大答案时遇到了麻烦。有什么好方法可以在设备上存储这么大的数字吗?
CUDA 标准数学库同时支持双精度函数tgamma
和单精度函数tgammaf
。由于 Γ(50( 的量级为 1062,因此结果溢出了float
类型的可表示范围,因此tgammaf (50.0f)
返回无穷大。但是,通过使用双精度函数tgamma
并将结果存储到double
变量中,计算可以在不溢出的情况下进行,例如
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
__global__ void kernel (int a)
{
float r = tgammaf ((float)a);
double rr = tgamma ((double)a);
printf ("tgammaf(%d) = %23.16entgamma(%d) = %23.16en", a, r, a, rr);
}
int main (void)
{
kernel<<<1,1>>>(50);
cudaDeviceSynchronize();
return EXIT_SUCCESS;
}
上述程序的结果应如下所示:
tgammaf(50) = inf
tgamma(50) = 6.0828186403426752e+62
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 递归函数计算序列中的平方和(并输出过程)
- (C++)分析树以计算返回错误值的简单算术表达式
- 我的字符计数代码计算错误.为什么
- 在计算中使用二的幂有多有利可图
- 如何计算文件中的"columns"数?
- 计算排序向量的向量中唯一值的计数
- 如何使用 std::累积在 C++ 中计算总和立方体
- 使用Qt C++计算类似Git的SHA1哈希
- OpenCV C++.快速计算混淆矩阵
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- C++如何计算用户输入的数字中的偶数位数
- 如何计算数据类型的范围,例如int
- 类似枚举的计算常量
- 计算每个节点的树高,帮助我解释这个代码解决方案
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 计算缩放多边形的比例,得到给定的多边形面积
- 在C++中如何在没有pow的情况下进行基础计算
- 计算平均值,不包括上次得分
- 有没有办法使用 cuda 在设备上计算 tgammaf(50)?