python 绘制3D平面图

news/2025/6/19 18:16:59

函数介绍

ax3d.plot_surface( x, # 网格坐标矩阵的x坐标 (2维数组)

                               y, # 网格坐标矩阵的y坐标 (2维数组)

                               z, # 网格坐标矩阵的z坐标 (2维数组)

                               rstride=30, # 行跨距

                               cstride=30, # 列跨距

                               cmap='jet' # 配色方案 )

配色方案如下:

有很多配色方案不仅局限于下面的几种,可以根据需要设置不同方案

代码如下:

# 绘制3D平面图
# 三维曲面图:切分成很多小段,每段绘制一个小平面
import numpy as np
import matplotlib.pyplot as mp
from mpl_toolkits.mplot3d import Axes3D
n = 1000
# 生成网格化坐标矩阵
# np.linspace()函数用于在区间内生成n个数据
# meshgrid用于生成网格矩阵  
'''
例如 矩阵
有如下坐标点
(0,1) (1, 1) (2, 1) (1, 0) (1, 0) (1, 0)
那么生成的x矩阵为
0 1 2
1 1 1
y矩阵为
1 1 1 
0 0 0
'''
x, y = np.meshgrid(np.linspace(-3, 3, n), np.linspace(-3, 3, n))
# 根据每个网格点坐标,通过某个公式计算z高度坐标
z = (1 - x / 2 + x ** 5 + y ** 3) * np.exp(-x ** 2 - y ** 2)
mp.figure('3D', facecolor='lightgray')  # 创建画布
# matplotlib不同版本对应的projection的写法不同,可根据对应版本查询其不同的写法,当前matplotlib版本为3.5.2
ax3d = mp.gca(projection='3d')  # 获取坐标系
mp.title('3D Surface', fontsize=18) # 设置图形的名称和字体
ax3d.set_xlabel('x', fontsize=14)  # 设置x轴名称和名称的字体大小
ax3d.set_ylabel('y', fontsize=14)
ax3d.set_zlabel('z', fontsize=14)
# 绘制3D平面图
# rstride: 行跨距
# cstride: 列跨距
ax3d.plot_surface(x, y, z, rstride=30, cstride=30, cmap='jet') # jet配色方案,正数越大越红,越小越蓝
mp.show()


https://dhexx.cn/news/show-5524796.html

相关文章

流程引擎选型指南

流程引擎选型指南 流程引擎是企业实现业务流程自动化(BPM)的核心组件,选择合适的流程引擎对系统架构和未来发展至关重要。以下是主流流程引擎的综合对比和选型建议。 一、主流流程引擎对比 引擎名称开源/商业BPMN支持DMN支持CMMN支持云原生支持社区活跃度学习曲线…

【T2I】Controllable Generation with Text-to-ImageDiffusion Models: A Survey

code: 2403 GitHub - PRIV-Creation/Awesome-Controllable-T2I-Diffusion-Models: A collection of resources on controllable generation with text-to-image diffusion models. Abstract 在快速发展的视觉生成领域,扩散模型带来了革命性的变化&#…

MCP Server Tool 开发学习文档

MCP Server Tool 开发学习文档 目录 MCP Server Tool 简介核心开发流程与知识点详解 2.1 工具函数的实现2.2 MCP Server 的注册与启动2.3 工具注册与调用机制2.4 工具列表的声明与返回2.5 传输方式(stdio 与 sse) Python 源码详细解析SSE 方式本地部署…

自制操作系统day8 (鼠标数据取得、通往32位模式之路、A20GATE、切换到保护模式、控制寄存器cr0-cr4以及cr8、ALIGNB)

day8 鼠标数据取得方法 fifo8_init(&mousefifo, 128, mousebuf); for (;;) { io_cli(); if (fifo8_status(&keyfifo) fifo8_status(&mousefifo) 0) { io_stihlt(); } else { if (fifo8_status(&keyfifo) ! 0) { i fifo8_get(&keyfifo); io_sti(); spr…

upload-labs靶场通关详解:第14关

一、分析源代码 这一关的任务说明已经相当于给出了答案,就是让我们上传一个图片木马,可以理解为图片中包含了一段木马代码。 function getReailFileType($filename){$file fopen($filename, "rb");$bin fread($file, 2); //只读2字节fclose…

ganache-ui使用

文章目录 概要下载ganache配合truffle使用连接metamask 概要 下载ganache 下载:https://github.com/trufflesuite/ganache-ui/releases 配合truffle使用 新建new workspace 添加项目,找到truffle项目的config.js文件 配置服务端口和网络id 其他默…

Java基础 Day18

一、集合的分类 1、单列集合 一次添加一个元素,实现了 Collection 接口 (1)List 接口的实现类 存取有序、有索引、可以存储重复的 (2)Set 接口的实现类 存取无序、没有索引、不可以存储重复的 2、双列集合 一次…

git merge解冲突后,add、continue提交

git merge解冲突后,add、continue提交 git merge操作冲突后,需要手动解冲突,解完冲突后,需要: git add . 然后,进入一般的正常git代码提交流程。 git合并‘merge’其他分支的个别文件到当前branch_gitbash 合并branc…

PostgreSQL 14 pacemaker 高可用集群

核心架构原理 集群组成(典型三节点结构): [Node1] PostgreSQL Pacemaker Corosync pcsd [Node2] PostgreSQL Pacemaker Corosync pcsd [Node3] PostgreSQL Pacemaker Corosync pcsd ↕ ↕ ↕ ← Corosync 多…

浅谈测试驱动开发TDD

目录 1.什么是TDD 2.TDD步骤 3.TDD 的核心原则 4.TDD 与传统开发的对比 5.TDD中的单元测试和集成测试区别 6.总结 1.什么是TDD 测试驱动开发(Test-Driven Development,简称 TDD) 是一种软件开发方法论,核心思想是 “先写测试…