首页 > 其他分享 >matplotlib作图不显示3D图,怎么办?

matplotlib作图不显示3D图,怎么办?

时间:2024-06-13 10:36:57浏览次数:21  
标签:theta2 loss theta1 作图 matplotlib plt grid w2 3D

大家好,我是Python进阶者。

一、前言

前几天在Python白银交流群【Kim】问了一个Python作图的问题,问题如下:他不显示3D图咋办?

代码如下:

from sklearn.linear_model import LogisticRegression
import numpy as np
from matplotlib import pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

# 加载数据
data = load_breast_cancer()
X, y = data['data'][:,:2], data['target']

# 求出两个维度对应的数据在逻辑回归算法下的最优解
lr = LogisticRegression(fit_intercept=False)    # 是否计算截距项
lr.fit(X, y)
# 分别把两个维度所对应的参数w1和w2取出来
theta1 = lr.coef_[0, 0]
theta2 = lr.coef_[0, 1]
print(theta1)
print(theta2)

def p_theta_function(features, w1, w2):
    """
    已知w1和w2的情况下,传进来数据X,返回数据的y_predict
    :param features:xi=(x1, x2)
    :param w1:
    :param w2:
    :return:  y_pred
    """
    # z = $\theta^Tx=w1*x1+w2*x2$
    z = w1 * features[0] + w2 * features[1]
    return 1 / (1 + np.exp(-z))

def loss_function(sample_features, sample_labels, w1, w2):
    """
    传入一份已知数据,如果已知w1和w2,计算对应这份数据的loss损失
    :param sample_features:
    :param sample_labels:
    :param w1:
    :param w2:
    :return:
    """
    result = 0
    # 遍历数据集中的每一条样本,并且计算每条样本的损失,加到result身上得到整体数据集
    for feature, label in zip(sample_features, sample_labels):
        # 计算一条样本的y_pred
        p_result = p_theta_function(feature, w1, w2)
        loss_result = -1 * label * np.log(p_result) - (1 - label) * np.log(1 - p_result)
        result += loss_result
    return result

theta1_space = np.linspace(theta1-0.6, theta1+0.6, 50)
theta2_space = np.linspace(theta2-0.6, theta2+0.6, 50)
result1 = np.array([loss_function(X, y, i, theta2) for i in theta1_space])
result2 = np.array([loss_function(X, y, theta1, i) for i in theta2_space])

fig1 = plt.figure(figsize=(8, 6))
plt.subplot(221)
plt.plot(theta1_space, result1)

plt.subplot(222)
plt.plot(theta2_space, result2)

plt.subplot(223)
theta1_grid, theta2_grid = np.meshgrid(theta1_space, theta2_space)
loss_grid = loss_function(X, y, theta1_grid, theta2_grid)
plt.contour(theta1_grid, theta2_grid, loss_grid)

plt.subplot(224)
plt. contour(theta1_grid, theta2_grid, loss_grid, 30)

fig2 = plt.figure()
ax = Axes3D(fig2)
ax.plot_surface(theta1_grid, theta2_grid, loss_grid)

plt.show()

二、实现过程

这里【莫生气】给了个思路如下:试试看windows下跑跑?

后来【瑜亮老师】给跑了出来,结果如下图所示:

image.png

总共有两张图。粉丝反馈确实有两张图,Mac机器下,平面图没问题,3d不行。后来发现是电脑配置太低了,加载需要时间,有时候有的电脑不一定出得来结果。

【瑜亮老师】的plt是3.5的。运行后会有一个提示,只是提醒版本的变化,图是能正常出的。后来发现Axes3D(fig) 的写法在plt3.6中就不能运行了,你的是3.9版本的所以无法出图。我的是3.5因此可以,但是提示版本更改。按照楼上大佬的代码,3.5也可以正常出图,且无提示。

如果你也有类似这种Python相关的小问题,欢迎随时来交流群学习交流哦,有问必答!

三、总结

大家好,我是Python进阶者。这篇文章主要盘点了一个Python正则表达式的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

最后感谢粉丝【Kim】提出的问题,感谢【瑜亮老师】给出的思路,感谢【莫生气】等人参与学习交流。

【提问补充】温馨提示,大家在群里提问的时候。可以注意下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。代码不多的话,直接发代码文字即可,代码超过50行这样的话,发个.py文件就行。

image.png

标签:theta2,loss,theta1,作图,matplotlib,plt,grid,w2,3D
From: https://www.cnblogs.com/dcpeng/p/18245345

相关文章

  • 如何低成本、高效搭建线上3D艺术展?
    随着数字技术的日新月异,艺术展览领域正迎来一场革新。未来的艺术展览将不再是单一的线下体验,而是线上线下相互融合,其中,3D线上展览将成为线下展览的重要延伸与拓展,为广大观众提供更多元化的选择。对于艺术家和策展人而言,3D线上展览不仅是一个全新的作品展示平台,更是一个突破时......
  • 中望ZW3D 二次开发 输出质量、体积等属性 cvxPartInqShapeMass
    svxPointP1={10,0,0};svxPointP2={20,0,0};svxPointP3={20,10,0};svxPointP4={10,10,0};intL1;cvxPartLine2pt(&P1,&P2,&L1);intL2;cvxPartLine2pt(&P2,&P3,&L2);intL3;cvxPartLine2pt(&P3,&P4,&......
  • 3dmax材质高清参数设置图
    3dsMax是一款在设计领域内非常受推崇的软件,以其强大的建模功能和丰富的材质库而知名。设计师可以通过调整材质的参数来制作出更加真实的渲染效果。本文将介绍一些技巧,教您如何通过简单的调整来优化3dsMax中的材质设置,从而增强作品的视觉效果。 3dmax材质高清参数设置1、清玻......
  • python-数据分析-Matplotlib-1-进阶图形(气泡图-面积图-雷达图-玫瑰图-3D图)
    气泡图#-*-coding:utf-8-*-#气泡图#气泡图可以用来了解三个变量之间的关系,通过比较气泡位置和大小来分析数据维度之间的相关性。#例如在我们之前绘制的月收入和网购支出的散点图中,我们已经发现了二者的正相关关系,如果我们引入第三个变量网购次数,那么我们就需要使用气泡图......
  • python-数据分析-Matplotlib-1-基础图形(曲线图-散点-柱状-堆叠柱状-饼状图-直方图)
    曲线图#-*-coding:utf-8-*-#基础、曲线图importnumpyimportmatplotlib.pyplotasplt#设置字体SimHei:黑体#需要注意的是,使用中文字体后坐标轴上的负号将会无法显示,需要将`axes.unicode_minus`参数设置为`False`,这样才能让坐标轴上的负号正常显示plt.rcParams['f......
  • 3D模型、轻量化、格式转换、可视化、数字孪生引擎等免费用!!
    老子云3D可视化快速开发平台,集云压缩、云烘焙、云存储云展示于一体,使3D模型资源自动输出至移动端PC端、Web端,能在多设备、全平台进行展示和交互,是全球领先、自主可控的自动化3D云引擎。老子云3D可视化与模型优化服务平台https://www.laozicloud.com/平台架构平台特性1......
  • 图形库使用 Direct3d
    1里面的数学矩阵是三角函数组合出来的旋转的时候xy两个变量距离变第三轴被影响角度2视锥远近四棱锥双剪切平面3三维点A点B点C点确定三位坐标,初始坐标是坐标中中心值x,y,z(0,0,0)4移动三维点点A到点B使用x加减y加减z加减5图片循环扫描整张图片6脚本着色器......
  • 中望ZW3D 二次开发 创建拉伸 cvxPartExtrude
    svxPointP1={0,0,0}; svxPointP2={10,0,0}; svxPointP3={10,10,0}; svxPointP4={0,10,0}; intL1; cvxPartLine2pt(&P1,&P2,&L1); intL2; cvxPartLine2pt(&P2,&P3,&L2); intL3; cvxPartLine2pt(&P3,&P......
  • 使用 ECharts 绘制3D饼图,立体效果华丽渲染!
    ✈️✈️✈️目录使用ECharts绘制3D饼图首先了解3D饼图的构成准备工作数据定义绘制一个三维饼图合并配置并初始化图表实践结语使用ECharts绘制3D饼图在数据可视化中,饼图是表达数据占比信息的常见方式。ECharts作为一个强大的数据可视化库,除了标准的二维饼图,也支持更......
  • 跟思兼学Klipper(30):使用辅助宏调整3D打印机无感归位堵转检测阈值
    又名《调整堵转检测阈值降低创想三维K1C打印机无感归位啪啪声》前言原创文章,转载引用务必著名链接,水平有限,如有疏漏,欢迎指正交流。文章如有更新请访问DFRobot社区及cnblogs博客园,前者内容较全,后者排版及阅读体验更佳。手中的创想三维K1C3D打印机目前使用很满意。如果......