news 2026/5/1 7:22:34

ExponentialCosine 复杂的二维数学函数映射为3D曲面

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ExponentialCosine 复杂的二维数学函数映射为3D曲面

一:主要的知识点

1、说明

本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客

2、知识点纪要

本段代码主要涉及的有①vtkWarpScalar根据标量值沿着发现方向进行形变


二:代码及注释

import vtkmodules.vtkRenderingOpenGL2 import vtkmodules.vtkInteractionStyle from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkRenderingCore import ( vtkActor, vtkDataSetMapper, vtkRenderWindow, vtkRenderWindowInteractor, vtkRenderer ) from vtkmodules.vtkFiltersSources import vtkPlaneSource from vtkmodules.vtkCommonTransforms import vtkTransform from vtkmodules.vtkFiltersGeneral import vtkTransformPolyDataFilter, vtkWarpScalar from vtkmodules.vtkCommonCore import vtkPoints, vtkDoubleArray from vtkmodules.vtkCommonDataModel import vtkPolyData import math def main(): colors = vtkNamedColors() ren = vtkRenderer() renWin = vtkRenderWindow() renWin.AddRenderer(ren) iren = vtkRenderWindowInteractor() iren.SetRenderWindow(renWin) plane = vtkPlaneSource() plane.SetResolution(300, 300) transform = vtkTransform() transform.Scale(10.0, 10.0, 1.0) transF = vtkTransformPolyDataFilter() transF.SetInputConnection(plane.GetOutputPort()) transF.SetTransform(transform) transF.Update() inputPd = transF.GetOutput() numPts = inputPd.GetNumberOfPoints() newPts = vtkPoints() newPts.SetNumberOfPoints(numPts) derivs = vtkDoubleArray() derivs.SetNumberOfTuples(numPts) bessel = vtkPolyData() bessel.CopyStructure(inputPd) # 将inputPd的拓扑结构复制到bessel中 bessel.SetPoints(newPts) bessel.GetPointData().SetScalars(derivs) x = [0.0] * 3 for i in range(0, numPts): inputPd.GetPoint(i, x) r = math.sqrt(float(x[0] * x[0]) + x[1] * x[1]) x[2] = math.exp(-r) * math.cos(10.0 * r) newPts.SetPoint(i, x) deriv = -math.exp(-r) * (math.cos(10.0 * r) + 10.0 * math.sin(10.0 * r)) derivs.SetValue(i, deriv) """ vtkWarpScalar 与vtkWarpVector不同,其是按照"标量场"来形变 用于根据点的标量值(scalar data)对几何体进行沿法线方向的形变 """ warp = vtkWarpScalar() warp.SetInputData(bessel) """ 启用XYPlane模式, 当 XYPlaneOn() 被调用时,vtkWarpScalar 过滤器会被指示只沿着与XY平面垂直的方向(即Z轴方向)移动顶点 默认情况下,vtkWarpScalar 会沿着几何体的表面法线方向(Normal)进行位移 """ warp.XYPlaneOn() warp.SetScaleFactor(0.5) mapper = vtkDataSetMapper() mapper.SetInputConnection(warp.GetOutputPort()) tmp = bessel.GetScalarRange() mapper.SetScalarRange(tmp[0], tmp[1]) carpet = vtkActor() carpet.SetMapper(mapper) # Assign our actor to the renderer. ren.AddActor(carpet) ren.SetBackground(colors.GetColor3d('Beige')) renWin.SetSize(640, 480) renWin.SetWindowName('ExponentialCosine') # draw the resulting scene ren.ResetCamera() ren.GetActiveCamera().Zoom(1.35) ren.GetActiveCamera().Elevation(-55) ren.GetActiveCamera().Azimuth(25) ren.ResetCameraClippingRange() renWin.Render() iren.Start() if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 7:21:59

HardwareSelector 单元网格面鼠标选择

一:主要的知识点 1、说明 本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客 2、知识点纪要 本段代码主要涉及的有①vtkHardwareSelector网格面的UI交互选择 …

作者头像 李华
网站建设 2026/5/1 6:17:28

ResNet18实战:智能监控系统物体识别部署案例

ResNet18实战:智能监控系统物体识别部署案例 1. 引言:通用物体识别的工程价值与ResNet-18的定位 在智能监控、安防预警、行为分析等实际场景中,通用物体识别是构建视觉感知能力的基础环节。传统方案依赖人工规则或轻量级分类器,…

作者头像 李华
网站建设 2026/5/1 6:14:55

ResNet18优化实战:推理吞吐量提升

ResNet18优化实战:推理吞吐量提升 1. 背景与挑战:通用物体识别中的性能瓶颈 在AI应用落地过程中,模型的稳定性和推理效率是决定用户体验的核心因素。基于TorchVision官方实现的ResNet-18模型因其轻量、稳定、泛化能力强,广泛应用…

作者头像 李华
网站建设 2026/4/25 10:15:36

ResNet18实战教程:工业缺陷检测系统搭建指南

ResNet18实战教程:工业缺陷检测系统搭建指南 1. 引言:从通用识别到工业场景的迁移价值 1.1 通用物体识别为何能用于工业缺陷检测? 在智能制造与自动化质检领域,传统机器视觉依赖规则化图像处理(如边缘检测、模板匹配…

作者头像 李华
网站建设 2026/5/1 7:36:28

ResNet18性能对比:与ResNet50差异分析

ResNet18性能对比:与ResNet50差异分析 1. 引言:为何关注ResNet18与ResNet50的性能差异? 在深度学习图像分类任务中,ResNet(残差网络) 自2015年提出以来,已成为计算机视觉领域的基石模型之一。…

作者头像 李华
网站建设 2026/5/1 7:35:24

ResNet18优化教程:早停策略应用

ResNet18优化教程:早停策略应用 1. 引言:通用物体识别中的ResNet-18 在现代计算机视觉任务中,通用物体识别是基础且关键的一环。无论是智能相册分类、自动驾驶环境感知,还是内容审核系统,都需要一个稳定、高效、准确…

作者头像 李华