• R语言--ggplot2包


    由于python中matplotlib包的画图功能比较基本,不怎么炫酷,所以想用R中的ggplot2来作图。用mysql作为数据中介,可以让python和R共享数据,这样数据处理起来能发挥各自优势,同时保持数据一致,而用R来做图也就方便很多了。

    原来在做数据可视化的时候用过ggplot2,不过没有系统学过,现在再学一遍。《ggplot2:数据分析与图形艺术》是一本全面的书,可以作为工具书。这次复习看的是知乎上的一个问题:

    https://www.zhihu.com/question/24779017

    上面的回答很精炼,谢谢所有答主。

    --

    首先是ggplot2的思想:

    • 作一张图就是将数据特点映射到点、线等几何对象的大小、颜色等属性上
    • 一张统计图还可能包含数据的统计变换(均值、方差等,stats),最后绘制在某个特定的坐标系(coord)中,还可能有分面(facet,将绘图窗口划分为若干子窗口)用来生成数据不同子集的图形
    • ggplot2的作图方式是按照图层作图,先设置一张“画布”,然后再向“画布”上添加一层一层的图层(会ps的同学会觉得很熟悉)

    几个概念:

    • 几何对象(geom_):代表在图中实际看到的图形元素,如点、线、多边形等
    • 图形属性(aes):横纵坐标、点的大小、颜色,填充色等
    • 统计变换(stat_):对数据进行的某种汇总与变换等
    • 标度(scale):其作用是将数据的取值映射到图形空间,例如用颜色、大小或形状来表示不同的取值。展现标度的常见做法是绘制图例和坐标轴--他们实际上是从图形到数据的一个映射,使读者可以从图形中读取原始数据
    • 坐标系(coord):描述了数据时如何映射到图形所在的平面的,它同时提供了看图所需的坐标轴和网格线
    • 分面(facet):描述了如何将数据分解为各个子集,以及如何对子集作图并联合进行展示。

    书上说的作图语法的局限性:

    • 对于感兴趣的问题,并不指出应该采用什么图形来进行展示,语法只能提供关于作图流程的说明,并不能告诉你作什么图合适
    • 语法并不规定图形的外观是怎样的,应该根据经验确定
    • 并没有交互式操作,ggplot2只能绘制静态图形(?)想绘制交互式图形需要看其他文献

    一个小例子:

    library(ggplot2)   #加载包
    
    x <- rnorm(100,14,5) #生成100个均值为14,方差为5正态分布随机数
    
    y <- x + rnorm(100,0,1
    )
    p <- ggplot(data = NULL) + aes(x = x,y = y) #创建“画布”
    
    #下面是添加点,这里是添加几何对象点,color就是图形属性,+号就是添加一个图层
    
    p <- p + geom_point(color = "darkred")
    
    #在添加一个图层,添加注释
    
    p <- p + annotate("text",x =13 , y = 20,parse = T,label = "x[1] == x[2]")
    
    #展示图形
    
    print(p)
  • 相关阅读:
    OpenCV 笔记 (C++模板template)
    C++中预定义的运算符的操作对象只能是基本的数据类型
    linux-CentOS6.4下安装oracle11g详解
    Eclipse 连接MySql数据库总结
    六个创建模式之单例模式(Singleton Pattern)
    六个创建模式之抽象工厂模式(Abstract Factory Pattern)
    六个创建模式之工厂方法模式(Factory Method Pattern)
    六个创建模式之简单工厂模式(Simple Factory Pattern)
    搜狗实习面试
    Java设计模式 -- 基本原则
  • 原文地址:https://www.cnblogs.com/batteryhp/p/5232353.html
Copyright © 2020-2023  润新知