当前位置: 首页 > article >正文

【R语言编程绘图-函数篇】

基础函数绘制

R语言可通过curve()函数直接绘制数学函数图形,无需预先生成数据点。例如绘制正弦函数:

curve(sin, from = -pi, to = pi, col = "blue", lwd = 2)

自定义函数绘制

对于用户自定义函数,需先定义函数表达式:

my_function <- function(x) x^2 + 2*x + 1
curve(my_function, from = -5, to 5, n = 1000)

多函数叠加绘制

使用add = TRUE参数可在同一图形上叠加多个函数:

curve(sin, -pi, pi, col = "red")
curve(cos, -pi, pi, col = "blue", add = TRUE)

参数化函数绘制

处理含参数的函数时,可通过匿名函数传递参数:

a <- 2
curve(function(x) a*sin(x), 0, 2*pi)

离散点绘制法

对于无法用表达式表示的函数,可生成离散点后绘图:

x <- seq(-3, 3, length.out = 100)
y <- dnorm(x)  # 标准正态分布密度函数
plot(x, y, type = "l")

图形定制技巧

通过图形参数增强可视化效果:

curve(exp, -2, 2, main = "Exponential Function",xlab = "Input", ylab = "Output",col = "darkgreen", lty = 2)
grid()  # 添加网格线

特殊函数绘制

统计分布函数可直接调用:

curve(dnorm, -3, 3)  # 正态分布密度
curve(pnorm, -3, 3)  # 正态分布累积概率

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# 设置随机种子
set.seed(123)# 定义x值范围
x <- seq(-10, 10, length.out = 200)# 设置图形布局为3行4列
par(mfrow = c(2, 2), mar = c(4, 4, 2, 2))  # 调整边距# 1. 线性函数
y1 <- 2 + 0.5 * x
plot(x, y1, type = "l", col = "blue", lwd = 2, main = "Linear Function", xlab = "x", ylab = "y")# 2. 多项式函数
y2 <- 2 + 0.5 * x + 0.1 * x^2
plot(x, y2, type = "l", col = "red", lwd = 2, main = "Polynomial Function", xlab = "x", ylab = "y")# 3. 指数函数
y3 <- 2 * exp(0.3 * x)
plot(x, y3, type = "l", col = "green", lwd = 2, main = "Exponential Function", xlab = "x", ylab = "y")# 4. 对数函数
y4 <- 2 + 0.5 * log(abs(x) + 1)  # 避免对负数取对数
plot(x, y4, type = "l", col = "purple", lwd = 2, main = "Logarithmic Function", xlab = "x", ylab = "y")# 设置图形布局为3行4列
par(mfrow = c(2, 2), mar = c(4, 4, 2, 2))  # 调整边距# 5. 幂函数
y5 <- 2 * x^0.5
plot(x, y5, type = "l", col = "orange", lwd = 2, main = "Power Function", xlab = "x", ylab = "y")# 6. 逻辑函数
y6 <- 1 / (1 + exp(-(2 + 0.5 * x)))
plot(x, y6, type = "l", col = "brown", lwd = 2, main = "Logistic Function", xlab = "x", ylab = "y")# 7. 正弦函数
y7 <- 2 * sin(0.5 * x + 1)
plot(x, y7, type = "l", col = "pink", lwd = 2, main = "Sine Function", xlab = "x", ylab = "y")# 8. 余弦函数
y8 <- 2 * cos(0.5 * x + 1)
plot(x, y8, type = "l", col = "cyan", lwd = 2, main = "Cosine Function", xlab = "x", ylab = "y")# 设置图形布局为3行4列
par(mfrow = c(2, 2), mar = c(4, 4, 2, 2))  # 调整边距# 9. 高斯函数
y9 <- 2 * exp(-((x - 0)^2) / (2 * 1^2))
plot(x, y9, type = "l", col = "magenta", lwd = 2, main = "Gaussian Function", xlab = "x", ylab = "y")# 10. 双曲函数
y10 <- 2 * tanh(0.5 * x + 1)
plot(x, y10, type = "l", col = "gray", lwd = 2, main = "Hyperbolic Function", xlab = "x", ylab = "y")# 11. 双指数函数y11 <- 2 * exp(-0.5 * abs(x))
plot(x, y11, type = "l", col = "gray", lwd = 2, main = "Hyperbolic Function", xlab = "x", ylab = "y")# 12. 三次多项式函数y12 <- 2 + 0.5 * x + 0.1 * x^2 + 0.01 * x^3
plot(x, y12, type = "l", col = "gray", lwd = 2, main = "Hyperbolic Function", xlab = "x", ylab = "y")
http://www.lryc.cn/news/2387533.html

相关文章:

  • 训练自己的yolo模型,并部署到rk3588上
  • Leetcode 3556. Sum of Largest Prime Substrings
  • 以少学习:通过无标签数据从大型语言模型进行知识蒸馏
  • 鸿蒙OSUniApp 实现带有滑动删除的列表#三方框架 #Uniapp
  • Qt qml Network error问题
  • Prompt工程:解锁大语言模型的终极密钥
  • Spring Boot微服务架构(六):伪装的微服务有哪些问题?
  • 恶意npm与VS Code包窃取数据及加密货币资产
  • Matlab快速上手五十六:详解符号运算里假设的用法,通过假设可以设置符号变量的取值范围,也可以通过假设设置变量属于集合:整数、正数和实数等
  • 机器学习笔记【Week1】
  • 什么是3D全景视角?3D全景有什么魅力?
  • 【Mini-F5265-OB开发板试用测评】按键控制测试
  • Debian重装系统后
  • 每日Prompt:古花卷
  • [学习]C语言指针函数与函数指针详解(代码示例)
  • 夏季用电高峰如何防患于未“燃”?电力测温技术守护城市生命线
  • 浙大版《Python 程序设计》题目集6-3,6-4,6-5,6-6列表或元组的数字元素求和及其变式(递归解法)
  • Leetcode 3563. Lexicographically Smallest String After Adjacent Removals
  • 【创造型模式】抽象工厂方法模式
  • 一台手机怎样实现多IP上网?方法有多种
  • 【FFmpeg+SDL】播放音频时,声音正常但是有杂音问题(已解决)
  • Linux 527 重定向 2>1 rsync定时同步(未完)
  • 3DVR拍摄指南:从理论到实践
  • OSI模型中的网络协议
  • 【C/C++】线程局部存储:原理与应用详解
  • 分块查找详解
  • leetcode hot100刷题日记——21.不同路径
  • Elasticsearch 如何实现跨数据中心的数据同步?
  • C语言学习笔记三 --- V
  • 通过JS模板引擎实现动态模块组件(Vite+JS+Handlebars)