Matlab中安装NURBS工具箱及使用

news2025/1/12 19:07:19

文章目录

  • 前言
  • 一、NURBS工具箱的安装
    • 1 打开matlab,点击附加功能
    • 2 输入nurbs
    • 3 下载后压缩包解压
    • 4 将解压后的文件夹放到matlab文件夹的toolbox文件夹里面
    • 5 选择“预设路径”上方的“预设”
  • 二、NURBS工具箱的使用
    • 2.1 NURBS 结构:
    • 2.2 对NURBS工具箱的初步理解
    • 2.3 matlab中cat函数


前言

只是为方便学习,不做其他用途,
学习等几何的时候编程用到NURBS函数,学习安装NURBS工具箱及使用

一、NURBS工具箱的安装

1 打开matlab,点击附加功能

在这里插入图片描述
出现如下页面,点击”产品“ :
在这里插入图片描述

2 输入nurbs

在这里插入图片描述下拉,找到如下NURBS Toolbox by D.M. Spink工具箱 :
在这里插入图片描述
点击 NURBS Toolbox by D.M. Spink

在这里插入图片描述 选下载,可能需要你注册账号,按要求注册好账号就可以下载了。

3 下载后压缩包解压

在这里插入图片描述

4 将解压后的文件夹放到matlab文件夹的toolbox文件夹里面

在这里插入图片描述
然后添加路径 :

  • 点击 设置路径
  • 将刚才的文件夹添加到路径中 注意要选包含子文件夹-----》保存-----》关闭

在这里插入图片描述

5 选择“预设路径”上方的“预设”

在这里插入图片描述

二、NURBS工具箱的使用

2.1 NURBS 结构:

曲线和曲面都由一个结构表示与 Mathworks 的样条工具箱兼容

nurbs.form … 输入名称’B-NURBS’
nurbs.dim … 控制点的尺寸= 4(x,y,z,w)
nurbs.number … 控制顶点个数
nurbs.coefs … 控制顶点坐标
nurbs.order … 样条的顺序?
nurbs.knots … 节点向量

2.2 对NURBS工具箱的初步理解

案例1:
构造一条从 (0,0) 到 (1.5,3) 的二维线.对于直线,需要 2 阶样条。 请注意,节点向量在开始 (0.0,0.0) 和结束 (1.0 1.0) 处的重数为 2,以满足端点插值性。

代码:

clear;
clc;
coef = [0.0 1.5; 0.0 3.0];    % 控制顶点
konts = [0.0 0.0 1.0 1.0];    % 节点向量
line = nrbmak(coef,konts);    % nrbmak(coef,konts)--给定控制顶点和节点向量,构造NURBS结构
figure(1)
nrbplot(line, 2);

在这里插入图片描述

line.coef: 对应nurbs曲线的坐标

在这里插入图片描述

line.konts: 对应nurbs曲线的节点向量

在这里插入图片描述
在这里插入图片描述

案例2:
在x-y平面上构造一个平面。

clear;
clc;

coefs = cat(3,[0 0; 0 1],[1 1; 0 1]);      
%控制顶点(0 0)  (0 1)  (1 0)  (1 1)
knots = {[0 0 1 1]  [0 0 1 1]}; 
%节点向量u = [0 0 1 1];  v = [0 0 1 1]
plane = nrbmak(coefs,knots); 
figure(2)
nrbplot(plane, [2 2]); 
     

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

例3:度数提升算法

clear;
clc;
pnts = [0.5 1.5 4.5 3.0 7.5 6.0 8.5; 
        3.0 5.5 5.5 1.5 1.5 4.0 4.5; 
        0.0 0.0 0.0 0.0 0.0 0.0 0.0]; 
crv = nrbmak(pnts,[0 0 0 1/4 1/2 3/4 3/4 1 1 1]); 
% 绘制控制点 
plot(crv.coefs(1,:),crv.coefs(2,:),'bo')    %画曲线的控制顶点
title('测试曲线度数提升1'); 
hold on; 
plot(crv.coefs(1,:),crv.coefs(2,:),'b--');   %画控制多边形,将控制顶点依次用直线连接
 
% 绘制Nurbs曲线 
nrbplot(crv,48); 
 
% 度提升的曲线 by 1 
icrv = nrbdegelev(crv, 1); 
nrbplot(icrv,50)
% 插入新的结点并绘制新的控制点 
plot(icrv.coefs(1,:),icrv.coefs(2,:),'ro') %画点
plot(icrv.coefs(1,:),icrv.coefs(2,:),'r--'); %连线
 
hold off;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.3 matlab中cat函数

cat函数 串联数组:

语法:
C = cat(dim,A,B)
C = cat(dim,A1,A2,…,An)

说明:
1、当 A 和 B 具有兼容的大小(除运算维度 dim 以外的维度长度匹配)时,C = cat(dim,A,B) 沿维度 dim 将B串联到A的末尾。
2、C = cat(dim,A1,A2,…,An) 沿维度dim串联A1、A2、…、An。
3、可以使用方括号运算符[]进行串联。例如,[A,B]或[A B]将水平串联数组A和B,而[A; B]将垂直串联它们。

示例:创建两个矩阵,先垂直串联这两个矩阵,然后再水平串联。
A = ones(3)
A = 3×3
 
     1     1     1
     1     1     1
     1     1     1
 
B = zeros(3)
B = 3×3
 
     0     0     0
     0     0     0
     0     0     0
 
C1 = cat(1,A,B)
C1 = 6×3
 
     1     1     1
     1     1     1
     1     1     1
     0     0     0
     0     0     0
     0     0     0
 
C2 = cat(2,A,B)
C2 = 3×6
 
     1     1     1     0     0     0
     1     1     1     0     0     0
     1     1     1     0     0     0
示例2:创建一个包含两个矩阵的元胞数组,并分别以垂直方式和水平方式串联这两个矩阵。
M1 = [1 2; 3 4];
M2 = [5 6; 7 8];
A1 = {M1,M2};
Cvert = cat(1,A1{:})
 
Cvert = 4×2
 
     1     2
     3     4
     5     6
     7     8
 
Chorz = cat(2,A1{:})
 
Chorz = 2×4
 
     1     2     5     6
     3     4     7     8
     
Cver3 = cat(3,A1{:})

Cver3(:,:,1) =

     1     2
     3     4


Cver3(:,:,2) =

     5     6
     7     8

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

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

相关文章

关于表的操作 数据库(3)

目录 前期准备工作: 一、单表查询: 二、多表查询: 前期准备工作: 修改数据库的配置文件,,使其可以显示库名,其中//d代表当前使用的数据库名 注:vim /etc/my.cnf.d/mysql-server.c…

Session与Cookie的区别(四)

咖啡寄杯的烦恼 虽然店里生意还可以,但小明无时无刻不想着怎么样发大财赚大钱,让店里的生意变得更好。 他观察到最近好多便利商店开始卖起了咖啡,而且时不时就买一送一或是第二件半价,并且贴心地提供了寄杯的服务。 寄杯就是指说你…

《剑指offer》:数组部分

一、数组中重复的数字题目描述:在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1…

C语言fscanf和fprintf函数的用法详解

fscanf() 和 fprintf() 函数与前面使用的 scanf() 和 printf() 功能相似,都是格式化读写函数,两者的区别在于 fscanf() 和 fprintf() 的读写对象不是键盘和显示器,而是磁盘文件。这两个函数的原型为:int fscanf ( FILE *fp, char …

【力扣-LeetCode】1138. 字母板上的路径-C++题解

1138. 字母板上的路径难度中等98收藏分享切换为英文接收动态反馈我们从一块字母板上的位置 (0, 0) 出发,该坐标对应的字符为 board[0][0]。在本题里,字母板为board ["abcde", "fghij", "klmno", "pqrst", &quo…

点云转3D网格【Python】

推荐:使用 NSDT场景设计器 快速搭建 3D场景。 在本文中,我将介绍我的 3D 表面重建过程,以便使用 Python 从点云快速创建网格。 你将能够导出、可视化结果并将结果集成到您最喜欢的 3D 软件中,而无需任何编码经验。 此外&#xff0…

总投资超500亿,广州白云机场三期扩建工程的IT投资更吸引人

【科技明说 | 每日看点】2023年基建大工程计划出台,广州白云机场三期将落实百亿元投资引发业内关注。据悉,广州白云机场三期扩建工程投资达537.7亿元,计划于2025年建成投产。这是中国民航历史上规模最大的改扩建工程,其扩建工程今…

TC3xx FlexRay™ 协议控制器 (E-Ray)-01

1 FlexRay™ 协议控制器 (E-Ray) E-Ray IP 模块根据为汽车应用开发的 FlexRay™ 协议规范 v2.1 执行通信【performs communication according to the FlexRay™ 1) protocol specification v2.1】。使用最大指定时钟,比特率可以编程为高达 10 Mbit/s 的值。连接到物…

Fluent Python 笔记 第 5 章 一等函数

在 Python 中,函数是一等对象。编程语言理论家把“一等对象”定义为满足下述条件的程 序实体: 在运行时创建能赋值给变量或数据结构中的元素 • 能作为参数传给函数能作为函数的返回结果 5.1 把函数视作对象 会用 map。 5.2 高阶函数 接受函数为参数&#xff0…

基于JAVA的超级玛丽设计与实现

技术:Java等摘要:随着计算机技术及网络技术的不断发展,电子游戏越来越普及。经典游戏“超级玛丽”因其本身所具有的娱乐性与教育意义而被人们广泛接受,在广大的青少年玩家中享有极高的知名度。Java语言作为一种完全面向对象的程序…

【AI 交互式聊天】无需等待 Bing ChatGPT : 已经有一个基于搜索结果响应的 AI 交互式聊天网站了!Perplexity

Perplexity: https://www.perplexity.ai 同样的问题,我问ChatGPT,回答如下: 实现财富自由需要一系列的步骤和策略,以下是一些建议: 1. 设定目标:明确你的财务目标,并制定一个有目标的计划来实…

吾爱破解2023安卓中级题

先来看看APP界面 拖到jadx,see see java 源码 关键是要让代码跳转到这里,我这里主要是修改smali,然后重新签名打包,当然,你也可以用frida或者objection hook 传参 模仿下面的两行代码,在位置1插入 :cond_6…

循环队列来了解一下!!

笔者在之前的一篇文章,详细的介绍了:队列之单向链表与双向链表的模拟实现:https://blog.csdn.net/weixin_64308540/article/details/128742090?spm1001.2014.3001.5502 感兴趣的各位老铁,可以参考一下啦!下面进入循环…

基于Java+SpringBoot+Vue前后端分离酒店管理系统设计与实现

博主介绍:✌全网粉丝3W,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建、毕业项目实战、项目定制✌ 博主作品:《微服务实战》专栏是本人的实战经验总结,《S…

linux系统常用命令

目录 一、系统介绍 二、Linux常用命令 1、Linux命令格式 2、文件目录操作命令:ls 3、文件目录操作命令:cd 4、文件目录操作命令:cat 5、文件目录操作命令:more 6、文件目录操作命令:tail 7、创建文件命令&…

【三维点云】01-激光雷达原理与应用

文章目录内容概要1 激光雷达原理1.1 什么是激光雷达?1.2 激光雷达原理1.3 激光雷达分类三角法TOF法脉冲间隔测量法幅度调制的相位测量法相干法激光雷达用途2 激光雷达安装、标定与同步2.1 激光雷达安装方式考虑因素2.2 激光雷达点云用途2.3 数据融合多激光雷达数据融…

Rust学习入门--【7】Rust 数据类型

类型系统 对于任何一门语言都是重中之重,因为它体现了语言所支持的不同类型的值。 类型系统 也是 IT 初学者最难啃的三座大山之一,而类型系统之所以难以理解,主要是没有合适的现成的参考体系。 我们说类型系统 存在的目的,就是 …

【代码随想录】-动态规划专题

文章目录理论基础斐波拉契数列爬楼梯使用最小花费爬楼梯不同路径不同路径 II整数拆分不同的二叉搜索树背包问题——理论基础01背包二维dp数组01背包一维数组(滚动数组)装满背包分割等和子集最后一块石头的重量 II目标和一和零完全背包零钱兑换 II组合总和…

JVM学习03:垃圾回收

JVM学习03:垃圾回收 1、如何判断对象可以回收 1.1、引用计数法 记录当前对象被引用的次数,当引用次数为0时则进行垃圾回收。缺点:当两个对象互相引用但并没有其他对象再引用它们时,他们的引用次数都为1,无法对其进行…

Spring Security in Action 第三章 SpringSecurity管理用户

本专栏将从基础开始,循序渐进,以实战为线索,逐步深入SpringSecurity相关知识相关知识,打造完整的SpringSecurity学习步骤,提升工程化编码能力和思维能力,写出高质量代码。希望大家都能够从中有所收获&#…