在三维几何建模中,计算两点间的测地线距离是一个重要的任务,特别是在计算机图形学、地理信息系统和物理学等领域。
测地线是曲面上两点之间最短的路径,它相当于平面上两点间直线的自然推广。
在地球表面,我们通常所说的“大圆航线”就是地球表面两点之间的测地线。
这个资源提供了计算三维模型上测地线距离的多种实现方法,作者DanilKirsanov显然是在探讨这个问题并提供了解决方案。
以下是根据提供的文件名解析出的可能的算法和概念:1.**GeodesicAlgorithm**:-`geodesic_algorithm_exact.h`:这个文件可能包含了一个精确计算测地线的算法。
"Exact"可能指的是算法考虑了模型的精确几何信息,不进行近似计算。
-`geodesic_algorithm_dijkstra_alternative.h`:Dijkstra算法通常用于寻找图中最短路径,这里的"Alternative"可能表示这是Dijkstra算法的一种变体,专门用于计算三维模型上的测地线。
-`geodesic_algorithm_subdivision.h`:分形细分算法可能被用来细化模型以提高计算精度,或者是在细分的表面上进行测地线的追踪。
2.**MeshDataStructure**:-`geodesic_mesh.h`和`geodesic_mesh_elements.h`:这些文件可能定义了用于存储和操作三维模型的网格数据结构。
网格是由顶点、边和面组成的,这些元素有助于在曲面上定位和计算路径。
3.**API**:-`geodesic_matlab_api.cpp`:提供了与MATLAB交互的接口,这使得用户可以在MATLAB环境中利用这些算法,方便进行数值计算和可视化。
4.**Examples**:-`example1.cpp`和`example0.cpp`:这些是示例代码,用于演示如何使用上述算法。
它们可能包含了如何加载模型,初始化算法,以及如何查询和打印测地线距离的步骤。
5.**HeaderFiles**:-其他头文件如`geodesic_algorithm_exact_elements.h`等,可能包含了算法所需的具体数据结构和辅助函数定义。
通过这些文件,我们可以了解到作者可能实现了一套完整的工具集,用于处理从网格数据读取、测地线计算到结果输出的全过程。
这些工具对进行三维模型分析,尤其是在需要考虑曲面最短路径的问题时,具有很高的实用价值。
例如,在游戏开发中计算角色移动路径,或在虚拟现实应用中计算视角变换的距离等。
理解并运用这些算法,将有助于提升三维空间中的导航和路径规划的精确性。
2025/7/2 13:25:30 45KB 测地线距离 三维模型
1
根据三个参数数组的原始数据,进行样条算法插值,得出三维曲面.可根据此实例完成自己的插值
2025/6/30 4:32:33 3KB 三维三次样条
1

在MATLAB中,计算三维散乱点云的曲率是一项重要的几何分析任务,尤其是在计算机图形学、图像处理和机器学习等领域。
曲率是衡量表面局部弯曲程度的一个度量,可以帮助我们理解点云数据的形状特征。
曲率的计算通常涉及主曲率、高斯曲率和平均曲率三个关键概念。
主曲率是描述曲面在某一点沿两个正交方向弯曲的程度,通常记为K1和K2,其中K1是最大曲率,K2是最小曲率。
主曲率可以提供关于曲线形状的局部信息,例如,当K1=K2时,表明该点处的曲面是球形;
当K1=0或K2=0时,可能对应于平面区域。
高斯曲率(Gaussian Curvature)是主曲率的乘积,记为K = K1 * K2。
高斯曲率综合了主曲率的信息,能反映曲面上任意点的全局弯曲特性。
如果高斯曲率为正,表明该点在凸形曲面上;
若为负,则在凹形曲面上;
为零时,表示该点位于平面上。
平均曲率(Mean Curvature)是主曲率的算术平均值,H = (K1 + K2) / 2。
它提供了曲面弯曲的平均程度,对于理解物体表面的整体形状变化非常有用。
例如,平均曲率为零的点可能表示曲面的边缘或者尖锐转折。
在MATLAB中,计算这些曲率通常需要以下步骤:1. **数据预处理**:你需要加载散乱点云数据。
这可以通过读取txt文件(如www.pudn.com.txt)或使用特定的数据集来完成。
数据通常包含每个点的XYZ坐标。
2. **邻域搜索**:确定每个点的邻域,通常采用球形邻域或基于距离的邻域。
邻域的选择直接影响曲率计算的精度和稳定性。
3. **拟合曲面**:使用最近邻插值、移动最小二乘法(Moving Least Squares, MLS)或其他方法,将点云数据拟合成一个连续曲面。
在本例中,"demo_MLS"可能是一个实现MLS算法的MATLAB脚本。
4. **计算几何属性**:在拟合的曲面上,计算每个点的曲率。
这涉及到计算曲面的曲率矩阵、主轴和主曲率。
同时,高斯曲率和平均曲率可以通过已知的主曲率直接计算得出。
5. **结果可视化**:你可以使用MATLAB的图形工具,如`scatter3`或`patch`函数,将曲率信息以颜色编码的方式叠加到原始点云上,以直观展示曲率分布。
在实际应用中,曲率计算对于识别物体特征、形状分析和目标检测等任务具有重要价值。
例如,在机器人导航、医学图像分析和3D重建等领域,理解点云数据的几何特性至关重要。
总结来说,MATLAB中的算法通过一系列数学操作和数据处理,可以有效地计算三维散乱点云的主曲率、高斯曲率和平均曲率,从而揭示其内在的几何结构和形状特征。
正确理解和运用这些曲率概念,有助于在相关领域进行更深入的研究和开发。
2025/6/18 16:18:34 130KB
1
第2章图形基础342.1笔和画刷342.1.1pen类342.1.2brush类352.2基本图形形状372.2.1点372.2.2直线和曲线372.2.3矩形、椭圆形和圆弧形402.2.4多边形422.3颜色442.4双倍缓存66第3章坐标系统和颜色变换693.1坐标系统693.2颜色变换77第二部分二维图形的基本算法第4章二维矩阵和变换824.1矩阵基础和变换824.2齐次坐标824.2.1齐次坐标中的缩放834.2.2齐次坐标中的平移834.2.3齐次坐标中的旋转844.2.4变换组合854.2.5c#中矩阵的定义864.2.6c#中的矩阵操作874.2.7c#中基本的矩阵变换894.3c#中图形对象的变换93基本变换934.4c#中的多对象变换1014.5文字变换105第5章二维线形图形1095.1序列化和反序列化及二维图形的基本框架1095.1.1c#序列化和反序列化1105.1.2二维图形的基本框架1135.2二维图形2485.2.1简单实例2485.2.2图例2785.2.3符号2895.2.4对数比例3025.2.5图形的修饰3085.3阶梯状图3165.4多y轴图318第6章特殊二维图形3276.1创建柱状图3276.1.1水平柱状图3276.1.2垂直柱状图3436.1.3图形充填柱状图3446.1.4重叠柱状图3466.2饼状图3486.3误差图3616.4股票图3676.4.1最高最低收盘价股票图3686.4.2最高最低开盘收盘价股票图3696.4.3最高最低价股票图3776.4.4k线图(阴阳烛图)3806.5面积图3896.6综合图390第三部分三维图形的相关知识及三维图形的实现第7章三维矩阵和变换3967.1三维数学概念3967.1.1操作三维对象3967.1.2数学结构3977.2三维中的基本矩阵和变换4027.2.1c#中三维点和矩阵的操作4037.2.2三维的基本变换4057.3方位角和仰角4347.4三维图形中的特殊坐标系统4397.4.1球坐标系统4407.4.2圆柱坐标系统4437.5特殊坐标中的实际应用4477.5.1球坐标示例4477.5.2双缓存463第8章三维图形4738.1三维图形基础4738.1.1point3和matrix3类4738.1.2chartstyle类4768.1.3坐标轴4968.1.4网格线4968.1.5标签4978.2三维折线图5038.3三维图形函数包5088.3.1chartstyle2d类5098.3.2point4类5158.3.3dataseries类5168.3.4chartfunctions类5218.3.5drawchart类5268.4曲面图的实现5418.4.1网格图5418.4.2幕布网格图5488.4.3瀑布网格图5518.4.4曲面图5538.5x-y平面色彩图5598.6轮廓图5648.6.1轮廓图的算法5648.6.2轮廓图的实现5648.7组合图5698.7.1三维体系中的x-y色彩图5708.7.2三维体系中的轮廓图5718.7.3网格-轮廓组合图5758.7.4曲面-轮廓组合图5768.7.5填充曲面-轮廓组合图5768.8三维柱状图577实现柱状图5778.9切片图591切片图的实现591第四部分c#中应用微软office的excel实现各种二维及三维图形第9章应用程序中的excel图表6009.1excel和c#间的互操作6009.2c#应用程序中的excel图表示例6029.2.1excel图表对象模型6029.2.2创建独立的excel图表6049.2.3创建嵌入式excel图表
2025/6/18 10:39:41 22.07MB C# 2D 3D 图形
1
matlab绘制B样条曲面的代码,包括均匀、准均匀、分段Bezier以及非均匀四种类型。
main.m是入口函数,输入控制网格的顶点坐标,曲面的类型以及次数。
2025/6/11 21:03:04 4KB B样条曲面 matlab
1
作为计算机图形学课程的大作业,具有基本的功能:绘制几种基本图元、绘制几种曲线曲面、分形以及真实感图形。
2025/6/9 12:14:55 5.66MB 计算机图形学 图形图像 图形学
1
视点变换,旋转,加速减速,星空背景太阳,光晕各行星纹理#include#include#include#include#include#include#include#pragmacomment(lib,"winmm.lib")#pragmacomment(lib,"wininet")//纹理图像结构typedefstruct{intimgWidth;//纹理宽度intimgHeight;//纹理高度unsignedcharbyteCount;//每个象素对应的字节数,3:24位图,4:带alpha通道的24位图unsignedchar*data;//纹理数据}TEXTUREIMAGE;//BMP文件头#pragmapack(2)typedefstruct{unsignedshortbfType;//文件类型unsignedlongbfSize;//文件大小unsignedshortbfReserved1;//保留位unsignedshortbfReserved2;//保留位unsignedlongbfOffBits;//数据偏移位置}BMPFILEHEADER;#pragmapack()//BMP信息头typedefstruct{unsignedlongbiSize;//此结构大小longbiWidth;//图像宽度longbiHeight;//图像高度unsignedshortbiPlanes;//调色板数量unsignedshortbiBitCount;//每个象素对应的位数,24:24位图,32:带alpha通道的24位图unsignedlongbiCompression;//压缩unsignedlongbiSizeImage;//图像大小longbiXPelsPerMeter;//横向分辨率longbiYPelsPerMeter;//纵向分辨率unsignedlongbiClrUsed;//颜色使用数unsignedlongbiClrImportant;//重要颜色数}BMPINFOHEADER;//定义窗口的标题、宽度、高度、全屏布尔变量#defineWIN_TITLE"模拟太阳系各星球的转动"constintWIN_WIDTH=800;constintWIN_HEIGHT=600;BOOLisFullScreen=FALSE;//初始不为全屏#defineDEG_TO_RAD0.017453floatangle=0.0;staticGLdoubleviewer[]={0,0,0,0,0};//初始化视角GLUquadricObj*quadric;//建立二次曲面对象GLfloatangle_Z;//星空旋转角度boolg_bOrbitOn=true;//控制转动暂停floatg_fSpeedmodifier=1.0f;//时间控制floatg_fElpasedTime;doubleg_dCurrentTime;doubleg_dLastTime;GLfloatLightAmbient[]={1.0f,1.0f,1.0f,0.0f};//环境光参数GLfloatLightDiffuse[]={1.0f,1.0f,1.0f,0.0f};//漫射光参数GLfloatLightPosition[]={0.0f,0.0f,0.0f,1.0f};//光源的位置//纹理图象TEXTUREIMAGEskyImg;TEXTUREIMAGEsunImg;TEXTUREIMAGErayImg;TEXTUREIMAGEmercuImg;TEXTUREIMAGEvenusImg;TEXTUREIMAGEearthImg;TEXTUREIMAGEmarsImg;TEXTUREIMAGEjupiterImg;TEXTUREIMAGEsaturnImg;TEXTUREIMAGEuranusImg;TEXTUREIMAGEneptuneImg;TEXTUREIMAGEmoonImg;GLuinttexture[12];//纹理数组//星球速度定义staticfloatfSunSpin=0.0f;//太阳自转速度staticfloatfMercuSpin=0.0f;//水星自转速度staticfloatfMercuOrbit=0.0f;//水星公转速度staticfloatfVenusSpin=0.0f;//金星自转速度staticfloatfVenusOrbit=0.0f;//金星公转速度staticfloatfEarthSpin=0.0f;//地球自转速度staticfloatfEarthOrbit=0.0f;//地球公转速度staticfloatfMarsSpin=0.0f;//火星自转速度staticfloatfMarsOrbit=0.0f;//火星公转速度staticfloatfJupiterSpin=0.0f;//木星自转速度staticfloatfJupiterOrbit=0.0f;//木星公转速度staticfloatfSaturnSpin=0.0f;//土星自转速度staticfloatfSaturnOrbit=0.0f;//土星公转速度staticfloatfUranusSpin=0.0f;//天王星自转速度staticfloatfUranusOrbit=0.0f;//天王星公转速度staticfloatfNeptuneSpin=0.0f;//海王星自转速度staticfloatfNeptuneOrbit=0.0f;//海王星公转速度staticfloatfMoonSpin=0.0f;//月亮自转速度staticfloatfMoonOrbit=0.0f;//月亮公转速度voidMakeTexture(TEXTUREIMAGEtextureImg,GLuint*texName)//转换为纹理{glPixelStorei(GL_UNPACK_ALIGNMENT,1);//对齐像素字节函数glGenTextures(1,texName);//第一个参数指定表明获取多少个连续的纹理标识符glBindTexture(GL_TEXTURE_2D,*texName);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_WRAP_S,GL_REPEAT);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_WRAP_T,GL_REPEAT);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);glTexImage2D(GL_TEXTURE_2D,0,GL_RGB,textureImg.imgWidth,textureImg.imgHeight,0,GL_RGB,GL_UNSIGNED_BYTE,textureImg.data);}//初始化OpenGLvoidInitGL(void){glClearColor(0.0f,0.0f,0.0f,0.5f);//设置黑色背景glClearDepth(2.0f);//设置深度缓存glEnable(GL_DEPTH_TEST);//启动深度测试glDepthFunc(GL_LEQUAL);//深度小或相等的时候渲染glShadeModel(GL_SMOOTH);//启动阴影平滑glEnable(GL_CULL_FACE);//开启剔除操作效果glHint(GL_PERSPECTIVE_CORRECTION_HINT,GL_NICEST);//使用质量最好的模式指定颜色和纹理坐标的插值质量glLightfv(GL_LIGHT1,GL_AMBIENT,LightAmbient);//设置环境光glLightfv(GL_LIGHT1,GL_DIFFUSE,LightDiffuse);//设置漫反射光glEnable(GL_LIGHTING);//打开光照glEnable(GL_LIGHT1);//打开光源1//载入纹理glEnable(GL_TEXTURE_2D);//开启2D纹理映射MakeTexture(skyImg,&texture;[0]);MakeTexture(sunImg,&texture;[1]);MakeTexture(rayImg,&texture;[2]);MakeTexture(mercuImg,&texture;[3]);MakeTexture(venusImg,&texture;[4]);MakeTexture(earthImg,&texture;[5]);MakeTexture(marsImg,&texture;[6]);MakeTexture(jupiterImg,&texture;[7]);MakeTexture(saturnImg,&texture;[8]);MakeTexture(uranusImg,&texture;[9]);MakeTexture(neptuneImg,&texture;[10]);MakeTexture(moonImg,&texture;[11]);quadric=gluNewQuadric();//建立一个曲面对象指针gluQuadricTexture(quadric,GLU_TRUE);//建立纹理坐标gluQuadricDrawStyle(quadric,GLU_FILL);//面填充}voidDisplay(void){glLoadIdentity();//设置观察点的位置和观察的方向gluLookAt(viewer[0],viewer[1],viewer[2],viewer[3],viewer[4],-5,0,1,0);//摄像机x,摄像机y,摄像机z,目标点x,目标点y,目标点z,摄像机顶朝向x,摄像机顶朝向y,摄像机顶朝向z//获得系统时间使太阳系有动态效果g_dCurrentTime=timeGetTime();g_fElpasedTime=(float)((g_dCurrentTime-g_dLastTime)*0.0005);g_dLastTime=g_dCurrentTime;glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);glMatrixMode(GL_MODELVIEW);//指定GL_MODELVIEW是下一个矩阵操作的目标glTranslatef(0.0f,0.0f,-5.0f);//将坐标系移入屏幕5.0fglRotatef(10,1.0f,0.0f,0.0f);//将坐标系绕x轴旋转10度glEnable(GL_LIGHT0);//打开光源0/**********************************绘制背景星空********************************************/glPushMatrix();//当前模型矩阵入栈glTranslatef(-10.0f,3.0f,0.0f);glRotatef(angle_Z,0.0f,0.0f,1.0f);glEnable(GL_TEXTURE_2D);glBindTexture(GL_TEXTURE_2D,texture[0]);//星空纹理glBegin(GL_QUADS);glNormal3f(0.0f,0.0f,1.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(50.0f,50.0f,-50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(-50.0f,50.0f,-50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(0.0f,0.0f,-1.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(-50.0f,-50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(50.0f,-50.0f,50.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(50.0f,50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(-50.0f,50.0f,50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(0.0f,1.0f,0.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(50.0f,-50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(50.0f,-50.0f,-50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(-50.0f,-50.0f,50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(0.0f,-1.0f,0.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(-50.0f,50.0f,-50.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(50.0f,50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(50.0f,50.0f,-50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(-50.0f,50.0f,50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(1.0f,0.0f,0.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(-50.0f,50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(-50.0f,-50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(-50.0f,50.0f,-50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(-1.0f,0.0f,0.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(50.0f,-50.0f,-50.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(50.0f,50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(50.0f,-50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(50.0f,50.0f,-50.0f);glEnd();glPopMatrix();//当前模型矩阵出栈/**********************************绘制太阳************************************************/glBindTexture(GL_TEXTURE_2D,texture[2]);//光晕纹理glEnable(GL_BLEND);//开启混合glDisable(GL_DEPTH_TEST);//关闭深度测试//绘制太阳光晕glDisable(GL_LIGHTING);//关闭光照glBlendFunc(GL_SRC_ALPHA,GL_ONE);//半透明混合函数glColor4f(1.0f,0.5f,0.0f,0.5f);//设置RGBA值glBegin(GL_QUADS);glNormal3f(0.0f,0.0f,1.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-1.0f,-1.0f,0.0f);glTexCoord2f(1.0f,0.0f);glVertex3f(1.0f,-1.0f,0.0f);glTexCoord2f(1.0f,1.0f);glVertex3f(1.0f,1.0f,0.0f);glTexCoord2f(0.0f,1.0f);glVertex3f(-1.0f,1.0f,0.0f);glEnd();glDisable(GL_BLEND);//关闭混合glEnable(GL_DEPTH_TEST);glEnable(GL_LIGHTING);//开启光照glLightfv(GL_LIGHT1,GL_POSITION,LightPosition);//设置光源1位置glBindTexture(GL_TEXTURE_2D,texture[1]);//太阳纹理//将坐标系绕Y轴旋转fSunSpin角度,控制太阳自转glRotatef(fSunSpin,0.0,1.0,0.0);gluSphere(quadric,0.3f,32,32);//绘制太阳球体/**********************************绘制水星************************************************/glDisable(GL_LIGHT0);glEnable(GL_TEXTURE_2D);//开启纹理glPushMatrix();//当前模型视图矩阵入栈//将坐标系绕Y轴旋转fMercuOrbit角度,控制水星公转glRotatef(fMercuOrbit,0.0f,1.0f,0.0f);glRotatef(-90.0f,1.0f,0.0f,0.0f);//将坐标系绕X轴旋转-90度glTranslatef(0.5f,0.0f,0.0f);//将坐标系右移0.5fglBindTexture(GL_TEXTURE_2D,texture[3]);//水星纹理//将坐标系绕Z轴旋转fMercuSpin角度控制水星自转glRotatef(fMercuSpin,0.0f,0.0f,1.0f);gluSphere(quadric,0.04f,32,32);//水星球体glPopMatrix();//当前模型视图矩阵出栈//绘制轨道glBegin(GL_LINE_LOOP);for(angle=0;angle=-6.0)viewer[0]-=0.5;break;case'u':case'U':if(viewer[1]=-6.0)viewer[1]-=0.1;break;case'+':case'='://加速,减速,暂停g_fSpeedmodifier+=1.0f;glutPostRedisplay();break;case'':g_bOrbitOn=!g_bOrbitOn;glutPostRedisplay();break;case'-'://按'-'减小运行速度g_fSpeedmodifier-=1.0f;glutPostRedisplay();break;caseVK_ESCAPE://按ESC键时退出exit(0);break;default:break;}}voidspecial_keys(ints_keys,intx,inty){switch(s_keys){caseGLUT_KEY_F1://按F1键时切换窗口/全屏模式if(isFullScreen){glutReshapeWindow(WIN_WIDTH,WIN_HEIGHT);glutPositionWindow(30,30);isFullScreen=FALSE;}else{glutFullScreen();isFullScreen=TRUE;}break;caseGLUT_KEY_RIGHT://视角上下左右旋转if(viewer[3]=-3.0)viewer[3]-=0.1;break;caseGLUT_KEY_UP:if(viewer[4]=-4.5)viewer[4]-=0.1;break;default:break;}}voidmouse(intbtn,intstate,intx,inty)//远近视角{if(btn==GLUT_RIGHT_BUTTON&&state==GLUT_DOWN)viewer[2]+=0.3;if(btn==GLUT_LEFT_BUTTON&&state==GLUT_DOWN&&viewer;[2]>=-3.9)viewer[2]-=0.3;}voidLoadBmp(char*filename,TEXTUREIMAGE*textureImg)//载入图片{inti,j;FILE*file;BMPFILEHEADERbmpFile;BMPINFOHEADERbmpInfo;intpixel_size;//初始化纹理数据textureImg->imgWidth=0;textureImg->imgHeight=0;if(textureImg->data!=NULL){delete[]textureImg->data;}//打开文件file=fopen(filename,"rb");if(file==NULL){return;}//获取文件头rewind(file);fread(&bmpFile;,sizeof(BMPFILEHEADER),1,file);fread(&bmpInfo;,sizeof(BMPINFOHEADER),1,file);//验证文件类型if(bmpFile.bfType!=0x4D42){return;}//获取图像色彩数pixel_size=bmpInfo.biBitCount>>3;//读取文件数据textureImg->data=newunsignedchar[bmpInfo.biWidth*bmpInfo.biHeight*pixel_size];for(i=0;idata+(i*bmpInfo.biWidth+j)*pixel_size+2,sizeof(unsignedchar),1,file);//绿色分量fread(textureImg->data+(i*bmpInfo.biWidth+j)*pixel_size+1,sizeof(unsignedchar),1,file);//蓝色分量fread(textureImg->data+(i*bmpInfo.biWidth+j)*pixel_size+0,sizeof(unsignedchar),1,file);//Alpha分量if(pixel_size==4){fread(textureImg->data+(i*bmpInfo.biWidth+j)*pixel_size+3,sizeof(unsignedchar),1,file);}}}//记录图像相关参数textureImg->imgWidth=bmpInfo.biWidth;textureImg->imgHeight=bmpInfo.biHeight;textureImg->byteCount=pixel_size;fclose(file);}//程序主函数voidmain(intargc,char**argv){//读图片LoadBmp("Picture//Sky.bmp",&skyImg;);LoadBmp("Picture//Sun.bmp",&sunImg;);LoadBmp("Picture//Ray.bmp",&rayImg;);LoadBmp("Picture//Mercu.bmp",&mercuImg;);LoadBmp("Picture//Venus.bmp",&venusImg;);//金星LoadBmp("Picture//Earth.bmp",&earthImg;);LoadBmp("Picture//Mars.bmp",&marsImg;);//火星LoadBmp("Picture//Jupiter.bmp",&jupiterImg;);//木星LoadBmp("Picture//Saturn.bmp",&saturnImg;);//土星LoadBmp("Picture//Uranus.bmp",&uranusImg;);//天王星LoadBmp("Picture//Neptune.bmp",&neptuneImg;);//海王星LoadBmp("Picture//Moon.bmp",&moonImg;);glutInit(&argc;,argv);//初始化GLUT库glutInitDisplayMode(GLUT_RGBA|GLUT_DOUBLE|GLUT_DEPTH);//初始化显示模式glutInitWindowSize(WIN_WIDTH,WIN_HEIGHT);//初始化窗口大小glutInitWindowPosition(20,20);//初始化窗口位置GLuintwindow=glutCreateWindow(WIN_TITLE);//建立窗口InitGL();//初始化OpenGLglutDisplayFunc(Display);glutReshapeFunc(Reshape);glutKeyboardFunc(keyboard);glutSpecialFunc(special_keys);glutMouseFunc(mouse);glutIdleFunc(Display);//设置窗口空闲时的处理函数glutMainLoop();//进入事件处理循环}
2025/6/8 20:47:10 3.53MB 三维动画 模拟太阳系
1
内容简介······本书专门讲述积分方法,涵盖各种函数积分的方法,从初等函数到特殊函数,从实变函数到复变函数.本书以方法为中心、以算例为导向,读者可在算例的引导下,逐步掌握积分之方法.本书从易到难,由浅入深,适用不同层次、不同群体的人阅读,他们可以是初学微积分的大学生,可以是已经学过微积分的研究生,也可以是有工作经验的科学家、工程师。
作者简介······金玉明,中国科学技术大学教授、博导。
1977-1992为创建我国**台同步輻射加速器而工作。
任“国家同步輻射实验室工程”(这是由国家计委命名的我国**个国家实验室)副总工程师,负责同步輻射加速器的物理设计。
该项目于1991年完成,于1992年获中国科学院科研成果特等奖,1995年获国家科技进步一等奖。
目录······前言绪论第1章不定积分1.1不定积分中的原函数概念1.2分项积分法1.3分部积分法1.3.1分部积分法的基本公式1.3.2分部积分法的推广公式1.4换元积分法1.5三角替代法1.6欧拉替换法1.7三角函数积分中的倍角法1.8倍角法的应用1.8.1在函数sinpx,cosqx,sinpxcosqx的积分中(p,q为正整数,或奇整数,或偶整数)1.8.2倍角法应用在含有三角函数与指数函数的积分1.9secnx和cscnx的积分1.10tannx和cotnx的积分1.11有理代数分式的积分法1.12无理代数函数的积分法1.13含有三角函数的有理式的积分法1.13.1一般的方法1.13.2微分积分法1.13.3XX替换法1.14含有双曲函数的有理式的积分法1.15配对积分法(组合积分法)第2章定积分2.1定积分的定义2.1.1黎曼定义2.1.2面积求和法的定义——曲线下的面积2.2定积分的基本公式和常用法则2.2.1定积分的基本公式2.2.2定积分中的几个常用法则2.3欧拉积分、欧拉常数及其他常用常数2.3.1B函数(Betafunction)2.3.2Γ函数(Gammafunction)2.3.3几个重要常数2.4定积分中的分部积分法2.5定积分中的换元法2.6含参变量的积分法2.7无穷级数积分法2.8反常积分(Improper)2.8.1反常积分的定义2.8.2反常积分存在的判别法2.8.3反常积分算例2.8.4伏汝兰尼(Froullani)积分2.8.5罗巴切夫斯基(Lobachevsky)积分法2.8.6一个通用的积分法则2.8.7有关欧拉常数γ的几个积分2.9定积分的近似计算2.9.1近似计算的方法2.9.2近似计算算例2.9.3近似计算的误差估算第3章定积分的应用3.1面积的计算3.1.1用定积分的定义来计算面积3.1.2几种常见曲线围成的面积的计算3.2曲线长度的计算3.3体积的计算3.3.1用逐次积分法计算体积3.3.2利用横截面计算体积3.3.3回旋体的体积3.4表面积的计算3.4.1投影法计算表面积3.4.2回旋体的侧面积计算法第4章重积分4.1二重积分4.1.1二重积分的定义及算例4.1.2二重积分上、下限的确定——穿线法4.1.3几个典型的积分次序及积分限变换的例子4.1.4两个一元函数乘积的积分4.2三重积分4.2.1三重积分的定义4.2.2三重积分的傅比尼定理4.2.3三重积分的算例4.3重积分的坐标变换4.3.1二重积分的坐标变换4.3.2三重积分的坐标变换4.3.3n重积分的坐标变换第5章曲线积分和曲面积分5.1曲线积分5.1.1XX型曲线积分5.1.2第二型曲线积分5.1.3曲线积分的应用5.2格林(Green)公式5.3曲面积分5.3.1XX型曲面积分5.3.2第二型曲面积分5.4斯托克斯(Stokes)公式5.5高斯(Gauss)公式5.6高斯公式和斯托克斯公式在场论中的应用5.6.1高斯公式在场论中的应用5.6.2斯托克斯公式在场论中的应用第6章傅里叶积分和积分变换6.1傅里叶(Fourier)积分6.1.1傅里叶级数6.1.2傅里叶积分公式6.2傅里叶变换及其性质6.2.1傅里叶变换6.2.2傅里叶变换的性质6.2.3傅里叶余弦变换和正弦变换6.2.4傅里叶变换及傅里叶余弦变换和正弦变换算例6.2.5傅里叶变换的应用6.3拉普拉斯(Laplace)变换6.3.1拉普拉斯变换6.3.2拉普拉斯变换的性质6.3.3单项式的拉普拉斯变换算例6.3.4拉普拉斯逆变换6.3.5拉普拉斯变换的应用第7章复变函数的积分7.1复变函数的概念7.1.1复数和复平面7.1.2复数
2025/5/30 8:56:04 33.28MB 金玉明 顾新身  毛瑞庭 微积分
1
径向基函数(RadialBasisFunctions,以下简称RBF)在数值和科学计算等领域被广泛应用,例如解微分方程、人工神经网络、曲面重建、计算机辅助设计、计算机图形学和多元插值等。
RBF插值方法不受输入参数的限制,可以进行高维插值。
2025/5/29 14:21:20 1.25MB 径向基函数 RBF
1
ug曲面建模方面的资料
2025/5/8 4:17:48 24.49MB ug 曲面 3d
1
共 153 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡