热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Stata数据可视化:十幅精美图形的绘制

Stata数据可视化: 十幅精美图形的绘制

特别说明: 文中包含的链接在微信中无法生效。请点击本文底部左下角的【阅读原文】,转入本文【简书版】。

相关推文: 连享会-数据可视化系列推文

  • 普林斯顿Stata教程 - Stata做图
  • Stata绘图:bgshade - 在图形中加入经济周期阴影
  • Stata绘图: 添加虚线网格线
  • Stata: 一个干净整洁的 Stata 图形模板qlean
  • Stata: 用暂元统一改变图形中的字号
  • Stata-IE-Visual-Library 可视化
  • Stata:中文期刊风格的纯黑白图形
  • Stata绘图:重新定义坐标轴刻度标签
  • Stata可视化:让他看懂我的结果!
  • Stata连享会:动画 GIF 演示 OLS 的性质
  • Stata: 姑娘的生日礼物
  • Stata: Graphing Distributions
  • Stata:让图片透明——你不要掩盖我的光芒
  • Stata:用 bytwoway 实现快速分组绘图
  • 怎么在Stata图形中附加水平线或竖直线?
  • 用 Stata 制作教学演示动态图 GIF


Source: https://www.surveydesign.com.au/tipsgraphs.html
该网站提供了几十种 Stata 图形的绘制方法 (dofile)


Stata数据可视化: 十幅精美图形的绘制

编译:张晓明 (中国人民大学);连玉君(中山大学)

Stata 连享会: 知乎 | 简书 | 码云

下载 dofile: 连享会-十幅经典图形绘制.do (可右击另存,亦可在线查看)

1. 散点图:附加密度函数图和拟合线(Scatter Plot with Regression Results)

附加密度函数和拟合曲线的散点图能够更好地看清样本的概率分布,同时能够表示出参数估计的置信区间。

Stata数据可视化: 十幅精美图形的绘制


*-文件夹设定
cd D:\
mkdir myfigs
cd D:\myfigs  // 后文输出的图形自从存储于此处

*-----------
*- F1 散点图:附加密度函数和拟合曲线图绘制
*-----------

sysuse auto, clear 
version 9.2  //绘制这幅图的时候,需要加这条命令,后续版本的stata绘图命令的语法有所改变
keep if foreign
sort weight

gen weight2 = weight^2
regress mpg weight weight2
predict fit
predict se , stdp

#delimit ;
twoway 
  scatter mpg weight , pstyle(p3) ms(o) ||
  fn weight[3]  - 1000 * normden(x, `=fit[3]' , `=se[3]') ,
    range(`=fit[3] -5' `=fit[3] +5') horiz pstyle(p1) ||
  fn `=fit[3]' , range(`=weight[3]' `=weight[3]-1000*normden(0, se[3])')
    pstyle(p1) ||
  fn weight[17] - 1000 * normden(x, `=fit[17]', `=se[17]') ,
    range(`=fit[17]-5' `=fit[17]+5') horiz pstyle(p1) ||
  fn `=fit[17]', range(`=weight[17]' `=weight[17]-1000*normden(0, se[17])')
    pstyle(p1) ||
  fn weight[21] - 1000 * normden(x, `=fit[21]' , `=se[21]') ,
    range(`=fit[21] -7' `=fit[21] +7') horiz pstyle(p1) ||
  fn `=fit[21]', range(`=weight[21]' `=weight[21]-1000*normden(0, se[21])')
    pstyle(p1) ||
  line fit weight, clwidth(*2) legend(off) 
    ytitle(Miles per gallon) xtitle(Weight)
    title("Scatter with Regression Line and Confidence Interval Densities"
           , size(*0.8) margin(t=0 b=1.5) span) 
;
#delimit cr

*-保存图片
graph export "F1_Scatter_distribution.png", ///
      replace width(506) height(376) 


2. 三变量比例图 (triplot)

三变量比例图可以显示出三个变量之间的复杂的组合关系,三个变量比例的取值范围为1~100。

Stata数据可视化: 十幅精美图形的绘制


*----------------
*-F2 三变量比例图
*----------------

* Plots 3 variables (proportions or percentages) 
* the total of each to equal either 1 or 100

ssc install triplot, replace  // 下载命令

clear
input a1 a2 a3 str10 name 
      10 10  80  John
      80 10  10  Fred
      25 25  50  Jane
      90  5   5  Helen
      0   0 100  Ed
      50 25  25  Kate
      20 60  20  Michael
      25 25  50  Darren
      5  90   5  Samar
end

list

triplot a1  a2  a3,  ///
    mlabel(name) mlabcolor(black) mcolor(blue) ///
    mlabsize(*0.9) max(100) ///
	title("Opinion a1 a2 a3")
	
//保存图片
graph export "F2_triplot.png", ///
      replace width(506) height(376) 


3. 点图:图示政策效果(Stripplot)

如果将本例中的纵轴分组变量换成年份,则这幅图可以在倍分法回归分析之前,图示政策效果。

Stata数据可视化: 十幅精美图形的绘制


*--------
*-F3 点图 图示政策效果
*--------

ssc install stripplot, replace // 下载并更新命令
help stripplot // 查看帮助文件

sysuse bplong, clear
egen group = group(age sex), label

#d ;
stripplot bp*, bar over(when) 
   by(group, compact col(1) note("")) 
   yscale(reverse) 
   subtitle(, pos(9) ring(1) nobexpand 
              bcolor(none) placement(e)) 
   ytitle("") 
   xtitle("Blood pressure (mm Hg)") ;
#d cr 

//保存图片
graph export "F3_triplot.png", ///
      replace width(531) height(394) 


4. 雷达图\蜘蛛网图 (Radar Plot, Spider plots)

雷达图在市场营销和管理学中应用较为广泛,主要用于呈现某个对象的各方面特征的均衡度,正所谓 “尺有所短寸有所长”。

Stata数据可视化: 十幅精美图形的绘制


*-------------------	  
*-F4 雷达图\蜘蛛网图
*-------------------

ssc install radar, replace //下载外部命令
help radar //查看帮助文件

sysuse auto, clear
sort price 

#d ;
radar make turn mpg trunk in 1/20,  
   aspect(1) 
   title(Nice Radar graph, size(*0.6)) 
   lc(red blue green)  
   lw(*1 *2 *4) rlabel(0 12 14 18 50) labsize(*0.7) 
   legend(label(1 "mpg-油效(英里/加仑)") 
          label(2 "turn-转弯半径(英尺)")
		  label(3 "trunk-后备箱容积(立方英尺)")
		  col(1) size(*.8)) ;
#d cr

//保存图片   
graph export "F4_radar_plot.png", ///
      replace width(431) height(394)


5. 快捷诊断图(Sixplot)

快捷诊断图针对一个变量提供了六幅分析性的、描述性的图片

Stata数据可视化: 十幅精美图形的绘制


*-------------- 
*-F5 快捷诊断图
*--------------

*-Goal: Displays six diagnostic and descriptive graphs for a single variable

ssc install sixplot //下载命令

sysuse uslifeexp.dta
sixplot le_male

//保存图片
graph export "F5_sixplot.png", ///
      replace width(431) height(394) 


6. 箱形图 (Box Plot)

箱形图又称为盒须图、盒式图或箱线图,是一种用作显示一组数据分散情况资料的统计图。因形状如箱子而得名。在各种领域也经常被使用,常见于品质管理。它主要用于反映原始数据分布的特征,还可以进行多组数据分布特征的比较。

Stata数据可视化: 十幅精美图形的绘制


*-----------	  
*-F6 箱形图
*-----------

sysuse nlsw88, clear

clonevar wagelog10 = wage
replace  wagelog10 = log10(wagelog10)

mylabels 0(10)40 , myscale(log10(@)) local(labels)

#d ;
graph hbox wagelog10, 
  over(ind, sort(1)) nooutside 
  ytitle("") ylabel(`labels') 
  title("Hourly wage, 1988, woman aged 34-46", span) 
  subtitle(" ") 
  note("Source:1988 data from NLS, U.S. Dept. of Labor, "
       "Bureau of Labor Statistics", span) ;
#d cr 

//保存图片
graph export "F6_box_plot.png", ///
      replace width(431) height(394)


7. 小提琴图(Violin Plot)

小提琴图 (Violin Plot) 用于显示数据分布及其概率密度。这种图表结合了箱形图和密度图的特征,主要用来显示数据的分布形状。中间的黑
色粗条表示四分位数范围,从其延伸的幼细黑线代表 95% 置信区间,而白点则为中位数。

Stata数据可视化: 十幅精美图形的绘制


*------------	
*-F7 小提琴图
*------------

ssc install vioplot // 下载外部命令
help vioplot // 查看帮助文件

sysuse auto, clear

vioplot mpg, over(rep78) horizontal name(myplot) ///
   title("Violin Plot of Mileage") ///
   subtitle("By repair record")    ///
   ytitle(Repair Record) ///
   ylab(, angle(horiz))  ///
   scheme(s2mono)

//保存图片   
graph export "F7Violin_plot.png", ///
      replace width(431) height(394) 


8. 热图绘制(Heat Map)

热图通过平面二维坐标加上不同区域颜色的变化表达了三维信息,热图中横坐标与纵坐标给出了数据的特征,**热图的颜色表示了该数据在整体中的概率密度分布。 **

Stata数据可视化: 十幅精美图形的绘制


*------------  
*-F8 热图绘制
*------------

ssc install spgrid, replace

ssc install spkde, replace

ssc install mylabels, replace //下载外部命令

sysuse "auto.dta", clear
set more off

summarize price mpg
clonevar x = mpg
clonevar y = price
replace x = (x-0)/(50-0)
replace y = (y-0)/(20000-0)

mylabels 0(10)50, myscale((@-0)/(50-0)) local(XLAB)
mylabels 0(5000)20000, myscale((@-0)/(20000-0)) local(YLAB)
keep x y
save "xy.dta", replace

* 1. Generate a 100x100 grid

spgrid, shape(hexagonal) xdim(100)    ///
xrange(0 1) yrange(0 1)               ///
dots replace                          ///
cells("2D-GridCells.dta")             ///
points("2D-GridPoints.dta")

* 2. Estimate the bivariate probability density function

spkde using "2D-GridPoints.dta",    ///
xcoord(x) ycoord(y)                 ///
bandwidth(fbw) fbw(0.1) dots        ///
saving("2D-Kde.dta", replace)

use "2D-Kde.dta", clear

merge 1:1 _n using xy.dta

twoway (contour p  spgrid_ycoord spgrid_xcoord  if p!=0 , ///
levels(15))                                               ///
(scatter y x, mcolor(black) msize(small) )                ///
,xlab(`XLAB', nogrid) xtitle("Mileage (mpg)")             ///
ylab(`YLAB', nogrid)                                      ///
ytitle("Price $US") plotregion(color(blue))

graph export "F8Heat_Map.png", replace width(431) height(394)


9. 棘状图绘制(Spine Plot)

棘状图的原理和条件密度图非常相似,都展示了给定某个自变量的情况下因变量的概率分布,但是棘状图首先对连续型的自变量进行了离散化处理,然后再离散区间内计算因变量的条件分布。除此之外,棘状图还兼顾了自变量的分布,在横轴方向上以不同宽度的矩形表示自变量的分布密度。

Stata数据可视化: 十幅精美图形的绘制


*--------------
*-F9 棘状图绘制
*---------------

sysuse auto, clear

replace rep78=0 if missing(rep78) 

bysort foreign rep78 : gen N   = _N
bysort foreign       : gen Na1 = (N/_N)*100

by foreign : gen N1 = string(Na1,"%5.2f") +"%"

label define kk 0 "missing",
label values rep78 kk

spineplot rep78 foreign, ///
   bar1(bcolor(gs14))    ///
   percent missing       ///
   bar2(bcolor(gs11))    ///
   bar3(bcolor(gs8))     ///
   bar4(bcolor(gs5))     ///
   bar5(bcolor(gs2))     ///
   bar6(bcolor(red)) text(N1)

graph export "F9Spine_Plot.png", ///
      replace width(431) height(394)


10. 中心条形图(Centred Bar Plot)

中心条形图经常被用在社会学统计分析中,中心的条块经常用来显示不同层次或年龄群体在横坐标对应的分类中的频率。

Stata数据可视化: 十幅精美图形的绘制


*---------------- 
*-F10 中心条形图
*---------------- 

ssc install cbarplot, replace 

clear
input levels freqcores freqblanks freqtools
    25 21  32   70
    24 36  52   115
    23 126 650  549
    22 159 2342 1633
    21 75  487  511
    20 176 1090 912
    19 132 713  578
    18 46  374  266
    17 550 6182 1541
    16 76  846  349
    15 17  182  51
    14 4   51   14
    13 29  228  130
    12 135 2227 729
end

reshape long freq, i(levels) j(kind) string

*-绘图
cbarplot levels kind [fw=freq], percent(levels) mlabsize(*.6)

*-保存图片
graph export "F10Centred_Bar_Plot.png", ///
      replace width(431) height(394)

下载 dofile: 连享会-十幅经典图形绘制.do (可右击另存,亦可在线查看)

Stata数据可视化: 十幅精美图形的绘制

关于我们

  • Stata 连享会(公众号:StataChina)】由中山大学连玉君老师团队创办,旨在定期与大家分享 Stata 应用的各种经验和技巧。
  • 公众号推文同步发布于 CSDN-Stata连享会 、简书-Stata连享会 和 知乎-连玉君Stata专栏。可以在上述网站中搜索关键词StataStata连享会后关注我们。
  • 点击推文底部【阅读原文】可以查看推文中的链接并下载相关资料。
  • Stata连享会 精品专题 || 精彩推文

联系我们

  • 欢迎赐稿: 欢迎将您的文章或笔记投稿至Stata连享会(公众号: StataChina),我们会保留您的署名;录用稿件达五篇以上,即可免费获得 Stata 现场培训 (初级或高级选其一) 资格。
  • 意见和资料: 欢迎您的宝贵意见,您也可以来信索取推文中提及的程序和数据。
  • 招募英才: 欢迎加入我们的团队,一起学习 Stata。合作编辑或撰写稿件五篇以上,即可免费获得 Stata 现场培训 (初级或高级选其一) 资格。
  • 联系邮件: [email protected]

往期精彩推文

  • Stata连享会推文列表
  • Stata连享会 精品专题 || 精彩推文

Stata数据可视化: 十幅精美图形的绘制


Stata数据可视化: 十幅精美图形的绘制


推荐阅读
  • 利用python爬取豆瓣电影Top250的相关信息,包括电影详情链接,图片链接,影片中文名,影片外国名,评分,评价数,概况,导演,主演,年份,地区,类别这12项内容,然后将爬取的信息写入Exce ... [详细]
  • C++ 开发实战:实用技巧与经验分享
    C++ 开发实战:实用技巧与经验分享 ... [详细]
  • MySQL 5.7 学习指南:SQLyog 中的主键、列属性和数据类型
    本文介绍了 MySQL 5.7 中主键(Primary Key)和自增(Auto-Increment)的概念,以及如何在 SQLyog 中设置这些属性。同时,还探讨了数据类型的分类和选择,以及列属性的设置方法。 ... [详细]
  • javascript分页类支持页码格式
    前端时间因为项目需要,要对一个产品下所有的附属图片进行分页显示,没考虑ajax一张张请求,所以干脆一次性全部把图片out,然 ... [详细]
  • PTArchiver工作原理详解与应用分析
    PTArchiver工作原理及其应用分析本文详细解析了PTArchiver的工作机制,探讨了其在数据归档和管理中的应用。PTArchiver通过高效的压缩算法和灵活的存储策略,实现了对大规模数据的高效管理和长期保存。文章还介绍了其在企业级数据备份、历史数据迁移等场景中的实际应用案例,为用户提供了实用的操作建议和技术支持。 ... [详细]
  • 如何将TS文件转换为M3U8直播流:HLS与M3U8格式详解
    在视频传输领域,MP4虽然常见,但在直播场景中直接使用MP4格式存在诸多问题。例如,MP4文件的头部信息(如ftyp、moov)较大,导致初始加载时间较长,影响用户体验。相比之下,HLS(HTTP Live Streaming)协议及其M3U8格式更具优势。HLS通过将视频切分成多个小片段,并生成一个M3U8播放列表文件,实现低延迟和高稳定性。本文详细介绍了如何将TS文件转换为M3U8直播流,包括技术原理和具体操作步骤,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • ClassList对象学习心得与表单事件非空校验技巧
    ClassList对象学习心得与表单事件非空校验技巧 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 体积小巧的vsftpd与pureftpd Docker镜像在Unraid系统中的详细配置指南:支持TLS加密及IPv6协议
    本文详细介绍了如何在Unraid系统中配置体积小巧的vsftpd和Pure-FTPd Docker镜像,以支持TLS加密和IPv6协议。通过这些配置,用户可以实现安全、高效的文件传输服务,适用于各种网络环境。配置过程包括镜像的选择、环境变量的设置以及必要的安全措施,确保了系统的稳定性和数据的安全性。 ... [详细]
  • 在 CentOS 6.5 系统上部署 VNC 服务器的详细步骤与配置指南
    在 CentOS 6.5 系统上部署 VNC 服务器时,首先需要确认 VNC 服务是否已安装。通常情况下,VNC 服务默认未安装。可以通过运行特定的查询命令来检查其安装状态。如果查询结果为空,则表明 VNC 服务尚未安装,需进行手动安装。此外,建议在安装前确保系统的软件包管理器已更新至最新版本,以避免兼容性问题。 ... [详细]
  • 结城浩(1963年7月出生),日本资深程序员和技术作家,居住在东京武藏野市。他开发了著名的YukiWiki软件,并在杂志上发表了大量程序入门文章和技术翻译作品。结城浩著有30多本关于编程和数学的书籍,其中许多被翻译成英文和韩文。 ... [详细]
  • 本章介绍了TCP/IP协议族中的链路层,其主要功能是为IP模块发送和接收IP数据报。链路层还支持一些辅助性协议,如ARP。此外,本文详细探讨了不同类型的链路层技术及其应用。 ... [详细]
  • 今天已经下载了 Visual Studio 2005 Beta 2 标准版,目前正在尝试安装,但似乎遇到了一些问题,安装未能成功。将进一步排查原因。该版本支持 .NET Framework 2.0.41202。 ... [详细]
  • 计算机视觉领域介绍 | 自然语言驱动的跨模态行人重识别前沿技术综述(上篇)
    本文介绍了计算机视觉领域的最新进展,特别是自然语言驱动的跨模态行人重识别技术。上篇内容详细探讨了该领域的基础理论、关键技术及当前的研究热点,为读者提供了全面的概述。 ... [详细]
author-avatar
小赖小燕_380
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有