Open CASCADE学习|三重正交标架法则

三重正交标架(Trihedron)

定义:三重正交标架是在三维空间中定义的一个坐标系,由三个互相垂直的向量构成。这些向量分别是:

切线向量(Tangent Vector) - 表示曲线在某一特定点处的切线方向。

主法线向量(Normal Vector) - 在曲线的每一点上垂直于切线向量,并且根据曲面的曲面法线(如果曲线位于某个曲面上)来定向。

副主法线向量(Binormal Vector) - 垂直于切线向量和主法线向量,完成三重正交标架的构建。

应用:三重正交标架在计算机图形学中用于:

  • 定义沿曲线的局部坐标系,这对于曲面的参数化和建模非常重要。

  • 分析曲线的曲率和扭率,因为曲率向量和扭率向量可以通过三重正交标架的导数来计算。

  • 生成管道(Pipe)和扫掠(Sweeping)曲面,这些曲面沿着曲线拉伸一个截面。

三重正交标架法则(Trihedron Law)

定义:三重正交标架法则是一个在曲线的每一点上定义三重正交标架的规则。这个法则可以是显式的,也可以是隐式的,取决于它是基于特定的几何构造(如Frenet-Serret公式)还是基于更通用的几何约束。

Frenet-Serret公式:在曲线r(t)的参数化形renet-Serret公式提供了一种计算三重正交标架的方法,其中 𝑡是曲线的参数。这些公式基于曲线的导数:

应用:三重正交标架法则在计算机辅助设计(CAD)和计算机辅助制造(CAM)中用于:

  • 定义沿曲线的几何变化,这在创建复杂的3D几何形状时非常有用。

  • 控制沿曲线的截面变形,以生成复杂的曲面,如螺旋曲面或螺旋管道。

  • 实现高级曲面建模技术,如NURBS曲面的构建。

GeomFill_Frenet类继承自GeomFill_TrihedronLaw,用于在3D空间中定义沿曲线的Frenet三重正交标架法则。

GeomFill_Frenet类实现了Frenet三重正交标架法则,这在3D几何建模中用于定义沿曲线的局部坐标系,该坐标系由切线(Tangent)、主法线(Normal)和副主法线(BiNormal)构成。此类提供了计算三重正交标架及其导数的方法,并且能够处理曲线上的奇异点,这些奇异点是曲线的曲率或扭率不连续的点。

// 防止头文件被重复包含。
#ifndef _GeomFill_Frenet_HeaderFile
#define _GeomFill_Frenet_HeaderFile
​
#include <Standard.hxx>  // 标准库的头文件
#include <TColStd_HArray1OfReal.hxx>  // 用于存储实数数组的OCCT类
#include <GeomFill_TrihedronLaw.hxx>  // 三重正交标架法则的基类
#include <Standard_Real.hxx>  // 实数类型定义
#include <Standard_Integer.hxx>  // 整型定义
#include <GeomAbs_Shape.hxx>  // 几何形状定义
#include <TColStd_Array1OfReal.hxx>  // 用于存储实数数组的OCCT类
#include <gp_Vec.hxx>  // 几何向量类
​
// 声明GeomFill_Frenet类和它的句柄类型。
class GeomFill_Frenet;
DEFINE_STANDARD_HANDLE(GeomFill_Frenet, GeomFill_TrihedronLaw)
​
// 定义Frenet三重正交标架法则。
class GeomFill_Frenet : public GeomFill_TrihedronLaw
{public:  // 公共成员函数
​// 构造函数Standard_EXPORT GeomFill_Frenet();
​// 复制构造函数,创建当前对象的一个副本Standard_EXPORT virtual Handle(GeomFill_TrihedronLaw) Copy() const Standard_OVERRIDE;
​// 初始化Frenet法则Standard_EXPORT void Init();
​// 设置Frenet法则的曲线Standard_EXPORT virtual Standard_Boolean SetCurve(const Handle(Adaptor3d_Curve)& C) Standard_OVERRIDE;
​// 计算曲线上参数为Param处的三重正交标架Standard_EXPORT virtual Standard_Boolean D0(const Standard_Real Param, gp_Vec& Tangent, gp_Vec& Normal, gp_Vec& BiNormal) Standard_OVERRIDE;
​// 计算曲线上参数为Param处的三重正交标架及其一阶导数Standard_EXPORT virtual Standard_Boolean D1(const Standard_Real Param, gp_Vec& Tangent, gp_Vec& DTangent, gp_Vec& Normal, gp_Vec& DNormal, gp_Vec& BiNormal, gp_Vec& DBiNormal) Standard_OVERRIDE;
​// 计算曲线上参数为Param处的三重正交标架及其一阶和二阶导数Standard_EXPORT virtual Standard_Boolean D2(const Standard_Real Param, gp_Vec& Tangent, gp_Vec& DTangent, gp_Vec& D2Tangent, gp_Vec& Normal, gp_Vec& DNormal, gp_Vec& D2Normal, gp_Vec& BiNormal, gp_Vec& DBiNormal, gp_Vec& D2BiNormal) Standard_OVERRIDE;
​// 返回连续性S的区间数量Standard_EXPORT virtual Standard_Integer NbIntervals(const GeomAbs_Shape S) const Standard_OVERRIDE;
​// 存储连续性S的区间的边界参数Standard_EXPORT virtual void Intervals(TColStd_Array1OfReal& T, const GeomAbs_Shape S) const Standard_OVERRIDE;
​// 获取Tangent(t)和Normal(t)的平均值,这对于快速近似有理曲面非常有用Standard_EXPORT virtual void GetAverageLaw(gp_Vec& ATangent, gp_Vec& ANormal, gp_Vec& ABiNormal) Standard_OVERRIDE;
​// 检查法则是否恒定Standard_EXPORT virtual Standard_Boolean IsConstant() const Standard_OVERRIDE;
​// 返回True,表示法则仅由3D曲线确定Standard_EXPORT virtual Standard_Boolean IsOnlyBy3dCurve() const Standard_OVERRIDE;
​// 实现运行时类型识别(RTTI)DEFINE_STANDARD_RTTIEXT(GeomFill_Frenet, GeomFill_TrihedronLaw)
​protected:  // 保护成员函数
​private:  // 私有成员函数和变量
​// 检查U是否为奇异点,并返回奇异点的索引Standard_EXPORT Standard_Boolean IsSingular(const Standard_Real U, Standard_Integer& Index) const;
​// 处理奇异点Standard_EXPORT Standard_Boolean DoSingular(const Standard_Real U, const Standard_Integer Index, gp_Vec& Tangent, gp_Vec& BiNormal, Standard_Integer& n, Standard_Integer& k, Standard_Integer& TFlag, Standard_Integer& BNFlag, Standard_Real& Delta);
​// 计算奇异点处的三重正交标架Standard_EXPORT Standard_Boolean SingularD0(const Standard_Real Param, const Standard_Integer Index, gp_Vec& Tangent, gp_Vec& Normal, gp_Vec& BiNormal, Standard_Real& Delta);
​// 计算奇异点处的三重正交标架及其一阶导数Standard_EXPORT Standard_Boolean SingularD1(const Standard_Real Param, const Standard_Integer Index, gp_Vec& Tangent, gp_Vec& DTangent, gp_Vec& Normal, gp_Vec& DNormal, gp_Vec& BiNormal, gp_Vec& DBiNormal, Standard_Real& Delta);
​// 计算奇异点处的三重正交标架及其一阶和二阶导数Standard_EXPORT Standard_Boolean SingularD2(const Standard_Real Param, const Standard_Integer Index, gp_Vec& Tangent, gp_Vec& DTangent, gp_Vec& D2Tangent, gp_Vec& Normal, gp_Vec& DNormal, gp_Vec& D2Normal, gp_Vec& BiNormal, gp_Vec& DBiNormal, gp_Vec& D2BiNormal, Standard_Real& Delta);
​// 旋转三重正交标架以使给定的“Tangent”和“NewTangent”轴重合Standard_EXPORT Standard_Boolean RotateTrihedron(gp_Vec& Tangent, gp_Vec& Normal, gp_Vec& BiNormal, const gp_Vec& NewTangent) const;
​// 存储曲线上的点、奇异点数组和奇异点长度数组的句柄gp_Pnt P;Handle(TColStd_HArray1OfReal) mySngl;Handle(TColStd_HArray1OfReal) mySnglLen;Standard_Boolean isSngl;
​
};
​
#endif // _GeomFill_Frenet_HeaderFile

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/7294.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

越权漏洞!

越权漏洞是指在一个系统或应用程序中存在某种不当的访问权限&#xff0c;使得攻击者可以获得比其应该拥有的权限更高的权限。这种漏洞可能允许攻击者执行未经授权的操作&#xff0c;例如访问他人的敏感数据、修改系统设置、执行恶意代码等。越权漏洞通常是由于设计或实现上的错…

淡茶怎么泡?

很多人都知道喝浓茶对身体不好&#xff0c;但是怎么冲泡淡茶却一知半解。按照《品深淡茶冲泡标准》中对绿茶冲泡淡茶的规定&#xff0c;冲泡的茶汤中咖啡碱不得高于31.67mg/100mL&#xff0c;可可碱不得高于2.67mg/mL&#xff0c;茶碱不得高于1.50mg/100mL&#xff0c;茶多酚不…

[C++核心编程-03]----C++函数提高学习

目录 引言 正文 01-函数提升简介 02-函数默认参数 03-函数占位参数 04-函数重载 05-函数重载的注意事项 总结 引言 函数在C编程中扮演着至关重要的角色&#xff0c;通过合理使用函数&#xff0c;可以提高程序的结构性、灵活性、可读性和维护性。因此&…

Guer完成对Gallium Semi的GaN产品组合的收购

预计到2024年6月&#xff0c;完整的射频氮化镓产品组合将完成整合 总部位于美国的Guerrilla RF (GUER)已完成对镓半导体公司GaN功率放大器和前端模块的全部收购。 自2024年4月26日起&#xff0c;GUER收购了Gallium Semiconductor先前发布的所有组件以及正在开发的新内核。此外…

软件测试与管理-白盒测试-基本路径测试法

知识点&#xff1a; 1.原理 是在程序控制流图的基础上&#xff0c;通过分析控制构造的环路复杂性&#xff0c;导出基本可执行路径的集合&#xff0c;然后根据可执行路径进行测试用例设计的方法。此方法设计出的测试用例需保证被测程序的每个可执行语句至少执行一次。 2.步骤 &a…

计算机SCI期刊,中科院2区,IF=6+,自引率低,专业认可度高!

一、期刊名称 Journal of King Saud University-Computer and Information Sciences 二、期刊简介概况 期刊类型&#xff1a;SCI 学科领域&#xff1a;计算机科学 影响因子&#xff1a;6.9 中科院分区&#xff1a;2区 出版方式&#xff1a;开放出版 版面费&#xff1a;$…

开源模型 Prometheus 2 能够评估其他语言模型,其效果几乎与 GPT-4 相当

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

在Codelab对llama3做Lora Fine tune微调

Unsloth 高效微调大模型的工具&#xff0c;通过Unsloth微调Llama3, Mistral, Gemma 速度提升2-5倍&#xff0c;内存减少70%&#xff01; Codelab 创建一个jupyter notebook 选择 T4 GPU 安装Fine tune 相关的lib %%capture import torch major_version, minor_version torch…

权益商城系统源码,支持多种支付方式

权益商城系统源码&#xff0c;支持多种支付方式&#xff0c;后台商品管理&#xff0c;订单管理&#xff0c;串货管理&#xff0c;分站管理&#xff0c; 会员列表&#xff0c;分销日志&#xff0c;应用配置。 上传到服务器&#xff0c;修改数据库信息&#xff0c;导入数据库&a…

Python中的分布式爬虫系统Scrapy与分布式任务队列的结合

随着互联网的不断发展&#xff0c;网络爬虫在数据采集和信息挖掘中发挥着重要作用。然而&#xff0c;单机爬虫往往难以应对大规模数据抓取的需求&#xff0c;因此&#xff0c;构建分布式爬虫系统成为了一种必然选择。本文将介绍如何利用 Python 中的 Scrapy 框架和分布式任务队…

android studio apt代码编写实战

之所以试一下apt代码的编写&#xff0c;是因为发现几年前写的工程&#xff0c;在新的android studio中debug apt代码时&#xff0c;一直连不上debug环境&#xff0c;提示报错 Unable to open debugger port (localhost:5005): java.net.ConnectException "Connection refu…

IOS自动化—将WDA打包ipa批量安装驱动

前言 CSDN&#xff1a; ios自动化-Xcode、WebDriverAgent环境部署 ios获取原生系统应用的包 如果Mac电脑没有配置好Xcode相关环境,可以参考以上文章。 必要条件 Mac电脑&#xff0c;OS版本在12.4及以上&#xff08;低于这个版本无法安装Xcode14&#xff0c;装不了Xcode14就…

excel中数据筛选技巧

1、筛选excel中破折号前后都为空的数据 在Excel中查找破折号前后为空的数据&#xff0c;你可以结合使用Excel的查找和筛选功能&#xff0c;或者利用一些公式来判断。以下是两种常用的方法&#xff1a; 方法一&#xff1a;使用筛选功能选中数据范围&#xff1a;首先&#xff0c…

微信小程序miniprogram_npm目录主包太大如何处理

在使用TDesign开发小程序&#xff0c;miniprogram_npm目录下很多组件&#xff0c;感觉很多组件我都没引用&#xff0c;为什么都在主包来&#xff0c;导致主包很大。如何优化&#xff1f; 在使用npm构建后生成的miniprogram_npm目录里&#xff0c;有所有TDesign组件。但是有很…

Docker 入门篇(六)-- idea 打包 docker 镜像流程

环境准备&#xff1a; idea 环境&#xff1a;IntelliJ IDEA 2021.3.1 (Ultimate Edition)docker 版本&#xff1a;v. 26.1.0准备 springboot jar 文件 &#xff1a;target/DockerDemo-0.0.1-SNAPSHOT.jardocker 可视化管理工具 portainer &#xff1a;v2.6.0 一. 配置docker远…

27.leetcode---随机链表的复制(Java版)

题目链接: https://leetcode.cn/problems/copy-list-with-random-pointer/description/ 题目解析: 使用map来解这个题就比较方便了 代码: 测试:

论文阅读:《Sequence can Secretly Tell You What to Discard》,减少推理阶段的 kv cache

目前各类大模型都支持长文本&#xff0c;例如 kimi chat 以及 gemini pro&#xff0c;都支持 100K 以及更高的上下文长度。但越长的上下文&#xff0c;在推理过程中需要存储的 kv cache 也越多。假设&#xff0c;数据的批次用 b 表示&#xff0c;输入序列的长度仍然用 s 表示&a…

【typescript测试 - Jest 配置与使用】

安装 npm install --save-dev types/jestnpm install --save-dev ts-jest配置 tsconfig.json {"compilerOptions": {"types": ["jest"]} }jest.config.js module.exports {preset: ts-jest,testEnvironment: node, };使用 // add.js funct…

C++学习笔记——对仿函数的理解

文章目录 思维导图仿函数出现的逻辑仿函数使用上的巧妙 仿函数的本质仿函数的优势仿函数语法的巧妙 思维导图 仿函数出现的逻辑 我们在学习stack时会遇到一些新的问题&#xff0c;这些问题需要我们使用非类型模板参数去解决&#xff0c;即我们需要在设计类时需要有一个途径去快…

Android硬件加速hardwareAccelerated支持/不支持的绘图接口

Android硬件加速hardwareAccelerated支持/不支持的绘图接口 Android硬件加速也即在Androidmanifest.xml配置开启GPU渲染&#xff1a; <application android:hardwareAccelerated"true" > 配置后&#xff0c;Android将启用GPU渲染&#xff0c;在trace里面看会…