data:image/s3,"s3://crabby-images/22491/2249133263f0c3d43c5aa9eae22364551e89c5a4" alt="Home" |
Microsoft Visual C# Statistics:
The Linear Correlation Coefficient |
|
|
In statistics, a correlation is a value that defines a
relationship between two variables so that it shows how one of the
variables is tied (related) to the other.
|
The linear correlation coefficient, represented as r,
defines the strength of the correlation between two elements of a sample.
The elements are usually represented with x and y. This almost means that
a value is considered as a pair of x and y.
The linear correlation coefficient is also called the
Pearson product moment correlation coefficient (from Karl Pearson
(1857-1936)).
The formula to calculate the linear correlation
coefficient is:
data:image/s3,"s3://crabby-images/3e626/3e626a03943794614f07cf66147988093060ec62" alt="Linear Correlation Coefficient"
|
|
The factors in this equation are:
Factor |
Description |
n |
The number of pairs of elements |
x |
An element of the series |
y |
The element corresponding to x in the pair |
Σx |
The sum of the x elements |
Σy |
The sum of the y elements |
Σxy |
The sum of the products of each pair |
Σx2 |
The sum of the squares of the x values |
(Σx)2 |
The square of the Σx sums |
Σy2 |
The sum of the squares of the y values |
(Σy)2 |
The square of the Σy sum |
Application:
Creating the Application
|
|
- Start Microsoft Visual Studio
- To create a new application, on the main menu, click File -> New
Project...
- In the middle list, click Windows Forms Application
- Change the Name to LinearCorrelationCoefficient1
- Click OK
- In the Solution Explorer, right-click Form1.cs and click Rename
- Type Exercise.cs and press Enter
- Design the form as follows:
data:image/s3,"s3://crabby-images/fa032/fa03206aca09053caa207af28868ef7ad5f5134c" alt="Linear Correlation Coefficient" |
Control |
(Name) |
Text |
Other Properties |
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
x |
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
y |
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Values to Add: |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="ListBox" |
txtX |
|
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="ListBox" |
txtY |
|
|
Button |
data:image/s3,"s3://crabby-images/887b3/887b37ed52699d8292ba5648d62d66129730ad30" alt="Button" |
btnAdd |
Add |
|
ListView |
data:image/s3,"s3://crabby-images/3cfdd/3cfddb5fce85060ad4770a888776e78ed9360cc8" alt="Label" |
lvwValues |
|
FullRowSelect: True GridLines: True View:
Details |
Columns |
|
(Name) |
Text |
TextAlign |
Width |
colIndex |
# |
|
30 |
colX |
x |
Right |
70 |
colY |
y |
Right |
70 |
colXSquared |
x2 |
Right |
90 |
colYSquared |
y2 |
Right |
90 |
colXY |
xy |
Right |
100 |
|
Button |
data:image/s3,"s3://crabby-images/887b3/887b37ed52699d8292ba5648d62d66129730ad30" alt="Button" |
btnCalculate |
Calculate |
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
n = |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtN |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Σx = |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtSumX |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Σx2 = |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtSumXSquare |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Σxy = |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtSumXY |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Σy = |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtSumY |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Σy2 = |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtSumYSquare |
|
|
PictureBox |
data:image/s3,"s3://crabby-images/734ed/734ed09fd44faf8cd05cf3454813f10ef20f1086" alt="PictureBox" |
pbxR |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
= |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="Text Box" |
txtR |
|
|
Label |
data:image/s3,"s3://crabby-images/f1f8e/f1f8eb82c90828a8c52e8a24846f0828a224c1e5" alt="Label" |
|
Conclusion |
|
TextBox |
data:image/s3,"s3://crabby-images/20276/20276ffdd1d79ac43b9e366254b2d899f462221a" alt="ListBox" |
txtConclusion |
|
|
Button |
data:image/s3,"s3://crabby-images/887b3/887b37ed52699d8292ba5648d62d66129730ad30" alt="Button" |
btnClear |
Clear/Reset |
|
Button |
data:image/s3,"s3://crabby-images/887b3/887b37ed52699d8292ba5648d62d66129730ad30" alt="Button" |
btnClose |
Close |
|
|
- Double-click an unoccupied area of the form
- Return to the form and double-click the Add button
- Return to the form
- Double-click the Calculate button
- Return to the form
- Double-click the Clear/Reset button
- Return to the form
- Double-click the Close button
- Change the file as follows:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace LinearCorrelationCoefficient1
{
public partial class LinearCorrelationCoefficient : Form
{
List<SamplePair> pairs;
public LinearCorrelationCoefficient()
{
InitializeComponent();
}
private void ShowPairs()
{
lvwValues.Items.Clear();
double SumX = 0.00, SumY = 0.00,
SumXSquare = 0.00, SumYSquare = 0.00,
SumXY = 0.00;
int i = 0;
foreach( SamplePair sp in pairs)
{
ListViewItem lviPair = new ListViewItem((i + 1).ToString());
lviPair.SubItems.Add(sp.x.ToString("F"));
lviPair.SubItems.Add(sp.y.ToString("F"));
lviPair.SubItems.Add(sp.xSquared.ToString("0.0000#"));
lviPair.SubItems.Add(sp.ySquared.ToString("0.0000#"));
lviPair.SubItems.Add(sp.xy.ToString("0.0000#"));
lvwValues.Items.Add(lviPair);
i++;
}
foreach (SamplePair sp in pairs)
{
SumX += sp.x;
SumY += sp.y;
SumXSquare += (sp.x * sp.x);
SumYSquare += (sp.y * sp.y);
SumXY += (sp.x * sp.y);
}
ListViewItem lviTotals = new ListViewItem("Totals");
lviTotals.SubItems.Add("Σx = " + SumX.ToString("F"));
lviTotals.SubItems.Add("Σy = " + SumY.ToString("F"));
lviTotals.SubItems.Add("Σx² = " + SumXSquare.ToString("0.0000#"));
lviTotals.SubItems.Add("Σy² = " + SumYSquare.ToString("0.0000#"));
lviTotals.SubItems.Add("Σxy = " + SumXY.ToString("0.0000#"));
lvwValues.Items.Add(lviTotals);
}
private void LinearCorrelationCoefficient_Load(object sender,
EventArgs e)
{
pairs = new List<SamplePair>();
}
private void btnAdd_Click(object sender, EventArgs e)
{
double x = 0.00, y = 0.00;
if( txtX.Text == "" )
{
MessageBox.Show("You must enter a value for x.");
return;
}
if (txtY.Text == "")
{
MessageBox.Show("You must enter a value for y.");
return;
}
try
{
x = double.Parse(txtX.Text);
}
catch (FormatException)
{
}
try
{
y = double.Parse(txtY.Text);
}
catch (FormatException)
{
}
SamplePair pair = new SamplePair(x, y);
pairs.Add(pair);
ShowPairs();
txtX.Text = "";
txtY.Text = "";
txtX.Focus();
ShowPairs();
}
private void btnCalculate_Click(object sender, EventArgs e)
{
double SumX = 0.00, SumY = 0.00,
SumXSquare = 0.00, SumYSquare = 0.00,
SumXY = 0.00, r = 0.00;
foreach (SamplePair sp in pairs)
{
SumX += sp.x;
SumY += sp.y;
SumXSquare += (sp.x * sp.x);
SumYSquare += (sp.y * sp.y);
SumXY += (sp.x * sp.y);
}
double NTimesSumXY = pairs.Count * SumXY;
double SumXTimesSumY = SumX * SumY;
double SquareRoot1 = pairs.Count * SumXSquare - Math.Pow(SumX, 2);
double SquareRoot2 = pairs.Count * SumYSquare - Math.Pow(SumY, 2);
r = (NTimesSumXY - SumXTimesSumY) / (Math.Sqrt(SquareRoot1) *
Math.Sqrt(SquareRoot2));
txtN.Text = pairs.Count.ToString();
txtSumX.Text = SumX.ToString("F");
txtSumY.Text = SumY.ToString("F");
txtSumXSquare.Text = SumXSquare.ToString();
txtSumYSquare.Text = SumYSquare.ToString();
txtSumXY.Text = SumXY.ToString("F");
txtR.Text = r.ToString("0.00#");
}
private void btnClear_Click(object sender, EventArgs e)
{
pairs.Clear();
lvwValues.Items.Clear();
txtN.Text = "";
txtSumX.Text = "";
txtSumY.Text = "";
txtSumXSquare.Text = "";
txtSumYSquare.Text = "";
txtSumXY.Text = "";
txtR.Text = "";
}
private void btnClose_Click(object sender, EventArgs e)
{
Close();
}
}
public class SamplePair
{
public double x { get; set; }
public double y { get; set; }
public SamplePair(double X, double Y)
{
x = X;
y = Y;
}
public double xSquared
{
get
{
return x * x;
}
}
public double ySquared
{
get
{
return y * y;
}
}
public double xy
{
get
{
return x * y;
}
}
}
}
- To execute, press F5
- Enter each pair of values and click Add each time
data:image/s3,"s3://crabby-images/3bbb2/3bbb22db4ae747d019084cc17764a0ecb7a2ddc6" alt="Linear Correlation Coefficient"
- After adding the values, click Calculate
data:image/s3,"s3://crabby-images/a0b07/a0b077f191704e8fe8dd31353e68a84b8e3f8809" alt="Linear Correlation Coefficient"
- Close the form and return to your programming environment
Application
|
|