朱丽叶—Cuda+OSG
- #include <cuda_runtime.h>
- #include <osg/Image>
- const int DIM = ;
- typedef struct cuComplex
- {
- float r;
- float i;
- __device__ cuComplex(float a, float b)
- :r(a)
- ,i(b)
- {
- }
- __device__ float magnitude2(void)
- {
- return r * r + i * i;
- }
- __device__ cuComplex operator * (const cuComplex & a)
- {
- return cuComplex(r * a.r - i * a.i, i * a.r + r * a.i);
- }
- __device__ cuComplex operator + (const cuComplex & a)
- {
- return cuComplex(r + a.r, i + a.i);
- }
- };
- __device__ int julia(int x, int y)
- {
- const float scale = 1.5;
- float jx = scale * (float)(DIM/ - x)/(DIM/);
- float jy = scale * (float)(DIM/ -y)/(DIM/);
- cuComplex c(-0.8, 0.156);
- cuComplex a(jx, jy);
- for (int i = ; i < ; ++i)
- {
- a = a * a + c;
- if (a.magnitude2() > )
- return ;
- }
- return ;
- }
- __global__ void kernel(unsigned char * ptr)
- {
- int x = blockIdx.x;
- int y = blockIdx.y;
- int offset = x + y * gridDim.x;
- int juliaValue = julia(x, y);
- ptr[offset * + ] = * juliaValue;
- ptr[offset * + ] = ;
- ptr[offset * + ] = ;
- ptr[offset * + ] = ;
- }
- extern "C" void SetUp(osg::Image * image)
- {
- unsigned char * dev_bitmap;
- cudaMalloc((void **)&dev_bitmap, DIM * DIM * );
- dim3 grid(DIM, DIM);
- kernel<<<grid, >>>(dev_bitmap);
- cudaMemcpy(image->data(), dev_bitmap, DIM * DIM * , cudaMemcpyDeviceToHost);
- cudaFree(dev_bitmap);
- }
- #include <osgViewer/Viewer>
- #include <osg/Texture2D>
- #include <osg/Image>
- #include <osgDB/WriteFile>
- #include <osgViewer/ViewerEventHandlers>
- #pragma comment(lib, "osgViewerd.lib")
- #pragma comment(lib, "osgDBd.lib")
- #pragma comment(lib, "osgd.lib")
- #pragma comment(lib, "osgGAd.lib")
- const int DIM = ;
- osg::ref_ptr<osg::Geode> CreateQuad()
- {
- osg::ref_ptr<osg::Geode> geode = new osg::Geode;
- osg::ref_ptr<osg::Geometry> geometry = new osg::Geometry;
- osg::ref_ptr<osg::Vec3Array> vArray = new osg::Vec3Array;
- osg::ref_ptr<osg::Vec2Array> tArray = new osg::Vec2Array;
- osg::ref_ptr<osg::Vec3Array> nArray = new osg::Vec3Array;
- vArray->push_back(osg::Vec3(-1.0, 0.0, -1.0));
- vArray->push_back(osg::Vec3(1.0, 0.0, -1.0));
- vArray->push_back(osg::Vec3(1.0, 0.0, 1.0));
- vArray->push_back(osg::Vec3(-1.0, 0.0, 1.0));
- tArray->push_back(osg::Vec2(0.0, 0.0));
- tArray->push_back(osg::Vec2(1.0, 0.0));
- tArray->push_back(osg::Vec2(1.0, 1.0));
- tArray->push_back(osg::Vec2(0.0, 1.0));
- nArray->push_back(osg::Vec3(0.0, 1.0, 0.0));
- geometry->setVertexArray(vArray.get());
- geometry->setTexCoordArray(, tArray.get());
- geometry->setNormalArray(nArray.get());
- geometry->setNormalBinding(osg::Geometry::BIND_OVERALL);
- geometry->addPrimitiveSet(new osg::DrawArrays(osg::PrimitiveSet::QUADS, , vArray->size()));
- geode->addDrawable(geometry.get());
- return geode.get();
- }
- osg::ref_ptr<osg::StateSet> CreateStateSet(osg::Image * image)
- {
- osg::ref_ptr<osg::StateSet> stateSet = new osg::StateSet;
- osg::ref_ptr<osg::Texture2D> texture = new osg::Texture2D();
- texture->setImage(image);
- stateSet->setTextureAttributeAndModes(, texture.get(), osg::StateAttribute::ON);
- return stateSet.get();
- }
- extern "C" void SetUp(osg::Image * image);
- int main()
- {
- osg::ref_ptr<osgViewer::Viewer> viewer = new osgViewer::Viewer;
- osg::ref_ptr<osg::Image> image = new osg::Image;
- image->allocateImage(DIM, DIM, , GL_RGBA, GL_UNSIGNED_BYTE);
- SetUp(image.get());
- osg::ref_ptr<osg::StateSet> stateSet = CreateStateSet(image.get());
- osg::ref_ptr<osg::Geode> quad = CreateQuad();
- quad->setStateSet(stateSet.get());
- viewer->setSceneData(quad.get());
- viewer->getCamera()->getOrCreateStateSet()->setMode(GL_LIGHTING, osg::StateAttribute::OFF);
- viewer->addEventHandler(new osgViewer::StatsHandler);
- viewer->setUpViewInWindow(, , , );
- viewer->run();
- return ;
- }
朱丽叶—Cuda+OSG的更多相关文章
- osg + cuda
#include <osg/Notify> #include <osgViewer/Viewer> #include <osgCompute/Memory> #in ...
- CUDA[2] Hello,World
Section 0:Hello,World 这次我们亲自尝试一下如何用粗(CU)大(DA)写程序 CUDA最新版本是7.5,然而即使是最新版本也不兼容VS2015 ...推荐使用VS2012 进入VS ...
- CUDA[1] Introductory
Section 0 :Induction of CUDA CUDA是啥?CUDA®: A General-Purpose Parallel Computing Platform and Program ...
- Couldn't open CUDA library cublas64_80.dll etc. tensorflow-gpu on windows
I c:\tf_jenkins\home\workspace\release-win\device\gpu\os\windows\tensorflow\stream_executor\dso_load ...
- OSG计时器与时间戳
static osg::Timer* sendMsgTimer = new osg::Timer; if (sendMsgTimer->time_m()>100)//100ms {// d ...
- ubuntu 16.04 + N驱动安装 +CUDA+Qt5 + opencv
Nvidia driver installation(after download XX.run installation file) 1. ctrl+Alt+F1 //go to virtual ...
- OSG消息机制之消息分析
OSG消息接收在头文件有各种事件的相关参数
- OSG消息机制之事件处理概述
OSG的消息机制包括好多个头文件预定义及多个类. 首先,消息接收相关的类当属osgGA::GUIEventHandler和osgGA::GUIEventAdapter这两个类了.前者处理OSG程序与用 ...
- OSG 3D场景渲染编程概述
OSG是Open Scene Graphic的缩写,是基于C++平台的使用OpenGL技术的开源3D场景开发. vs环境安装或者是在Ubuntu中环境的安装网上教程很多,都是大同小异的,认真操作容易成 ...
随机推荐
- solr最佳实践
管理页面 页面地址:http://{ip}:{port}/solr/#/ 管理页面的data-import页可以手动重建索引,configuration指定了数据源,重建索引也可以通过http请求触发 ...
- Ansible安装配置
Ansible工具的安装与配置 Ansible基于SSH,不需要在远程端安装任何软件,只需要在管理端安装ansible及其组件即可. Ansible使用前提是已配置ssh密钥免登陆. 一.安装组件: ...
- PopupWindow 的使用
//contentView : 气泡显示的内容 //width ,height : 宽高 PopupWindow popupWindow = new PopupWindow(contentView, ...
- Minicom配置及使用详解
因为现在电脑基本不配备串行接口,所以,usb转串口成为硬件调试时的必然选择.目前知道的,PL2303的驱动是有的,在dev下的名称是ttyUSB*. minicom,tkterm都是linux下应用比 ...
- [MFC] 编辑框 EditControl 输入数字范围限制
在MFC中,项目需要对编辑框EditControl的数字输入范围进行限制,主要有以下实现方式,各有优缺点,个人推荐第三种. 第一种:添加变量 为编辑框添加int.float变量的时候,可以填写最大值与 ...
- 闹心的python编码
说起编码,真是十分忧伤.每次听课都是绕了半天把自己搞糊涂.今天特意来整理一下思路. What 编码!? 基本概念很简单.首先,我们从一段信息即消息说起,消息以人类可以理解.易懂的表示存在.我打算将这种 ...
- CSS3之响应式布局
在没有C3的时候,响应式布局是通过js来实现的. 开始研究响应式web设计,CSS3 Media Queries是入门. Media Queries,其作用就是允许添加表达式用以确定媒体的环境情况,以 ...
- HDU 5869 Different GCD Subarray Query
离线操作,树状数组,$RMQ$. 这个题的本质和$HDU$ $3333$是一样的,$HDU$ $3333$要求计算区间内不同的数字有几个. 这题稍微变了一下,相当于原来扫描到$i$的之后是更新$a[i ...
- CodeForces 706E Working routine
十字链表. 开一个十字链表,矩阵中每一格作为一个节点,记录五个量: $s[i].L$:$i$节点左边的节点编号 $s[i].R$:$i$节点右边的节点编号 $s[i].U$:$i$节点上面的节点编号 ...
- liunx环境C、C++代码编译链接中间代码主要流程
一个比较小的问题,可以直接看帖子: http://blog.csdn.net/gengyichao/article/details/6544266