多元统计分析——基于R的笔记本电脑价格与参数可视化

2024-08-21 15:44

本文主要是介绍多元统计分析——基于R的笔记本电脑价格与参数可视化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注:能力有限,存在不足之处。

         现如今,笔记本电脑现在已经成为了我们日常生活中所必备的一种工具,使用笔记本既可以为我们在学习上带来便利也可以在为我们在工作上带来便利,但是笔记本的价格与许多参数有关,因此,关于笔记本的价格与参数,展开研究。

一、提出问题(要解决或分析的问题)

        1、根据笔记本电脑参数预测价格

        2、笔记本电脑的参数为什么区别大

二、数据来源及选取方法

数据集来源:kaggle(Laptop price predictor | Kaggle)。

数据集说明:该数据集的上传时间为2019年,因此可以说该数据集是关于2019年印度四大笔记本制造商的笔记本电脑(intel处理器)的参数与销售价格。

选取方法:根据提出的问题,选择作图分析的方法以及利用主成分回归分析对价格进行预测的方法。

 三、数据可视化分析

 3.1数据信息基本描述

#导入数据集
data <- read.csv('C:\\Users\\leglon\\Desktop\\假期r\\1\\多元统计分析\\期末1\\laptop_pricing.csv')
#查看并修改列名,便于操作
colnames(data) <- c("Manufacturer","Series","IntelCoreGen","processingSpeed","Ram","HDD","SSD","Graphics","ScreenSize","Price")
#查看数据集的基本信息
data$Manufacturer <- factor(data$Manufacturer,levels = c("Dell","HP","ASUS","Lenovo"),labels = c(0,1,2,3))
data$Manufacturer <- as.numeric(data$Manufacturer)
head(data)
str(data)
summary(data)

 数据集中各参数的解释如下:

其中,SSD为0表示没有固态硬盘只有机械硬盘;Graphics为0表示没有独立显卡,显存为0。 

3.2 采用的多元分析方法 

        主成分分析法:主成分分析(PCA)的目标是用一组较少的不相关变量代替大量相关变量,同时尽可能保留初始变量的信息,这些推导所得的变量称为主成分,它们是观测变量的线性组合。假如此时有第一主成分为: 

PC1 = a1X1 + a2X2 + … + akXk

它是k个观测变量的加权组合,对初始变量集的方差解释性最大。第二主成分也是初始变量的线性组合,对方差的解释性排第二,同时与第一主成分正交(不相关)。后面每一个主成分都最大化它对方差的解释程度,同时与之前所有主成分都正交。理论上来说我们可以与变量数相同的主成分,但从实用的角度来看,我们更希望能用较少的主成分来近似全变量集。

3.3数据可视化分析结果及解释

 (1)不同品牌的笔记本数量

brand <- factor(data$Manufacturer,labels = c("Dell","HP","ASUS","Lenovo"),levels = c(1,2,3,4))
plot(brand,main = "不同品牌的笔记本数量",xlab = "笔记本制造商",ylab = "笔记本数量")
#可以看出,该地区HP和Lenovo两个品牌的电脑型号较多,而ASUS以及Dell品牌的笔记本电脑较少

(2) 固态与机械硬盘可视化

hdd <- table(data$HDD);hdd
ssd <- table(data$SSD);ssd
opar <- par(mfrow = c(1,2))
barplot(hdd,main = "机械硬盘",xlab = "机械硬盘大小(Gb)", ylab = "配备数量")
barplot(ssd,main = "固态硬盘",xlab = "固态硬盘大小(Gb)", ylab = "配备数量")
par(opar)

         如图,该地区的笔记本电脑大多数都配备了1000Gb的机械硬盘,并且大多数电脑没有配备固态硬盘。

(3)笔记本电脑配备可视化


opar <- par(mfrow = c(2,2))
barplot(table(data$Ram),main = "内存配备图",xlab = "内存大小)", ylab = "配备数量")
barplot(table(data$Graphics),main = "独显显存",xlab = "显存大小", ylab = "配备数量")
barplot(table(data$ScreenSize),main = "屏幕尺寸配备图",xlab = "屏幕尺寸", ylab = "配备数量")
par(opar)

        如图,当地笔记本电脑配备的不同内存、独显、屏幕尺寸如图,可以看出,大多数配置都在中下水平。 

(4)不同销售商的笔记本电脑价格可视化


x <- data[order(data$Price), ] #排序
x$color[x$Manufacturer == 1] <- "red"
x$color[x$Manufacturer == 2] <- "blue"
x$color[x$Manufacturer == 3] <- "green"
x$color[x$Manufacturer == 4] <- "pink"
x$color 
dotchart(x$Price, labels = row.names(x), cex = 0.8, pch = 11, groups = x$Manufacturer, gcolor = "black", color = x$color, main = "不同销售商的笔记本电脑价格", xlab = "价格(卢比)")

        如图,该地区HP和Lenovo两个笔记本制造商发售的笔记本型号最多。还可以看出不同销售商的笔记本电脑价格,其中红色为Dell,蓝色为HP,绿色为ASUS,粉色为Lenovo,其中,ASUS有着价格最高的电脑。 

 3.4 做主成分可视化分析

# 进行主成分分析
PCA <- princomp(data,cor = TRUE);summary(PCA)
#前四个主成分累积贡献率达到85%,第四主成分的标准差也接近1
#碎石图
screeplot(PCA,type="lines")
#选择前四个主成分,达到了降维的目的

 

根据碎石图和特征值,选择了前四个主成分做主成分回归分析,进行模型测试。 


# 主成分载荷
PCA$loadings
c <- cor(data);eigen(c)#主成分回归
pre<-predict(PCA)
data$z1<-pre[,1]
data$z2<-pre[,2]
data$z3<-pre[,3]
data$z4<-pre[,4]
data.lm<-lm(data$Price~z1+z2+z3+z4, data=data)
summary(data.lm)
#根据主成分分析的结果,F检验对应P值 = 5.535e-15,并且调整后的R平方为0.9386  ,模型通过了检验,可以认为模型的拟合效果较好。#对主成分模型作变换, 得到原坐标下的关系表达式:
beta<-coef(data.lm); A<-loadings(PCA)
x.bar<-PCA$center; x.sd<-PCA$scale
coef<-(beta[2]*A[,1]+ beta[3]*A[,2]+ beta[4]*A[,3]+beta[5]*A[,4])/x.sd
beta0 <- beta[1]- sum(x.bar * coef)
c(beta0, coef)
#得到的关系表达式为:
#Price = -323912.8 - 5313.315 * Manufacturer + 593.7563 * Series - 2284.516 * IntelCoreGen + 11652.16 * processingSpeed + 4293.208 * Ram 
# - 4.322066 * HDD + 37.29517 * SSD + 5564.728 * Graphics + 21796.82 * ScreenSize#测试模型,用第一组数据预测价格
Price = -323912.8 - 5313.315 * 1 + 593.7563 * 3 - 2284.516 * 7 + 11652.16 * 2.29 + 4293.208 * 4 - 4.322066 * 1000 + 37.29517 * 0 + 5564.728 * 0 + 21796.82 * 15.6
Price / 39057 #第一组的准确率为92.5%

         根据主成分分析的结果,F检验对应P值 = 5.535e-15,并且调整后的R平方为0.9386  ,模型通过了检验,可以认为模型的拟合效果较好。

        对主成分模型作变换, 得到原坐标下的关系表达式系数:

使用第一组数据对模型进行测试,结果如下: 

 如图,测试的结果有92.5%的准确率。

四、讨论和小结:联系实际,分析问题(对应第一部分提出的问题)

        1、根据分析,在使用主成分回归的方法后,得到了回归模型,并利用数据对笔记本电脑的价格进行了预测。可以说明,笔记本电脑的价格Manufacturer(笔记本制造商),Series(intel处理器系列),IntelCoreGen(intel处理器核心), processingSpeed(处理器主频), Ram(内存), HDD(机械硬盘), SSD(固态硬盘), Graphics(显存大小), ScreenSize(屏幕尺寸)之间有关系,但我认为该模型还可以再添加其他的参数,如散热水平,音质等,这些我认为也是影响笔记本电脑价格的因素。 

         2、 根据作图分析,以intel处理器的笔记本电脑为例,印度地区在2019年发售最多的笔记本电脑品牌是HP与Lenovo,而剩下的Dell与ASUS发售的款式较少,其中Dell发售的款式售价都较低,或许主打的是低端市场,而ASUS发售的款式价格有低的也有高的,面向了更多的用户。

        而发售机型较多的HP与Lenovo,然用户有了更多选择的空间。 用户也可能会考虑到不同制造商的口碑,来选择是否购买产品,而制造商也会因为口碑来调整产品的价格。

        在这四家厂商发售的电脑中,大多数笔记本电脑都配备了机械硬盘而没有配备固态硬盘,固态硬盘比机械硬盘有着更快的速度,但价格也更贵,可以看出配备了固态硬盘的笔记本电脑价格都比较高,内存与它相同,内存越大,笔记本电脑的价格也越高。可以看出,厂商们在选择了中等容量的内存条以及机械硬盘的时候,就是考虑到了印度的消费水平,这也解释了为什么笔记本电脑的参数为什么区别大,用户可以通过后期自行升级内存与硬盘的方式来得到更好的体验,同时满足了客户对价格与配置的需求。

这篇关于多元统计分析——基于R的笔记本电脑价格与参数可视化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1093583

相关文章

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python实现数据可视化图表生成(适合新手入门)

《Python实现数据可视化图表生成(适合新手入门)》在数据科学和数据分析的新时代,高效、直观的数据可视化工具显得尤为重要,下面:本文主要介绍Python实现数据可视化图表生成的相关资料,文中通过... 目录前言为什么需要数据可视化准备工作基本图表绘制折线图柱状图散点图使用Seaborn创建高级图表箱线图热

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键