代写算法程序,通过Linear Regression对CO2数据进行拟合。
Purpose
Fit data using linear regression least squares. Fit to a straight line and a
power law function. Test the relative success of the fits by calculating the
standard deviation in each case from the expression given in course notes
Algorithm
Write a program named ass3 that will enable the user to fit data to a simple
function. The application can analyze both linear and exponential data. If you
use dynamic memory to hold data, it must be released at the end of the
application.
Here is a data set for CO2 levels in the World at different years.
time - year | CO2 level ppm |
---|---|
1960 | 316.5 |
1965 | 320 |
1970 | 325 |
1975 | 331 |
1980 | 338 |
1985 | 346 |
1990 | 353 |
1995 | 360 |
2000 | 368.5 |
2005 | 378 |
The data is also supplied in the file CO2.txt. It is the same data as above | |
but 1960 has been subtracted from each of the years and 316.5 has been | |
subtracted from each CO2 level. In other words, 1960 is the start year and | |
levels are measured relative to what it was in that year. This is better data | |
to fit to since it does not accumulate large numbers (and so reduces epsilon | |
cancellation effects): |
CO2.txt
time - year | CO2 level ppm |
---|---|
5 | 3.5 |
10 | 8.5 |
15 | 14.5 |
20 | 21.5 |
25 | 29.5 |
30 | 36.5 |
35 | 43.5 |
40 | 52 |
45 | 61.5 |
When the application runs it offers the user two options. |
Option 1. Fit to a straight Line: C02 level = a*year + b
a and b are the constants calculated from the fit.
A data set to test your code is given in the file CO2.txt. It is the level of
carbon dioxide in the atmosphere measured at different years between 1960 and
2005. (NOTE: your code must be able to read a file with an arbitrary number of
points even though there are only 9 data points in this example).
In this linear case you are fitting the data to the straight line y = ax + b
, where y represents the CO2 level and x represents the year. Solve these
equations using the code discussed in class to get solutions for a and b. Use
the fit to offer the user the option of extrapolating into the future.
Option 2. Fit to a power law C02 level = a*year^b
a and b are the constants calculated from the fit.
You are fitting the data to the power law y = ax^b
where x and y refer to
years and CO2 levels respectively, as in the linear case. You will use the
data in the CO2.txt file, as in the linear case.
Your starting point for this is the appropriate transform discussed in class.
Make the transform so that the data can be fit to a linear function to
calculate c and m for this equation. The way to do this is take the natural
logs of y and x in the following way:
ln(y) = ln(ax^b) = ln(a) + ln(x^b) = ln(a) + bln(x)
so using the new variables Y = ln(y)
and X = ln(x)
we now have a
straight line equation again :
Y = A + bX
where A = ln(a). You can get a from the fit parameter A since a = ln^-1(A) = exp(A)
.
Write the code so that the file is read and a least squares fit is done. Use
the equation to give the user the option of extrapolating the CO2 level to
time in the future, as in the linear case.
An example of the output of the running application is given at the end. Yours
must work identically and produce identical (or very similar) output. When the
application terminates it releases all dynamically allocated memory so it does
not have a resource leak (or you lose 30%).
See the Marking Sheet for how you can lose marks, but you will lose at least
60% if: it fails to build in Visual Studio 2013, it crashes in normal
operation, it doesn’t produce the example output.
What to Submit
Use Blackboard to submit this assignment as a zip file (not RAR) containing
only the source code file(s) ass3.cpp (definitely not the entire project!).
The name of the zipped folder must contain your name as a prefix so that I can
identify it, for example using my name the file would be
tyleraAss3CST8233.zip. It is also vital that you include the Cover Information
(as specified in the Submission Standard) as a file header in your source file
so the file can be identified as yours. Use comment lines in the file to
include the header.
- Before you submit the code, check that it builds and executes in Visual Studio 2013 as you expect - if it doesn’t build for me, for whatever reason, you get a deduction of at least 60%.
- Make sure you have submitted the correct file - if I cannot build it because the file is wrong or missing from the zip, even if it’s an honest mistake, you get 0.
- Because of the imminent semester end, this assignment cannot be late.
Example Output:
Linear Regression of Data - Function Type Menu- Linear: y = a*x + b
- Power Law: y = a*x^b
- Quit
Select an option: 1
Please enter the name of the file to open:CO2.txt
FILE OPENED FOR READING
There are 9 records.
File read into memory
Linear: y = 1.451x -6.18
Standard Deviation = 1.553
Extapolation of data Menu
- Do an extrapolation
- Return to main menu
Select an option: 1
Input a year (e.g. 2020) to extrapolate to: 2030 y(2030) = 411.9
Extapolation of data Menu
- Do an extrapolation
- Return to main menu
Select an option: 2
Linear Regression of Data - Function Type Menu
- Linear: y = a*x + b
- Power Law: y = a*x^b
- Quit
Select an option: 2
Please enter the name of the file to open:CO2.txt
FILE OPENED FOR READING
There are 9 records.
File read into memory
Power Law: y = 0.426x^1.31
Standard Deviation = 0.0172
Extapolation of data Menu
- Do an extrapolation
- Return to main menu
Select an option: 1
Input a year to extrapolate to: 2030 y(2.03e+003) = 426
Extapolation of data Menu
- Do an extrapolation
- Return to main menu
Select an option: