Python数据可视化:幂律分布实例详解


Posted in Python onDecember 07, 2019

1、公式推导

对幂律分布公式:

Python数据可视化:幂律分布实例详解

对公式两边同时取以10为底的对数:

Python数据可视化:幂律分布实例详解

Python数据可视化:幂律分布实例详解

所以对于幂律公式,对X,Y取对数后,在坐标轴上为线性方程。

2、可视化

从图形上来说,幂律分布及其拟合效果:

Python数据可视化:幂律分布实例详解

对X轴与Y轴取以10为底的对数。效果上就是X轴上1与10,与10与100的距离是一样的。

Python数据可视化:幂律分布实例详解

对XY取双对数后,坐标轴上点可以很好用直线拟合。所以,判定数据是否符合幂律分布,只需要对XY取双对数,判断能否用一个直线很好拟合就行。常见的直线拟合效果评估标准有拟合误差平方和、R平方。

3、代码实现

#!/usr/bin/env python
# -*-coding:utf-8 -*-

import matplotlib.pyplot as plt
import numpy as np
from sklearn import linear_model
from scipy.stats import norm

def DataGenerate():
 X = np.arange(10, 1010, 10) # 0-1,每隔着0.02一个数据 0处取对数,会时负无穷 生成100个数据点
 noise=norm.rvs(0, size=100, scale=0.2) # 生成50个正态分布 scale=0.1控制噪声强度
 Y=[]
 for i in range(len(X)):
  Y.append(10.8*pow(X[i],-0.3)+noise[i]) # 得到Y=10.8*x^-0.3+noise

 # plot raw data
 Y=np.array(Y)
 plt.title("Raw data")
 plt.scatter(X, Y, color='black')
 plt.show()

 X=np.log10(X) # 对X,Y取双对数
 Y=np.log10(Y)
 return X,Y

def DataFitAndVisualization(X,Y):
 # 模型数据准备
 X_parameter=[]
 Y_parameter=[]
 for single_square_feet ,single_price_value in zip(X,Y):
  X_parameter.append([float(single_square_feet)])
  Y_parameter.append(float(single_price_value))

 # 模型拟合
 regr = linear_model.LinearRegression()
 regr.fit(X_parameter, Y_parameter)
 # 模型结果与得分
 print('Coefficients: \n', regr.coef_,)
 print("Intercept:\n",regr.intercept_)
 # The mean square error
 print("Residual sum of squares: %.8f"
  % np.mean((regr.predict(X_parameter) - Y_parameter) ** 2)) # 残差平方和

 # 可视化
 plt.title("Log Data")
 plt.scatter(X_parameter, Y_parameter, color='black')
 plt.plot(X_parameter, regr.predict(X_parameter), color='blue',linewidth=3)

 # plt.xticks(())
 # plt.yticks(())
 plt.show()

if __name__=="__main__":
 X,Y=DataGenerate()
 DataFitAndVisualization(X,Y)

Python数据可视化:幂律分布实例详解

Python数据可视化:幂律分布实例详解

以上这篇Python数据可视化:幂律分布实例详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python使用自定义user-agent抓取网页的方法
Apr 15 Python
Python控制多进程与多线程并发数总结
Oct 26 Python
Python中super函数的用法
Nov 17 Python
python+django+sql学生信息管理后台开发
Jan 11 Python
numpy创建单位矩阵和对角矩阵的实例
Nov 29 Python
关于初始种子自动选取的区域生长实例(python+opencv)
Jan 16 Python
Python类继承和多态原理解析
Feb 05 Python
tensorflow实现读取模型中保存的值 tf.train.NewCheckpointReader
Feb 10 Python
python 成功引入包但无法正常调用的解决
Mar 09 Python
python轮询机制控制led实例
May 03 Python
Python xlrd/xlwt 创建excel文件及常用操作
Sep 24 Python
如何利用python发送邮件
Sep 26 Python
Python数据可视化:泊松分布详解
Dec 07 #Python
python-numpy-指数分布实例详解
Dec 07 #Python
Python Sympy计算梯度、散度和旋度的实例
Dec 06 #Python
python实现输入的数据在地图上生成热力图效果
Dec 06 #Python
python 画3维轨迹图并进行比较的实例
Dec 06 #Python
解决pyshp UnicodeDecodeError的问题
Dec 06 #Python
python创建ArcGIS shape文件的实现
Dec 06 #Python
You might like
PHP 金额数字转换成英文
2010/05/06 PHP
FirePHP 推荐一款PHP调试工具
2011/04/23 PHP
discuz免激活同步登入代码修改方法(discuz同步登录)
2013/12/24 PHP
php读取csc文件并输出
2015/05/21 PHP
Centos PHP 扩展Xchche的安装教程
2016/07/09 PHP
js不是基础的基础
2006/12/24 Javascript
jquery 输入框数字限制插件
2009/11/10 Javascript
一个背景云变换js特效 鼠标移动背景云变化
2012/12/28 Javascript
js中自定义方法实现停留几秒sleep
2014/07/11 Javascript
node.js中的fs.writeSync方法使用说明
2014/12/15 Javascript
详解JS模块导入导出
2017/12/20 Javascript
详解webpack打包后如何调试的方法步骤
2018/11/07 Javascript
layui前端时间戳转化实例
2019/11/15 Javascript
iSlider手机端图片滑动切换插件使用详解
2019/12/24 Javascript
[02:09]EHOME夺得首届辉夜杯冠军—现场颁奖仪式
2015/12/28 DOTA
python输入错误密码用户锁定实现方法
2017/11/27 Python
python机器学习案例教程——K最近邻算法的实现
2017/12/28 Python
Python tornado队列示例-一个并发web爬虫代码分享
2018/01/09 Python
Python排序算法之选择排序定义与用法示例
2018/04/29 Python
详解有关PyCharm安装库失败的问题的解决方法
2020/02/02 Python
python3 使用openpyxl将mysql数据写入xlsx的操作
2020/05/15 Python
浅谈Selenium+Webdriver 常用的元素定位方式
2021/01/13 Python
CSS类名支持中文命名的示例
2014/04/04 HTML / CSS
一款利用css3的鼠标经过动画显示详情特效的实例教程
2014/12/29 HTML / CSS
CSS3 Calc实现滚动条出现页面不跳动问题
2017/09/14 HTML / CSS
Agoda.com官方网站:便宜预订全球酒店,高达80%的折扣
2018/04/04 全球购物
澳洲女装时尚在线:Blue Bungalow
2018/05/05 全球购物
应聘收银员个人的求职信
2013/11/30 职场文书
电子专业毕业生自我鉴定
2014/01/22 职场文书
yy生日主持词
2014/03/20 职场文书
个人求职信范文
2014/05/24 职场文书
手把手教你制定暑期学习计划,让你度过充实的暑假
2019/08/22 职场文书
详解Nginx 工作原理
2021/03/31 Servers
Redis可视化客户端小结
2021/06/10 Redis
bootstrapv4轮播图去除两侧阴影及线框的方法
2022/02/15 HTML / CSS
JS前端可视化canvas动画原理及其推导实现
2022/08/05 Javascript