2287. Fit

单点时限: 2.0 sec

内存限制: 256 MB

In science there are often data points (xi, yi) measured, for which an affine correlation is assumed by theory. That means, you can choose the parameters a and b for a straight line f(x)=a+b*x in such a way, that the sum of the squared y-distances (Chi2) from the points to the line is very low.

For example, if the points (1,2), (2,3) and (3,4) are measured, the line f(x)=1+1*x fits the points best, cause Chi2 then equals 0. That was easy! Now to a more challenging example: How should a and b be chosen, if the second point would be (2,2) instead of (2,3)?

Maybe you found out, that b again is 1, and a is about 0.67. If not, don’t worry, I’ll give you some hints to find out a and b for even more difficult situations. And you’ll need those hints, cause reality is even harder!

For example, imagine two police men. They want to know, if the average value of alcohol in people increases in the evening and if so, how fast. To this end, they stop one car exactly every 5 Minutes to measure the drunkness of the driver. This means an exact xi value (where i is an index which tells how many cars have been stoped before). Unfortunatelly, the alcohol analysers are still not so exact, so the yi value is not known for sure. But at least their analyser is good enough to give some information about the uncertainty of the measured yi-value, which will be called sigmai in the following.

In science and measurement it very often happens, that the y value can not be measured exactly, and you can only say that the real value is in the intervall [ yi-sigmai , yi+sigmai ] with a probability of 68%. You see why sigmai often is called uncertainty of yi: The bigger the sigmai, the less you know about the real value.

Now the police men have lots of triples (xi, yi, sigmai). Your task is to help them find out the best fit parameters a and b for the straight line, with which they can see, if and how fast the drunkness is increasing in the evening.

To make your task easier, I give you some tips. In the first sentences it was said, that the Chi^2 is the sum over the squared differences between f(xi) and yi. But now the y-coordinate is not so sure anymore, and so you have to divide each of those differences by the corresponding sigma value before squaring and summing. By this, you make sure that values, which are not so very well known (big sigma) are less much counted than values, which are nearly exactly known (small sigma).

To get the best fit with the given values (xi, yi, sigmai) you have to minimize the Chi^2, which means you have to build the derivative of (1)

with respect to a and b and set them equal to zero. That means you get an equation system with 2 equations and 2 unknown variables (a and b). By solving this equation system you get (check this to learn more!!!) :

This looks awful! But thats why nobody (including our police man and all scientists) wants to calculate a and b by hand. For your task - writing a little programm to calculate a and b - you only need (2)-(4). But be sure to write a memory efficient programm, there could be millions of triples!!! Though this looks like lots of work, if you’re clever you will only need about 10 lines for the main part of the programm plus some lines for in- and output.

输入格式

The input starts with a single int n which indicates the number of datasets. Each set will consist of an unknown number of lines. In each line there will be three integers, xi , yi , and sigmai , respectively, which are separated by one or more blanks. If there is a line in which sigmai equals zero, this means the end of this dataset and the beginning of a new one. The line with sigmai =0 only is there to show this, it musn’t be used as data itself.

You can assume, that each x-value appears at maximum once in each dataset.

输出格式

For each dataset you have to put out the parameters of the least Chi2-Fit under respect of the uncertainties. To be precise, for each dataset output the parameter a rounded to the second decimal place, then exactly one space, then the parameter b,again rounded to the second decimal place, and then at once a newline.

If a parameter is negativ, there should be no space between the minus sign and the number. For positive parameters don’t print a sign!

样例

Input
4
1 1 1
2 1 1
0 0 0
1 2 1
2 3 1
3 4 1
0 0 0
1 2 1
2 2 1
3 4 1
0 0 0
1 2 1
2 2 1
3 4 5
0 0 0
Output
1.00 0.00
1.00 1.00
0.67 1.00
1.73 0.20

3 人解决,4 人已尝试。

3 份提交通过,共有 7 份提交。

7.9 EMB 奖励。

创建: 16 年,5 月前.

修改: 7 年,4 月前.

最后提交: 4 年,1 月前.

来源: Freshman Programming Contest

题目标签