आर - रैखिक प्रतिगमन
प्रतिगमन विश्लेषण दो चर के बीच संबंध मॉडल स्थापित करने के लिए एक बहुत व्यापक रूप से इस्तेमाल किया जाने वाला सांख्यिकीय उपकरण है। इनमें से एक वैरिएबल को प्रेडिक्टर वैरिएबल कहा जाता है जिसका मान प्रयोगों के माध्यम से इकट्ठा किया जाता है। दूसरे चर को प्रतिक्रिया चर कहा जाता है जिसका मान पूर्वसूचक चर से लिया गया है।
रैखिक प्रतिगमन में ये दो चर एक समीकरण के माध्यम से संबंधित होते हैं, जहां इन दोनों चर के घातांक (शक्ति) 1. गणितीय रूप से एक रेखीय संबंध एक सीधी रेखा का प्रतिनिधित्व करता है जब ग्राफ के रूप में प्लॉट किया जाता है। एक गैर-रैखिक संबंध जहां किसी भी चर का घातांक 1 के बराबर नहीं है, एक वक्र बनाता है।
एक रेखीय प्रतिगमन के लिए सामान्य गणितीय समीकरण है -
y = ax + b
निम्नलिखित मापदंडों का वर्णन है -
y प्रतिक्रिया चर है।
x भविष्यवक्ता चर है।
a तथा b स्थिरांक हैं जिन्हें गुणांक कहा जाता है।
एक प्रतिगमन स्थापित करने के लिए कदम
प्रतिगमन का एक सरल उदाहरण एक व्यक्ति के वजन की भविष्यवाणी कर रहा है जब उसकी ऊंचाई ज्ञात होती है। ऐसा करने के लिए हमें किसी व्यक्ति की ऊंचाई और वजन के बीच संबंध होना चाहिए।
संबंध बनाने के लिए कदम है -
ऊंचाई और इसी वजन के मनाया मूल्यों के एक नमूने को इकट्ठा करने का प्रयोग करें।
का उपयोग कर एक संबंध मॉडल बनाएं lm() कार्यों में आर।
बनाए गए मॉडल से गुणांक का पता लगाएं और इनका उपयोग करके गणितीय समीकरण बनाएं
भविष्यवाणी में औसत त्रुटि जानने के लिए संबंध मॉडल का सारांश प्राप्त करें। यह भी कहा जाता हैresiduals।
नए व्यक्तियों के वजन की भविष्यवाणी करने के लिए, का उपयोग करें predict() समारोह में आर।
इनपुट डेटा
नीचे अवलोकनों का प्रतिनिधित्व करने वाला नमूना डेटा है -
# Values of height
151, 174, 138, 186, 128, 136, 179, 163, 152, 131
# Values of weight.
63, 81, 56, 91, 47, 57, 76, 72, 62, 48
lm () फ़ंक्शन
यह फ़ंक्शन भविष्यवक्ता और प्रतिक्रिया चर के बीच संबंध मॉडल बनाता है।
वाक्य - विन्यास
के लिए मूल वाक्यविन्यास lm() रैखिक प्रतिगमन में कार्य है -
lm(formula,data)
निम्नलिखित मापदंडों का वर्णन है -
formula x और y के बीच के संबंध को प्रस्तुत करने वाला एक प्रतीक है।
data वह वेक्टर है जिस पर सूत्र लागू किया जाएगा।
संबंध मॉडल बनाएं और गुणांक प्राप्त करें
x <- c(151, 174, 138, 186, 128, 136, 179, 163, 152, 131)
y <- c(63, 81, 56, 91, 47, 57, 76, 72, 62, 48)
# Apply the lm() function.
relation <- lm(y~x)
print(relation)
जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Call:
lm(formula = y ~ x)
Coefficients:
(Intercept) x
-38.4551 0.6746
रिश्ते का सारांश प्राप्त करें
x <- c(151, 174, 138, 186, 128, 136, 179, 163, 152, 131)
y <- c(63, 81, 56, 91, 47, 57, 76, 72, 62, 48)
# Apply the lm() function.
relation <- lm(y~x)
print(summary(relation))
जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Call:
lm(formula = y ~ x)
Residuals:
Min 1Q Median 3Q Max
-6.3002 -1.6629 0.0412 1.8944 3.9775
Coefficients:
Estimate Std. Error t value Pr(>|t|)
(Intercept) -38.45509 8.04901 -4.778 0.00139 **
x 0.67461 0.05191 12.997 1.16e-06 ***
---
Signif. codes: 0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1
Residual standard error: 3.253 on 8 degrees of freedom
Multiple R-squared: 0.9548, Adjusted R-squared: 0.9491
F-statistic: 168.9 on 1 and 8 DF, p-value: 1.164e-06
भविष्यवाणी () समारोह
वाक्य - विन्यास
रैखिक प्रतिगमन में पूर्वानुमान के लिए मूल सिंटैक्स है -
predict(object, newdata)
निम्नलिखित मापदंडों का वर्णन है -
object सूत्र है जो पहले ही lm () फ़ंक्शन का उपयोग करके बनाया गया है।
newdata सदिश भविष्य कहनेवाला चर के लिए नए मूल्य युक्त वेक्टर है।
नए व्यक्तियों के वजन की भविष्यवाणी करें
# The predictor vector.
x <- c(151, 174, 138, 186, 128, 136, 179, 163, 152, 131)
# The resposne vector.
y <- c(63, 81, 56, 91, 47, 57, 76, 72, 62, 48)
# Apply the lm() function.
relation <- lm(y~x)
# Find weight of a person with height 170.
a <- data.frame(x = 170)
result <- predict(relation,a)
print(result)
जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
1
76.22869
चित्रण को रेखांकन रूप से देखें
# Create the predictor and response variable.
x <- c(151, 174, 138, 186, 128, 136, 179, 163, 152, 131)
y <- c(63, 81, 56, 91, 47, 57, 76, 72, 62, 48)
relation <- lm(y~x)
# Give the chart file a name.
png(file = "linearregression.png")
# Plot the chart.
plot(y,x,col = "blue",main = "Height & Weight Regression",
abline(lm(x~y)),cex = 1.3,pch = 16,xlab = "Weight in Kg",ylab = "Height in cm")
# Save the file.
dev.off()
जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -