Matlab之空间坐标系绘制平面图形

在空间直角坐标系中,绘制指定平面方程的图形

版本说明:

20240413_V1.01:更正代码错误,并修改输入参数类型(测试用例得修改)

20240413_V1.00:初始版本

一、平面方程

基本形式为:A*X+B*Y+C*Z+D=0

例如:对于X+23=0的平面方程如下

二、Matlab通用绘制函数

cpp 复制代码
%% 绘制平面图形
% 输入参数:平面方程的参数以及图形的范围
function plot_plane(A, B, C, D, Range)
% 检查平面是否与坐标轴平行
if A == 0 && B == 0
    % 平面与z轴垂直
    [X, Y] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Z =zeros(size(X))-D;  % 固定z值
elseif B == 0 && C == 0
    % 平面与y轴和Z轴平行
    [Y, Z] = meshgrid(linspace(-Range, Range, 100), linspace(-Range, Range, 100));
    X = zeros(size(Y))- D;  % 固定X值
elseif A == 0 && C == 0
    % 平面与X轴和Z轴平行
    [X, Z] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Y = zeros(size(X))- D;  % 固定x值    
elseif C == 0
    % 平面与Z轴平行
    [X, Z] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Y = -(A.* X +D)/B;  % 解平面方程得到Y
else
    % 平面不与Z坐标轴平行
    % 选择一个合适的范围来创建网格点
    [X, Y] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Z = -(A.* X + B.* Y+D)/C;  % 解平面方程得到z
end

% 绘制平面
surf(X, Y, Z, 'FaceColor', 'none', 'EdgeColor', 'blue');

% 设置图形属性
grid on;
xlabel('X轴');
ylabel('Y轴');
zlabel('Z轴');
xlim([-Range, Range]);
ylim([-Range, Range]);
zlim([-Range, Range]);
% axis equal;     % 保持轴的比例一致
view(3);         % 设置三维视角
end

三、测试用例

3.1 X+23=0

plot_plane(1, 0, 0, 23, '平面绘制示例')

3.2 Y+23=0

plot_plane(0, 1, 0, 23, '平面绘制示例')

3.3 Z+23=0

plot_plane(0, 0, 1, 23, '平面绘制示例')

3.4 Y+Z+23=0

plot_plane(0, 1, 1, 23, '平面绘制示例')

3.5 X+Z+23=0

plot_plane(1, 0, 1, 23, '平面绘制示例')

3.6 X+Y+23=0

plot_plane(1, 1, 0, 23, 5)

3.7 X+Y+Z+23=0

plot_plane(1, 1, 1, 23, '平面绘制示例')

相关推荐
你的冰西瓜4 分钟前
C++ 中最短路算法的详细介绍
c++·算法·图论·最短路
zstar-_11 分钟前
【算法笔记】6.LeetCode-Hot100-链表专项
笔记·算法·leetcode
Swift社区16 分钟前
Swift 图论实战:DFS 算法解锁 LeetCode 323 连通分量个数
算法·swift·图论
<但凡.19 分钟前
数据结构与算法之美:广义表
数据结构·c++·算法
前端极客探险家30 分钟前
告别卡顿与慢响应!现代 Web 应用性能优化:从前端渲染到后端算法的全面提速指南
前端·算法·性能优化
程序员Xu1 小时前
【OD机试题解法笔记】连续出牌数量
笔记·算法·深度优先
CoovallyAIHub1 小时前
单目深度估计重大突破:无需标签,精度超越 SOTA!西湖大学团队提出多教师蒸馏新方案
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
从FCOS3D到PGD:看深度估计如何快速搭建你的3D检测项目
深度学习·算法·计算机视觉
偷偷的卷2 小时前
【算法笔记 day three】滑动窗口(其他类型)
数据结构·笔记·python·学习·算法·leetcode
北京地铁1号线2 小时前
Zero-Shot(零样本学习),One-Shot(单样本学习),Few-Shot(少样本学习)概述
人工智能·算法·大模型