服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - R语言 - R语言—自定义函数求置信区间的操作

R语言—自定义函数求置信区间的操作

2022-01-10 15:37弓二竹 R语言

这篇文章主要介绍了R语言—自定义函数求置信区间的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

代码如下:

#求单正态均值mu的置信区间
#参数依次为置信水平alpha,正态样本x,已知总体方差(默认为未知)
mu <- function(alpha,x,sigma=NA){
n <- length(x)
meanx <- mean(x)
if(is.na(sigma)){
  t1 <- qt(1-alpha/2,n-1)
  t2 <- qt(1-alpha,n-1)
  mu11 <- meanx - t1*sqrt(sum((x-meanx)^2)/(n-1))/sqrt(n)
  mu12 <- meanx + t1*sqrt(sum((x-meanx)^2)/(n-1))/sqrt(n)
  mu21 <- meanx + t2*sqrt(sum((x-meanx)^2)/(n-1))/sqrt(n)
  mu22 <- meanx - t2*sqrt(sum((x-meanx)^2)/(n-1))/sqrt(n)
}
else{
  u1 <- qnorm(1-alpha/2,0,1)
  u2 <- qnorm(1-alpha,0,1)
  mu11 <- meanx - u1*sigma/sqrt(n)
  mu12 <- meanx + u1*sigma/sqrt(n)
  mu21 <- meanx + u2*sigma/sqrt(n)
  mu22 <- meanx - u2*sigma/sqrt(n)
}
string1 <- paste('以1-',alpha,'为置信水平的mu双侧置信区间为:[',mu11,', ',mu12,']。',sep='')
string2 <- paste('以1-',alpha,'为置信水平的mu单侧置信区间上限为:',mu21,'。',sep='')
string3 <- paste('以1-',alpha,'为置信水平的mu单侧置信区间下限为:',mu22,'。',sep='')
string <- data.frame(Confidence_Interval=c(string1,string2,string3))
return(string)
}
#求单正态方差sigma的置信区间
#参数依次为置信水平alpha,正态样本x,已知总体均值(默认为未知)
sigma <- function(alpha,x,mu=NA){
n <- length(x)
if(is.na(mu)){
  meanx <- mean(x)
  chisq11 <- qchisq(1-alpha/2,n-1)
  chisq12 <- qchisq(alpha/2,n-1)
  chisq21 <- qchisq(alpha,n-1)
  chisq22 <- qchisq(1-alpha,n-1)
  sigma11 <- sqrt(sum((x-meanx)^2)/chisq11)
  sigma12 <- sqrt(sum((x-meanx)^2)/chisq12)
  sigma21 <- sqrt(sum((x-meanx)^2)/chisq21)
  sigma22 <- sqrt(sum((x-meanx)^2)/chisq22)
}
else{
  chisq11 <- qchisq(1-alpha/2,n)
  chisq12 <- qchisq(alpha/2,n)
  chisq21 <- qchisq(alpha,n)
  chisq22 <- qchisq(1-alpha,n)
  sigma11 <- sqrt(sum((x-mu)^2)/chisq11)
  sigma12 <- sqrt(sum((x-mu)^2)/chisq12)
  sigma21 <- sqrt(sum((x-mu)^2)/chisq21)
  sigma22 <- sqrt(sum((x-mu)^2)/chisq22)
}
string1 <- paste('以1-',alpha,'为置信水平的sigma双侧置信区间为:[',sigma11,', ',sigma12,']。',sep='')
string2 <- paste('以1-',alpha,'为置信水平的sigma单侧置信区间上限为:',sigma21,'。',sep='')
string3 <- paste('以1-',alpha,'为置信水平的sigma单侧置信区间下限为:',sigma22,'。',sep='')
string <- data.frame(Confidence_Interval=c(string1,string2,string3))
return(string)
}
#求两个正态均值差(mux-muy)的置信区间
#参数依次为置信水平alpha,正态样本x,正态样本y,
#已知x总体方差sigmax(默认为未知),已知y总体方差sigmay(默认为未知)
mux_muy <- function(alpha,x,y,sigmax=NA,sigmay=NA){
if(is.na(sigmax)|is.na(sigmay)){
  meanx <- mean(x)
  meany <- mean(y)
  m <- length(x)
  n <- length(y)
  sx <- sqrt(sum((x-meanx)^2)/(m-1))
  sy <- sqrt(sum((y-meany)^2)/(n-1))
  sw <- sqrt((m-1)*sx^2/(m+n-2)+(n-1)*sy^2/(m+n-2))
  mu11 <- (meanx-meany)+qt(1-alpha/2,m+n-2)*sw*sqrt(1/m+1/n)
  mu11 <- (meanx-meany)-qt(1-alpha/2,m+n-2)*sw*sqrt(1/m+1/n)
}
else{
  meanx <- mean(x)
  meany <- mean(y)
  m <- length(x)
  n <- length(y)
  sx <- sqrt(sum((x-mux)^2)/m)
  sy <- sqrt(sum((y-muy)^2)/n)
  mu11 <- (meanx-meany)+qt(1-alpha/2,m+n)*sw*sqrt(1/m+1/n)
  mu11 <- (meanx-meany)-qt(1-alpha/2,m+n)*sw*sqrt(1/m+1/n)
}
string1 <- paste('以1-',alpha,'为置信水平的mux-muy双侧置信区间为:[',mu11,', ',mu12,']。',sep='')
return(string1)
}
#求两个正态标准差比sigmax/sigmay的置信区间
#参数依次为置信水平alpha,正态样本x,正态样本y,
#已知x总体均值mux(默认为未知),已知y总体均值muy(默认为未知)
sigmax_sigmay <- function(alpha,x,y,mux=NA,muy=NA){
alpha <- alpha
mux <- mux
muy <- muy
if(is.na(mux)|is.na(muy)){
  meanx <- mean(x)
  m <- length(x)
  meany <- mean(y)
  n <- length(y)
  F1 <- qf(1-alpha/2,m-1,n-1)
  F2 <- qf(alpha/2,m-1,n-1)
  sigma11 <- 1/F1*sum((x-meanx)^2)*(n-1)/sum((y-meany)^2)/(m-1)
  sigma12 <- 1/F2*sum((x-meanx)^2)*(n-1)/sum((y-meany)^2)/(m-1)
}
else{
  m <- length(x)
  n <- length(y)
  F1 <- qf(1-alpha/2,m,n)
  F2 <- qf(alpha/2,m,n)
  sigma11 <- 1/F1*sum((x-mux)^2)*n/sum((y-muy)^2)/m
  sigma12 <- 1/F2*sum((x-mux)^2)*n/sum((y-muy)^2)/m
}
string1 <- paste('以1-',alpha,'为置信水平的sigmax-sigmay双侧置信区间为:[',sigma11,', ',sigma12,']。',sep='')
return(string1)
}

选修课作业,自己写函数求单正态样本均值、方差置信区间,两个正态样本均值差、方差比的置信区间。

求解时正态方差和均值默认为未知,函数具体样子可以参考题图。

本来是想输出一段话,但是我不知道怎么换行,所以将就着看吧。

补充:R语言【估计单侧置信区间】

R语言—自定义函数求置信区间的操作

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/weixin_36814155/article/details/78766410

延伸 · 阅读

精彩推荐
  • R语言R语言读取xls与xlsx格式文件过程

    R语言读取xls与xlsx格式文件过程

    这篇文章主要为大家介绍了使用R语言读取xls与xlsx格式文件的过程步骤,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪...

    Kanny广小隶11982022-01-20
  • R语言R语言中qplot()函数的用法说明

    R语言中qplot()函数的用法说明

    这篇文章主要介绍了R语言中qplot()函数的用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    Jack_丁明12752022-01-05
  • R语言R语言实现支持向量机SVM应用案例

    R语言实现支持向量机SVM应用案例

    本文主要介绍了R语言实现支持向量机SVM应用案例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    一天_pika5222022-01-18
  • R语言基于R/RStudio中安装包“无法与服务器建立连接”的解决方案

    基于R/RStudio中安装包“无法与服务器建立连接”的解决方案

    这篇文章主要介绍了基于R/RStudio中安装包“无法与服务器建立连接”的解决方案,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    truffle52815052022-01-05
  • R语言R语言中的vector(向量),array(数组)使用总结

    R语言中的vector(向量),array(数组)使用总结

    这篇文章主要介绍了R语言中的vector(向量),array(数组)使用总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    A叶子叶来5772021-11-14
  • R语言R语言常量知识点总结

    R语言常量知识点总结

    在本篇文章里小编给大家整理了一篇关于R语言常量知识点总结内容,有兴趣的朋友们可以学习分享下。...

    R语言教程网12102021-12-29
  • R语言如何用R语言绘制散点图

    如何用R语言绘制散点图

    这篇文章主要介绍了如何用R语言绘制散点图,帮助大家更好的理解和学习使用R语言,感兴趣的朋友可以了解下...

    菜鸟教程13002021-12-23
  • R语言R语言gsub替换字符工具的具体使用

    R语言gsub替换字符工具的具体使用

    这篇文章主要介绍了R语言gsub替换字符工具的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    lztttao10372021-12-24