码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 如何在分面中添加数学表达式标签?


    简介

    最近自己论文中需要绘制不同公式得到结果的分面图,并且在标签中给出表达式。对于这样的需求,一时半会想不出来。经过一顿搜索,得到了以下不错的解决方案。

    关于分面的基础教程可见以前写的推文:R可视乎|分面一页多图。拓展的技巧可见:xxx。老俊俊的生信笔记也给出了几篇不错的分面技巧介绍:使用 jjAnno 对分面添加注释;ggplot2 如何在不同分面添加不同文字;ggplot2 如何在不同分面添加不同图形。

    构建模拟数据

    老样子,给出模拟数据,读者根据自己数据进行转换即可。

    # 相关包
    library(ggplot2)
    library(grid)
    mydf <- data.frame(letter = factor(rep(c("A", "B", "C", "D"), each = 20)), x = rnorm(80), y = rnorm(80))
    head(mydf)
    
    • 1
    • 2
    • 3
    • 4
    • 5

    基本绘图

    简单绘制出数据 x,y 之间的散点图和拟合曲线,并根据分类数据 letter 进行分面。

    ggplot(mydf, aes(x = x, y = y)) + 
      geom_smooth(method = "lm") + 
      geom_point() + 
      facet_wrap(~ letter)
    
    • 1
    • 2
    • 3
    • 4

    设置表达式标签

    使用 expression() 函数定义表达式标签,存储到 f_names。并定义 f_labeller 提取 f_names 中的值。之后在分面中使用参数 labeller = f_labeller。

    当然,也可以使用 latex2exp 包中的 TeX(), 用类似 LeTeX 语句写表达式。例如:TeX("$\\alpha_2$")。

    f_names <- list('A' = expression(paste(alpha[2])), 'B' = expression(Gamma(3,4)), 'C' = expression(paste(y = beta[0] + beta[1]*x[1])), 'D' = expression(delta))
    f_labeller <- function(variable, value){return(f_names[value])}
    ggplot(mydf, aes(x = x, y = y)) + 
      geom_smooth(method = "lm") + 
      geom_point() + 
      facet_wrap(~ letter, labeller = f_labeller)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    修改主题

    ggplot(mydf, aes(x = x, y = y)) + 
      geom_smooth(method = "lm",color = "#e99e9c",fill = "#98c0d7") + 
      geom_point(color = "gray60") + 
      facet_wrap(~ letter, labeller = f_labeller,scales = "free") +
      theme_bw() + ylab("Value") + xlab("Time") + #主题设置
      theme(panel.grid = element_blank(), 
            strip.background = element_blank()) 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    添加中文标签

    加入想要添加中文标签,只需修改:

    # 设置标签
    f_names <- list('A' = expression(paste(alpha[2])), 'B' = expression(Gamma(3,4)), 'C' = expression(paste(y = beta[0] + beta[1]*x[1])), 'D' = expression(delta))
    f_names <- list('A' = "庄闪闪", 'B' = "庄亮亮", 
                    'C' = "庄晶晶", 'D' = "庄暗暗")
    
    • 1
    • 2
    • 3
    • 4

    如果存在中文字体乱码,请参考这篇推文:R问题|解决PDF导出字体无法显示的问题。即在文中前面加入以下代码:

    library(showtext)
    showtext.auto()
    
    • 1
    • 2

    此时绘制出来的结果如下:

  • 相关阅读:
    Isito 入门(四):微服务可观测性
    包 package
    如何实现多任务管理
    Spring中的IOC控制Mybatis案例
    go实战(1)-hello,world与包基础(1)-模块基础
    Something went wrong trying to start the trace - check the logs.
    项目(智慧教室)第四部分,页面交互功能,WebServer建立与使用,
    C++ 继承
    Leetcode152. 连续子数组的最大乘积
    WPF调用webapi并展示数据(二):类库实体类的构建
  • 原文地址:https://blog.csdn.net/qq_37379316/article/details/126023019
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号