草庐IT

gpu-constant-memory

全部标签

c++ - Direct3D11(C++) : Updating Texture coordinates in constant buffer?

我正在尝试使用Direct3D制作一个相当基本的2D引擎。我制作了一个LoadImage()函数,它将图像的所有相当静态的行为存储在一个对象中。(着色器、顶点缓冲区、采样器等)我计划在常量缓冲区中使用矩阵定位顶点。但是,我还想有一个DrawImage()函数,它有一个参数来告诉纹理的哪一部分应该被绘制(剪裁),所以我必须更新纹理坐标。由于顶点缓冲区已经预定义,我想知道是否有一种方法可以通过发送到顶点着色器的常量缓冲区来更新纹理坐标?我希望我的问题足够清楚,如果您有任何疑问,请查看下面的代码。boolGameManager::GMLoadImage(Image*pImage,constc

c++ - 是否有与 Thrust(GPU 的并行 STL)类似的库,但用于 GPGPU AMD Radeon?

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion是否有类似Thrust的库(用于GPU的并行STL,可以使用OpenMP/TBB,C++CUDA),但用于GPGPUAMDRadeon(例如使用OpenCL而不是使用CUDA)?所需的标准STL算法(排序、合并、删除/复制、In/Exc

解决方案:2024年Pytorch(GPU版本)+ torchvision手动安装教程[万能安装方法] win64、linux、macos、arm、aarch64均适用

目录一、Pytorch手动安装1.1、前提准备1.2、创建虚拟环境1.3、搜索Pytorch包1.4、选择下载符合配置的Pytorch包1.4、安装离线包二、torchvision手动安装2.1、查找对应的版本2.2、安装torchvision对于深度学习新手和入门不久的同学来说,在安装PyTorch和torchvision时经常会遇到各种各样的问题。这些问题可能包括但不限于:PyTorch与CUDA对不上:当前PyTorch版本要求的CUDA版本与系统中已安装的CUDA版本不匹配时。PyTorch和Python版本对不上:所选择的PyTorch版本与系统中已安装的Python版本不兼容。安装

c++ - 在 C++ 中解决稀疏线性系统的最佳方法 - GPU 可能吗?

我目前正在做一个我们需要解决的项目|Ax-b|^2。在这种情况下,A是一个非常稀疏的矩阵,A'A每行最多有5个非零元素。我们正在处理图像,A'A的维度是NxN,其中N是像素数。在本例中N=76800。我们计划转到RGB,然后维度将是3Nx3N。在matlab中求解(A'A)\(A'b)大约需要0.15秒,使用double。我现在已经对Eigens稀疏求解器进行了一些试验。我试过:SimplicialLLTSimplicialLDLTSparseQRConjugateGradient和一些不同的顺序。目前为止最好的是SimplicialLDLT使用AMDOrdering大约需要0.35-

c++ - std::atomic::compare_exchange 与两个 memory_order 参数一起使用的真实示例

您能否给出一个真实世界的例子,其中出于某种原因使用了std::atomic::compare_exchange的两个memory_order参数版本(因此一个memory_order参数版本是不够的)? 最佳答案 在许多情况下,compare_exchange上的第二个内存排序参数设置为memory_order_relaxed。在这些情况下,省略它通常并没有错,只是可能效率较低。这里是一个简单的无锁列表/堆栈示例,它需要compare_exchange_weak上的第二个不同的排序参数,以便避免数据竞争。调用push可以并发执行,但

深度学习环境配置超详细教程【Anaconda+Pycharm+PyTorch(GPU版)+CUDA+cuDNN】

 在宇宙的浩瀚中,我们是微不足道的,但我们的思维却可以触及无尽的边界。 目录关于Anaconda:关于Pycharm:关于Pytorch:关于CUDA:关于Cudnn:一、🌎前言:二、🔖Anaconda安装三、🔖Pycharm安装四、🔖CUDA安装1、查看NVDIA显卡型号2、判断自己应该下载什么版本的cuda3、安装CUDA11.2 CUDAtoolkitDownload五、🔖Cudnn安装1、cuDNN下载2、Cudnn配置3、添加环境变量 六、🔖Pytorch安装1、pytorch安装(gpu版本和cpu版本的安装) 2、验证配置是否成功🥇Summary获取源码?私信?关注?点赞?收藏?

c++ - 如何在没有警告的情况下在 gnu++11 标准中写入 "nested if...else statement for constants"?

当我使用嵌套的if....else语句时if(std::is_same::value){//dosomething}elseif(std::is_same::value){//dosomethingelse}...else{//printerror}我收到QACPP静态代码分析器的编译器警告qacpp-4.2.1-4090,其中包含消息“此‘if’语句中的条件是常量。”我该如何修复gnu++11标准中的编译器警告?注意:我不是C++专家,所以如果这个问题听起来很业余,请原谅。 最佳答案 对于T的特定实例,if条件是常量。换句话说st

c++ - C/C++ : Bitwise operators on dynamically allocated memory

在C/C++中,是否有一种简单的方法可以将按位运算符(特别是左移/右移)应用于动态分配的内存?例如,假设我这样做了:unsignedchar*bytes=newunsignedchar[3];bytes[0]=1;bytes[1]=1;bytes[2]=1;我想要一种方法来做到这一点:bytes>>=2;(那么“字节”将具有以下值):bytes[0]==0bytes[1]==64bytes[2]==64为什么值应该是这样的:分配后,字节如下所示:[00000001][00000001][00000001]但我希望将字节视为一长串位,如下所示:[000000010000000100000

c++ - 在 DirectX 10/11 中从 GPU 取回变换后的顶点

我正在开发的图形引擎出现了一个主要瓶颈,即顶点上的矩阵变换(几乎没有静态顶点)。到目前为止,我一直在用CPU转换顶点并每帧更新顶点缓冲区(数据复制本身是一个小瓶颈,但到目前为止是可以管理的)。所以我在想,如果我可以将网格缓冲区保留在GPU中,我可以在那里变换顶点并将变换后的顶点集返回到主内存以进行其他处理(后续处理需要更多的内部连接比GPU着色器允许)。这可能会消除当前代码中的瓶颈。关于如何做到这一点的任何提示?谢谢。 最佳答案 查看DX11中的流输出阶段:http://msdn.microsoft.com/en-us/librar

c++ - cuda在gpu和主机之间统一内存

我正在编写一个基于cuda的程序,需要定期将一组项目从GPU传输到主机内存。为了保持进程异步,我希望使用cuda的UMA在主机内存中有一个内存缓冲区和标志(这样GPU和CPU都可以访问它)。GPU将确保标志已清除,将其项目添加到缓冲区,然后设置标志。CPU等待设置标志,从缓冲区中复制内容,然后清除标志。据我所知,这不会产生任何竞争条件,因为它会强制GPU和CPU轮流,始终读取和写入彼此相对的标志。到目前为止,我还没有能够让它工作,因为似乎确实存在某种竞争条件。我想出了一个具有类似问题的更简单的示例:#include__global__voiduva_counting_test(intn