利用python画一颗心的方法示例


Posted in Python onJanuary 31, 2017

前言

Python一般使用Matplotlib制作统计图形,用它自己的说法是‘让简单的事情简单,让复杂的事情变得可能'。用它可以制作折线图,直方图,条形图,散点图,饼图,谱图等等你能想到的和想不到的统计图形,这些图形可以导出为多种具有出版质量的格式。此外,它和ipython结合使用,确实方便,谁用谁知道!本文将介绍利用python中的matplotlib画一颗心,感兴趣的朋友们下面来一起看看吧。

安装matplotlib

首先要安装matplotlib

pip install matplotlib

windows用户可以去官网下载安装。官网看到matpltlib的作者John Hunter (1968-2012)刚去世不久,在此感谢他创造了这样一个强大的绘图工具。

上代码

#!/usr/bin/env python3
from mpl_toolkits.mplot3d import Axes3D
from matplotlib import cm
from matplotlib.ticker import LinearLocator, FormatStrFormatter
import matplotlib.pyplot as plt
import numpy as np


def heart_3d(x,y,z):
 return (x**2+(9/4)*y**2+z**2-1)**3-x**2*z**3-(9/80)*y**2*z**3


def plot_implicit(fn, bbox=(-1.5, 1.5)):
 ''' create a plot of an implicit function
 fn ...implicit function (plot where fn==0)
 bbox ..the x,y,and z limits of plotted interval'''
 xmin, xmax, ymin, ymax, zmin, zmax = bbox*3
 fig = plt.figure()
 ax = fig.add_subplot(111, projection='3d')
 A = np.linspace(xmin, xmax, 100) # resolution of the contour
 B = np.linspace(xmin, xmax, 40) # number of slices
 A1, A2 = np.meshgrid(A, A) # grid on which the contour is plotted

 for z in B: # plot contours in the XY plane
  X, Y = A1, A2
  Z = fn(X, Y, z)
  cset = ax.contour(X, Y, Z+z, [z], zdir='z', colors=('r',))
  # [z] defines the only level to plot
  # for this contour for this value of z

 for y in B: # plot contours in the XZ plane
  X, Z = A1, A2
  Y = fn(X, y, Z)
  cset = ax.contour(X, Y+y, Z, [y], zdir='y', colors=('red',))

 for x in B: # plot contours in the YZ plane
  Y, Z = A1, A2
  X = fn(x, Y, Z)
  cset = ax.contour(X+x, Y, Z, [x], zdir='x',colors=('red',))

 # must set plot limits because the contour will likely extend
 # way beyond the displayed level. Otherwise matplotlib extends the plot limits
 # to encompass all values in the contour.
 ax.set_zlim3d(zmin, zmax)
 ax.set_xlim3d(xmin, xmax)
 ax.set_ylim3d(ymin, ymax)

 plt.show()

if __name__ == '__main__':
 plot_implicit(heart_3d)

效果是这个样子,挺有意思的:

利用python画一颗心的方法示例

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用python能带来一定的帮助,如果有疑问大家可以留言交流。

Python 相关文章推荐
python 实现插入排序算法
Jun 05 Python
Python中使用partial改变方法默认参数实例
Apr 28 Python
用Python计算三角函数之acos()方法的使用
May 15 Python
python中的全局变量用法分析
Jun 09 Python
使用C#配合ArcGIS Engine进行地理信息系统开发
Feb 19 Python
Python2和Python3.6环境解决共存问题
Nov 09 Python
使用pycharm设置控制台不换行的操作方法
Jan 19 Python
对python:循环定义多个变量的实例详解
Jan 20 Python
python3.7 使用pymssql往sqlserver插入数据的方法
Jul 08 Python
Flask使用Pyecharts在单个页面展示多个图表的方法
Aug 05 Python
Python+OpenCV实现图片中的圆形检测
Apr 07 Python
Python各协议下socket黏包问题原理
Apr 12 Python
利用Python脚本生成sitemap.xml的实现方法
Jan 31 #Python
利用python实现命令行有道词典的方法示例
Jan 31 #Python
Python爬虫包 BeautifulSoup  递归抓取实例详解
Jan 28 #Python
python 编程之twisted详解及简单实例
Jan 28 #Python
详解python之简单主机批量管理工具
Jan 27 #Python
Python下的Softmax回归函数的实现方法(推荐)
Jan 26 #Python
在Django同1个页面中的多表单处理详解
Jan 25 #Python
You might like
php中用于检测一个地理IP地址是否可用的代码
2012/02/19 PHP
PHP中fwrite与file_put_contents性能测试代码
2013/08/02 PHP
jquery.fileEveryWhere.js 一个跨浏览器的file显示插件
2011/10/24 Javascript
javascript中节点的最近的相关节点访问方法
2013/03/20 Javascript
JavaScript Array对象扩展indexOf()方法
2014/05/09 Javascript
javascript中substring()、substr()、slice()的区别
2015/08/30 Javascript
json格式数据的添加,删除及排序方法
2016/01/21 Javascript
Bootstrap框架下下拉框select搜索功能
2020/03/26 Javascript
JQuery中Ajax的操作完整例子
2017/03/07 Javascript
整理关于Bootstrap模态弹出框的慕课笔记
2017/03/29 Javascript
基于easyui checkbox 的一些操作处理方法
2017/07/10 Javascript
jQuery Ajax向服务端传递数组参数值的实例代码
2017/09/03 jQuery
JavaScript数组去重的多种方法(四种)
2017/09/19 Javascript
Vue+webpack项目基础配置教程
2018/02/12 Javascript
用Vue写一个分页器的示例代码
2018/04/22 Javascript
vue.js实现带日期星期的数字时钟功能示例
2018/08/28 Javascript
vue 项目接口管理的实现
2019/01/17 Javascript
vue 组件间的通信之子组件向父组件传值的方式
2020/07/29 Javascript
python中format()函数的简单使用教程
2018/03/14 Python
django如何连接已存在数据的数据库
2018/08/14 Python
Python图像处理之简单画板实现方法示例
2018/08/30 Python
python文字转语音实现过程解析
2019/11/12 Python
pip安装提示Twisted错误问题(Python3.6.4安装Twisted错误)
2020/05/09 Python
Scrapy 配置动态代理IP的实现
2020/09/28 Python
Ruby如何定义一个类
2012/10/08 面试题
自荐信不宜过于夸大
2013/11/06 职场文书
土木工程师职业规划范文
2014/03/07 职场文书
一位农村小子的自荐信
2014/04/07 职场文书
教导主任竞聘演讲稿
2014/05/16 职场文书
金融与证券专业求职信
2014/06/22 职场文书
农村党员学习党的群众路线教育实践活动心得体会
2014/11/04 职场文书
求职简历自我评价范文
2015/03/10 职场文书
行政处罚事先告知书
2015/07/01 职场文书
适合毕业生创业的项目怎么找?
2019/08/08 职场文书
python引入其他文件夹下的py文件具体方法
2021/05/23 Python
一次Mysql update sql不当引起的生产故障记录
2022/04/01 MySQL