使用R语言进行方差分析(ANOVA、ANCOVA)(一)

news2025/1/21 15:21:47

方差分析(一)

    • 1. ANOVA模型拟合
      • 1.1 aov()函数
      • 1.2 表达式中各项的顺序
    • 2. 单因素方差分析(One-Way ANOVA)
      • 2.1 绘制各组均值及其置信区间的图形
      • 2.2 多重比较-TukeyHSD
        • 2.2.1 成对比较图
        • 2.2.2 多重均值比较-TukeyHSD(更易理解)
      • 2.3 评估检验的假设条件
        • 2.3.1 正态性检验
        • 2.3.2 方差齐性检验
        • 2.3.3 离群点检验
    • 3. 单因素协方差分析
      • 3.1 去除协变量的影响
      • 3.2 用户定义对照的多重比较(User-defined Contrasts)
      • 3.3 评估检验的假设条件
      • 3.4 结果可视化
    • 4. 双因素方差分析(ANOVA)
      • 4.1 结果可视化

1. ANOVA模型拟合

1.1 aov()函数

 语法:aov(formula, data = dataframe)

R表达式中的特殊符号:
在这里插入图片描述

R语言中常见研究设计的表达式:
在这里插入图片描述

1.2 表达式中各项的顺序

  表达式中各项的顺序在两种情况下会造成影响,例如,y ~ AB与y ~ BA的结果不同:

  1. 因子有多个,且非平衡设计 (即每组样本数不同)
  2. 存在协变量 (每个样本之间会有差别,而引起这些差别的变量叫做协变量)

R语言默认为类型I(序贯型)
又如:y~A+B+A:B:

  1. A对y的影响
  2. 控制A时,B对y的影响
  3. 控制A和B的主效应时,A与B的交互效应

各因子的顺序对结果的影响:
在这里插入图片描述

  样本大小越不平均,效应项顺序对结果的影响越大。所以,越基础性的因子越应该放在表达式前面,即协变量应该放在主变量之前,接下来是双因素的交互项,再接下来是三因素的交互项。
  对于主效应,越基础的变量越应该放在表达式的前面,比如,性别应该放在处理方式的前面。
  car包中的Anova()函数提供使用类型2和类型3方法,aov()函数使用类型1方法。

2. 单因素方差分析(One-Way ANOVA)

  单因子方差分析,比较分类因子定义的两个或者多个组别中因变量均值。以multcomp包中的cholesterol数据集为例(取自Westfall、Tobia、Rom、Hochberg,1999),50个患者均接受降低胆固醇药物治疗(trt)五种疗法中的一种疗法。其中三种治疗条件使用药物相同,分别是20mg一天一次(1time)、10mg一天两次(2times)和5mg一天四天(4times)。剩下的两种方式(drugD和drugE)代表候选药物。哪种药物疗法降低胆固醇(响应变量)最多?

install.packages('multcomp')
library(multcomp)

attach(cholesterol) #打开连接:直接使用其中的变量名而不需要使用符号
colnames(cholesterol)
table(trt)

## 计算各组平均值mean
## aggregate()函数是用于对数据进行分组统计的函数:
# aggregate()函数是用于对数据进行分组统计的函数。
# response是一个向量,trt是一个因子变量,表示不同的处理组。
# aggregate(response, by=list(trt), FUN=mean)的作用是计算response向量中每个处理组的平均值
aggregate(response, by=list(trt), FUN=mean)
response

## 计算各组标准差sd
aggregate(response, by=list(trt), FUN=sd)

## 检验组间差异
fit <- aov(response ~ trt)
summary(fit)
#自由度 平方和 均方和 F值 P值

结果:

> aggregate(response, by=list(trt), FUN=mean)
  Group.1        x
1   1time  5.78197
2  2times  9.22497
3  4times 12.37478
4   drugD 15.36117
5   drugE 20.94752
> aggregate(response, by=list(trt), FUN=sd)
  Group.1        x
1   1time 2.878113
2  2times 3.483054
3  4times 2.923119
4   drugD 3.454636
5   drugE 3.345003
> summary(fit)
            Df Sum Sq Mean Sq F value   Pr(>F)    
trt          4 1351.4   337.8   32.43 9.82e-13 ***
Residuals   45  468.8    10.4                     
---
Signif. codes:  0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1

  ANOVA对治疗方式(trt)的F检验非常显著(p<0.0001),说明五种疗法的效果不同。

2.1 绘制各组均值及其置信区间的图形

## 绘制各组均值及其置信区间的图形
library(gplots) 
plotmeans(response ~ trt, xlab="Treatment", ylab="Response", 
            main="Mean Plot\nwith 95% CI")
detach(cholesterol) # 关闭连接

在这里插入图片描述

  自由度: 考虑样本量为n的样本(n个数),如果我们知道样本均值,那么我们只需要知道前n-1个数,就可以得知全部信息,因为最后一个数可以借助均值计算得出。所以,在给定样本均值(约束条件)的情况下,我们相当于在原本n个数的基础上消减了一个自由度,样本提供的信息只有n-1个独立的部分。

2.2 多重比较-TukeyHSD

   虽然ANOVA对各疗法的F检验表明五种药物疗法效果不同,但是并没有告诉你哪种疗法与其他疗法不同。多重比较可以解决这个问题,其中TukeyHSD()函数提供了对各组均值差异的成对检验。

TukeyHSD(fit)

结果:

  Tukey multiple comparisons of means
    95% family-wise confidence level

Fit: aov(formula = response ~ trt)

$trt
                  diff        lwr       upr     p adj
2times-1time   3.44300 -0.6582817  7.544282 0.1380949
4times-1time   6.59281  2.4915283 10.694092 0.0003542
drugD-1time    9.57920  5.4779183 13.680482 0.0000003
drugE-1time   15.16555 11.0642683 19.266832 0.0000000
4times-2times  3.14981 -0.9514717  7.251092 0.2050382
drugD-2times   6.13620  2.0349183 10.237482 0.0009611
drugE-2times  11.72255  7.6212683 15.823832 0.0000000
drugD-4times   2.98639 -1.1148917  7.087672 0.2512446
drugE-4times   8.57274  4.4714583 12.674022 0.0000037
drugE-drugD    5.58635  1.4850683  9.687632 0.0030633

  可以看到,1time和2times的均值差异不显著(p=0.138),而1time和4times间的差异非常显著(p<0.001)。

2.2.1 成对比较图

  第一个par语句用来旋转轴标签,第二个用来增大左边界的面积,可使标签摆放更美观。图形中置信区间包含0的疗法说明差异不显著(p>0.5)
在R语言中,par(las=2)是用来设置绘图区域的标签方向的。其中,las是一个整数,用于指定标签的方向。las=0表示标签平行于坐标轴las=1表示标签垂直于坐标轴las=2表示标签垂直于坐标轴并且文字是从右向左书写的

par(las=2)
par(mar=c(5,8,4,2)) 
plot(TukeyHSD(fit))

结果展示:
在这里插入图片描述

2.2.2 多重均值比较-TukeyHSD(更易理解)

  multcomp包中的glht()函数提供了多重均值比较更为全面的方法,既适用于线性模型),也适用于广义线性模型。下面的代码重现了Tukey HSD检验,并用一个不同的图形对结果进行展示。

library(multcomp) 
par(las=0)
par(mar=c(5,4,6,2))
tuk <- glht(fit, linfct=mcp(trt="Tukey")) 
plot(cld(tuk, level=.05),col="lightgrey") #cld()函数中的level选项设置了使用的显著水平0.05

结果展示:
在这里插入图片描述
图像解释:
  有相同字母的组(用箱线图表示)说明均值差异不显著。可以看到,1time和2times差异不显著(有相同的字母a),2times和4times差异也不显著(有相同的字母b),而1time和4times差异显著(它们没有共同的字母)。个人认为,该图比2.2.1中的成对比较图更易理解。

2.3 评估检验的假设条件

2.3.1 正态性检验

  我们对于结果的可靠性取决于做统计检验时数据满足假设条件的程度。单因素方差分析中,我们假设因变量服从正态分布各组方差相等。可以使用Q-Q图来检验正态性假设:

library(car) 
# qqPlot()要求用lm()拟合
qqPlot(lm(response ~ trt, data=cholesterol), 
         simulate=TRUE, main="Q-Q Plot", labels=FALSE)

Q-Q图:
在这里插入图片描述
数据落在95%的置信区间范围内,说明满足正态性假设。

2.3.2 方差齐性检验

library(car) 
qqPlot(lm(response ~ trt, data=cholesterol), 
         simulate=TRUE, main="Q-Q Plot", labels=FALSE)

结果展示:


	Bartlett test of homogeneity of variances

data:  response by trt
Bartlett's K-squared = 0.57975, df = 4, p-value = 0.9653

  还有其他检验如Fligner-Killeen检验(fligner.test()函数)和Brown-Forsythe检验(HH包中的hov()函数),它们获得的结果与Bartlett检验相同。

2.3.3 离群点检验

  离群点 :预测效果不佳的点,具有加大残差。

根据最大的残差值的显著性来判断是否存在离群点:

  1. 若不显著 Bonferonni P>0.05 ,表明没有离群点;
  2. 若显著 Bonferonni P<0.05 ,表明该最大残差值点为离群点,需要删去,然后对删除该点后的拟合模型再次进行离群点的检验。

  方差齐性分析对离群点非常敏感。可利用car包中的outlierTest()函数来检测离群点:

library(car)
outlierTest(fit)

结果展示:

No Studentized residuals with Bonferroni p < 0.05
Largest |rstudent|:
   rstudent unadjusted p-value Bonferroni p
19 2.251149           0.029422           NA

结果分析:
  这个结果是关于特定回归分析的统计学测试的输出内容。对于第19个数据点,该测试计算出了学生化残差值为2.251,对应的未经校正的p值为0.029422。然而,经过Bonferroni校正后的p值小于0.05的学生化残差值没有被发现,因此输出显示了“无Bonferroni p < 0.05的学生化残差”。由此可以得出结论,此数据点的学生化残差值并不显著,即不具有统计学上的显著性 (不具有统计学上的显著性意味着,结果不足以证明假设成立。在这种情况下,我们不能拒绝原假设。例子中,没有学生化残差的Bonferroni p值小于0.05,这意味着没有离群点)。

  从输出结果来看,并没有证据说明胆固醇数据中含有离群点(当p>1时将产生NA)。因此根据Q-Q图、Bartlett检验和离群点检验,该数据似乎可以用ANOVA模型拟合得很好。这些方法反过来增强了我们对于所得结果的可靠性。

3. 单因素协方差分析

  单因素协方差分析(ANCOVA)扩展了单因素方差分析(ANOVA),包含一个或多个定量的协变量。下面的例子来自于multcomp包中的litter数据集。怀孕小鼠被分为四个小组,每个小组接受不同剂量(0、5、50或500)的药物处理。产下幼崽的体重均值为因变量,怀孕时间为协变量

#单因素协方差分析
data(litter, package="multcomp")
attach(litter) 
table(dose)
aggregate(weight, by=list(dose), FUN=mean)

fit <- aov(weight ~ gesttime + dose) # 注意aov()使用的是类型1
summary(fit)

结果展示:

> table(dose)
dose
  0   5  50 500 
 20  19  18  17
> aggregate(weight, by=list(dose), FUN=mean)
  Group.1        x
1       0 32.30850
2       5 29.30842
3      50 29.86611
4     500 29.64647
> summary(fit)
            Df Sum Sq Mean Sq F value  Pr(>F)   
gesttime     1  134.3  134.30   8.049 0.00597 **
dose         3  137.1   45.71   2.739 0.04988 * 
Residuals   69 1151.3   16.69                   
---
Signif. codes:  0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1

结果分析:
  利用table()函数,可以看到每种剂量下所产的幼崽数并不相同:0剂量时(未用药)产崽20个,500剂量时产崽17个。再用aggregate()函数获得各组均值,可以发现未用药组幼崽体重均值最高(32.3)。ANCOVA的F检验表明:
(a) 怀孕时间与幼崽出生体重相关;
(b) 控制怀孕时间,药物剂量与出生体重相关。
控制怀孕时间,确实发现每种药物剂量下幼崽出生体重均值不同。

3.1 去除协变量的影响

  由于使用了协变量,你可能想要获取调整的组均值,即去除协变量效应后的组均值。可使用 effects包中的effects()函数 来计算调整的均值:

library(effects)
effect("dose", fit)

结果:

 dose effect
dose
       0        5       50      500 
32.35367 28.87672 30.56614 29.33460 

  调整的均值与aggregate()函数得出的未调整的均值类似,但并非所有的情况都是如此。 总之,effects包为复杂的研究设计提供了强大的计算调整均值的方法,并能将结果可视化。

3.2 用户定义对照的多重比较(User-defined Contrasts)

  剂量的F检验虽然表明了不同的处理方式幼崽的体重均值不同,但无法告知我们哪种处理方式与其他方式不同。同样,我们使用multcomp包来对所有均值进行成对比较。另外,multcomp包还可以用来检验用户自定义的均值假设。假定你对未用药条件与其他三种用药条件影响是否不同感兴趣,可使用以下代码实现:

library(multcomp)
contrast <- rbind("no drug vs. drug" = c(3, -1, -1, -1)) #rbind表示“row bind”,即“按行绑定”,其中每个对象应该具有相同的列数和相同的类型
summary(glht(fit, linfct=mcp(dose=contrast)))

  rbind(“no drug vs. drug” = c(3, -1, -1, -1))中的c(3, -1, -1, -1)是一个长度为4的数值向量,其中第一个数值(即3)表示“未注射药物的比重”,后面三个数值(即-1,-1,-1)表示“三种剂量的比重”。这个向量用于定义将三个剂量合并为一个组并将其与未注射药物组进行比较的比较向量。

结果:

	 Simultaneous Tests for General Linear Hypotheses

Multiple Comparisons of Means: User-defined Contrasts


Fit: aov(formula = weight ~ gesttime + dose)

Linear Hypotheses:
                      Estimate Std. Error t value Pr(>|t|)
no drug vs. drug == 0    8.284      3.209   2.581    0.012
                       
no drug vs. drug == 0 *
---
Signif. codes:  
0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1
(Adjusted p values reported -- single-step method)

  对照c(3, -1, -1, -1)设定第一组和其他三组的均值进行比较。假设检验的t统计量(2.581)在p<0.05水平下显著,因此,可以得出未用药组比其他用药条件下的出生体重高的结论。

3.3 评估检验的假设条件

  ANCOVA与ANOVA相同,都需要正态性和同方差性假设,另外ANCOVA还假定回归斜率相同。本例中,假定四个处理组通过怀孕时间来预测出生体重的回归斜率都相同。ANCOVA模型包含怀孕时间×剂量的交互项时,可对回归斜率的同质性进行检验。交互效应若显著,则意味着时间和幼崽出生体重间的关系依赖于药物剂量的水平。

library(multcomp)
fit2 <- aov(weight ~ gesttime*dose, data=litter) 
summary(fit2)

结果:

              Df Sum Sq Mean Sq F value  Pr(>F)   
gesttime       1  134.3  134.30   8.289 0.00537 **
dose           3  137.1   45.71   2.821 0.04556 * 
gesttime:dose  3   81.9   27.29   1.684 0.17889   
Residuals     66 1069.4   16.20                   
---
Signif. codes:  0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1

  可以看到交互效应不显著,支持了斜率相等的假设。若假设不成立,可以尝试变换协变量或因变量,或使用能对每个斜率独立解释的模型,或使用不需要假设回归斜率同质性的非参数ANCOVA方法。sm包中sm.ancova()函数为后者提供了一个例子。
  总之,如果交互效应不显著,就说明自变量对因变量的影响是线性的,可以使用统一的回归方程来描述它们之间的关系。

3.4 结果可视化

  HH包中的ancova()函数可以绘制因变量、协变量和因子之间的关系图:

library(HH)
ancova(weight ~ gesttime + dose, data=litter)

结果:

Analysis of Variance Table

Response: weight
          Df  Sum Sq Mean Sq F value   Pr(>F)   
gesttime   1  134.30 134.304  8.0493 0.005971 **
dose       3  137.12  45.708  2.7394 0.049883 * 
Residuals 69 1151.27  16.685                    
---
Signif. codes:  0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1

在这里插入图片描述
  从图中可以看到,用怀孕时间来预测出生体重的回归线相互平行,只是截距项不同。随着怀孕时间增加,幼崽出生体重也会增加。另外,还可以看到0剂量组截距项最大,5剂量组截距项最小。由于你上面的设置,直线会保持平行,若使用ancova(weight ~ gesttime*dose),生成的图形将允许斜率和截距项依据组别而发生变化,这对可视化那些违背回归斜率同质性的实例非常有用。

4. 双因素方差分析(ANOVA)

  在双因素方差分析中,受试者被分配到两因子的交叉类别组中。 以基础安装中的ToothGrowth数据集为例,随机分配60只豚鼠,分别采用两种喂食方法(橙汁或维生素C),各喂食方法中抗坏血酸含量有三种水平(0.5mg、1mg或2mg),每种处理方式组合都被分配10只豚鼠。牙齿长度为因变量。

#双因素方差分析
attach(ToothGrowth)
table(supp, dose)
head(ToothGrowth)
aggregate(len, by=list(supp, dose), FUN=mean)
aggregate(len, by=list(supp, dose), FUN=sd)

dose <- factor(dose)
fit <- aov(len ~ supp*dose) # 双因素影响
summary(fit)
detach(ToothGrowth)

结果:

> head(ToothGrowth)
   len supp dose
1  4.2   VC  0.5
2 11.5   VC  0.5
3  7.3   VC  0.5
4  5.8   VC  0.5
5  6.4   VC  0.5
6 10.0   VC  0.5
> aggregate(len, by=list(supp, dose), FUN=mean)
  Group.1 Group.2     x
1      OJ     0.5 13.23
2      VC     0.5  7.98
3      OJ     1.0 22.70
4      VC     1.0 16.77
5      OJ     2.0 26.06
6      VC     2.0 26.14
> aggregate(len, by=list(supp, dose), FUN=sd)
  Group.1 Group.2        x
1      OJ     0.5 4.459709
2      VC     0.5 2.746634
3      OJ     1.0 3.910953
4      VC     1.0 2.515309
5      OJ     2.0 2.655058
6      VC     2.0 4.797731
> summary(fit)
            Df Sum Sq Mean Sq F value   Pr(>F)    
supp         1  205.4   205.4  15.572 0.000231 ***
dose         2 2426.4  1213.2  92.000  < 2e-16 ***
supp:dose    2  108.3    54.2   4.107 0.021860 *  
Residuals   54  712.1    13.2                     
---
Signif. codes:  0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1

结果分析:
  table语句的预处理表明该设计是均衡设计(各设计单元中样本大小都相同),aggregate语句处理可获得各单元的均值和标准差。dose变量被转换为因子变量,这样aov()函数就会将它当做一个分组变量,而不是一个数值型协变量。 用summary()函数得到方差分析表,可以看到主效应(supp和dose)和交互效应都非常显著。

4.1 结果可视化

  此处可用interaction.plot()函数来展示双因素方差分析的交互效应。

interaction.plot(dose, supp, len, type="b", 
                 col=c("red","blue"), pch=c(16, 18), 
                 main = "Interaction between Dose and Supplement Type")

图形展示了各种剂量喂食下豚鼠牙齿长度的均值:
在这里插入图片描述

用gplots包中的plotmeans()函数来展示交互效应:

library(gplots)
plotmeans(len ~ interaction(supp, dose, sep=" "), 
          connect=list(c(1,3,5),c(2,4,6)), 
          col=c("red", "darkgreen"), 
          main = "Interaction Plot with 95% CIs", 
          xlab="Treatment and Dose Combination")

图形展示了均值、误差棒(95%的置信区间)和样本大小:
在这里插入图片描述

  用HH包中的interaction2wt()函数来可视化结果,图形对任意顺序的因子设计的主效应和交互效应都会进行展示:

library(HH)
interaction2wt(len~supp*dose)

ToothGrowth数据集的主效应和交互效应:
在这里插入图片描述

  以上三幅图形都表明随着橙汁(QJ)和维生素C(VC)中的抗坏血酸剂量的增加,牙齿长度变长。对于0.5mg和1mg剂量,橙汁比维生素C更能促进牙齿生长;对于2mg剂量的抗坏血酸,两种喂食方法下牙齿长度增长相同。三种绘图方法中,我更推荐HH包中的interaction2wt()函数,因为它能展示任意复杂度设计(双因素方差分析、三因素方差分析等)的 主效应(箱线图) 和交互效应。
  此处没有涵盖模型假设检验和均值比较的内容,因为它们只是之前方法的一个自然扩展而已。此外,该设计是均衡的,故而不用担心效应顺序的影响。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/434406.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图的存储(邻接矩阵邻接表)

图的存储 文章目录 图的存储1 邻接矩阵1.1 邻接矩阵存储结构定义1.2 完整代码应用 2 邻接表2.1 邻接表存储结构定义2.2 完整代码应用 1 邻接矩阵 A [ i ] [ j ] 1 A[i][j]1 A[i][j]1 表示顶点i与顶点j邻接&#xff0c;即i与j之间存在边或者弧。 A [ i ] [ j ] 0 A[i][j]0 A…

使用jdk17 搭建Hadoop3.3.5和Spark3.3.2 on Yarn集群模式

搭建Hadoop3.3.5和Spark3.3.2 on Yarn集群模式&#xff0c;使用jdk17 搭建Hadoop3.3.5和Spark3.3.2 on Yarn集群模式1. 创建一台虚拟机2. 安装jdk17&#xff08;1&#xff09;下载jdk17&#xff08;2&#xff09;安装jdk17&#xff08;3&#xff09;配置环境变量 3. 虚拟机之间…

【音视频第15天】webRTC协议(2)

目录 协议ICESTUNNATTURNSDPSDP结构 Signaling and ConnectingSignaling: How peers find each other in WebRTCConnecting and NAT Traversal with STUN/TURN Signalingsdp协议WebRTC如何使用sdpWebRTC会话示例 Connecting为什么WebRTC需要一个专用的子系统来连接?现实世界的…

Day949.遗留系统之殇:为什么要对遗留系统进行现代化? -遗留系统现代化实战

遗留系统之殇&#xff1a;为什么要对遗留系统进行现代化&#xff1f; Hi&#xff0c;我是阿昌&#xff0c;今天学习记录是关于遗留系统之殇&#xff1a;为什么要对遗留系统进行现代化&#xff1f;的内容。 不知道你是否跟曾经一样&#xff0c;身处一个遗留系统的漩涡之中&…

数据结构-基数排序

基数排序是和其他的各类排序方式都不同的方式&#xff0c;之前的各类排序&#xff0c;如快速排序&#xff0c;堆排序&#xff0c;冒泡排序等等&#xff0c;都是通过关键字之间的比较和移动记录这两种操作来实现的&#xff0c;而基数排序不需要记录关键字之间的比较。所谓基数排…

ubuntu 安装vmware tool

1在虚拟机种站到安装vmware-tools 然后重启虚拟机 2在磁盘中可以看到如下文件&#xff0c;将zip文件移动到桌面解压备用 3关闭虚拟机 找到编辑虚拟机设置 4点击左侧 CD/dvd(SATA) 如果是使用镜像文件&#xff0c;改成使用物理驱动器. 5 打开命令行 cd 桌面 &#xff08;如…

CSS基础——盒子模型的一些属性概念

目录 display visibility overflow 文档流 元素在文档流中的特点 块元素 内联元素 浮动 float 浮动元素特点 清除浮动 clear 小练习 效果图 具体实现 高度塌陷问题 BFC 特点 如何开启BFC 解决方案 本篇的最终练习 效果图如下&#xff1a; 具体实现 disp…

ChatGPT原理解释

写了一本介绍ChatGPT原理的课程 结构如下 01、介绍ChatGPT及其原理 1.1 ChatGPT的概述 1.2 什么是自然语言处理&#xff08;NLP&#xff09; 1.3 深度学习与NLP的关系 1.4 GPT模型的介绍 02、GPT原理探讨 2.1 GPT模型的输入与输出 2.2 GPT模型的结构 2.3 GPT模型的预训练方法…

flv怎么无损转换成mp4格式,3大超级方法分享

flv格式是目前在视频分享媒体播放网站上广泛使用的一种视频文件格式&#xff0c;可以在网站窗口中直接播放&#xff0c;这类视频文件还能够有效保护版权。但是有些时候我们可能需要将flv格式的视频转换为其他格式&#xff0c;比如mp4。但是该怎么操作呢&#xff1f; 其实有很多…

数据挖掘:汽车车交易价格预测(测评指标;EDA)

目录 一、前期工作 1.赛题介绍 赛题分析&#xff1a; 分类和回归问题的评价指标有如下一些形式&#xff1a; &#xff08;下文2.1和2.2会用到&#xff09; 2.数据简介 3.探索性分析-EDA介绍 二、实战演练 2.1分类指标评价计算示例 2.2回归指标评价计算示例 2.3数据探索…

抠图,扣掉背景图片

Remove Image Backgrounds, Free HD, No Signup - Pixian.AI https://pixian.ai/ 从电脑本地选取图片&#xff0c;然后会自动扣掉背景&#xff0c;点击DOWNLOAD就可以了 第一个&#xff1a;Pixian.AI 这是一款国外的在线抠图网站&#xff0c;把需要扣除背景的图片拖拽进来&am…

简单的了解下 Fetch API 的工作原理

简介 Fetch API是一种现代的Web API&#xff0c;提供了一种异步获取网络资源的方法。由于其简单性、灵活性和一致性&#xff0c;它已经成为Web应用程序中获取数据和资源的流行选择。在本文中&#xff0c;我们将深入探讨Fetch API的核心特性&#xff0c;并了解其工作原理。 Fetc…

Windows逆向安全(一)之基础知识(七)

汇编C语言类型转换 类型转换 类型转换的使用场景 类型转换一般为由数据宽度小的转换成数据宽度大的&#xff0c;不然可能会有高位数据被截断的现象&#xff0c;引起数据丢失 需要一个变量来存储一个数据&#xff0c;刚开始这个数据的数据宽度较小&#xff0c;后来发现存不下…

什么是UML?

文章目录 00 | 基础知识01 | 静态建模类图对象图用例图 02 | 动态建模时序图通信图状态图活动图 03 | 物理建模构件图部署图 UML&#xff08;Unified Model Language&#xff09;&#xff0c;统一建模语言&#xff0c;是一种可以用来表现设计模式的直观的&#xff0c;有效的框图…

【图像分割】Grounded Segment Anything根据文字自动画框或分割环境配置和基本使用教程

1 环境配置 要求&#xff1a;python>3.8, pytorch>1.7, torchvision>0.8 官方地址&#xff1a;https://github.com/IDEA-Research/Grounded-Segment-AnythingMarrying Grounding DINO with Segment Anything & Stable Diffusion & BLIP & Whisper &am…

命运坎坷的保定县

保定的词语分解 保护而安定之。诗小雅天保&#xff1a;“天保定尔&#xff0c;亦孔之固。”谓稳固地保有。 晋 陆云 大将军宴会被命作诗&#xff1a;“皇皇帝祜&#xff0c;诞隆骏命。四祖正家&#xff0c;天禄保定。” 保定府&#xff1f;保定县&#xff1f; 今天提起“保定…

将“每日造型”变成长久习惯,戴森Airwrap™美发棒为何成为最好的“美丽投资”?

做头发、换发型是一个大工程&#xff0c;这几乎成了一种固定印象。虽然卷发棒已成为几乎“人手必备”的头发造型工具&#xff0c;但使用起来往往“现实很骨感”&#xff0c;不是使用频次极低&#xff0c;就是被束之高阁&#xff0c;每天都自己做头发换造型&#xff0c;只能是一…

陶泓达:4.19黄金原油早间精准策略!

黄金方面&#xff1a; 周二(4月18日)美市早盘&#xff0c;现货黄金一度跌至1991.05美元低点&#xff0c;但随后迅速拉升近20美元&#xff0c;向上触及2010.71美元高点&#xff0c;短线走出V型反转行情。本周&#xff0c;美国经济日历上没有太多关键数据会影响黄金和美元。因此&…

docker的数据卷详解

数据卷 数据卷是宿主机中的一个目录或文件&#xff0c;当容器目录和数据卷目录绑定后&#xff0c;对方修改会立即同步 一个数据卷可以同时被多个容器同时挂载&#xff0c;一个容器也可以被挂载多个数据卷 数据卷作用&#xff1a;容器数据持久化 /外部机器和容器间接通信 /容器…

leetCode算法第二天

好好刷刷算法题&#xff0c;提高自己的编码能力。 文章目录 将整数转为罗马数字将罗马数字转为整数编写一个函数来查找字符串数组中的最长公共前缀电话号码的字母组合 将整数转为罗马数字 leetcode链接&#xff1a;https://leetcode.cn/problems/integer-to-roman/ 解题思路…