line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
/* |
2
|
|
|
|
|
|
|
*+ |
3
|
|
|
|
|
|
|
* Name: |
4
|
|
|
|
|
|
|
* palInvf |
5
|
|
|
|
|
|
|
|
6
|
|
|
|
|
|
|
* Purpose: |
7
|
|
|
|
|
|
|
* Invert a linear model of the type produced by the palFitxy routine. |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
* Language: |
10
|
|
|
|
|
|
|
* Starlink ANSI C |
11
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
* Type of Module: |
13
|
|
|
|
|
|
|
* Library routine |
14
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
* Invocation: |
16
|
|
|
|
|
|
|
* palInvf ( double fwds[6], double bkwds[6], int *j ) |
17
|
|
|
|
|
|
|
|
18
|
|
|
|
|
|
|
* Arguments: |
19
|
|
|
|
|
|
|
* fwds = double[6] (Given) |
20
|
|
|
|
|
|
|
* model coefficients |
21
|
|
|
|
|
|
|
* bkwds = double[6] (Returned) |
22
|
|
|
|
|
|
|
* inverse model |
23
|
|
|
|
|
|
|
* j = int (Returned) |
24
|
|
|
|
|
|
|
* status: 0 = OK, -1 = no inverse |
25
|
|
|
|
|
|
|
|
26
|
|
|
|
|
|
|
* Description: |
27
|
|
|
|
|
|
|
* The models relate two sets of [x,y] coordinates as follows. |
28
|
|
|
|
|
|
|
* Naming the elements of fwds: |
29
|
|
|
|
|
|
|
* --- |
30
|
|
|
|
|
|
|
* fwds[0] = A |
31
|
|
|
|
|
|
|
* fwds[1] = B |
32
|
|
|
|
|
|
|
* fwds[2] = C |
33
|
|
|
|
|
|
|
* fwds[3] = D |
34
|
|
|
|
|
|
|
* fwds[4] = E |
35
|
|
|
|
|
|
|
* fwds[5] = F |
36
|
|
|
|
|
|
|
* --- |
37
|
|
|
|
|
|
|
* where two sets of coordinates [x1,y1] and [x2,y2] are related |
38
|
|
|
|
|
|
|
* thus: |
39
|
|
|
|
|
|
|
* --- |
40
|
|
|
|
|
|
|
* x2 = A + B * x1 + C * y1 |
41
|
|
|
|
|
|
|
* y2 = D + E * x1 + F * y1 |
42
|
|
|
|
|
|
|
* --- |
43
|
|
|
|
|
|
|
* the present routine generates a new set of coefficients: |
44
|
|
|
|
|
|
|
* --- |
45
|
|
|
|
|
|
|
* bkwds[0] = P |
46
|
|
|
|
|
|
|
* bkwds[1] = Q |
47
|
|
|
|
|
|
|
* bkwds[2] = R |
48
|
|
|
|
|
|
|
* bkwds[3] = S |
49
|
|
|
|
|
|
|
* bkwds[4] = T |
50
|
|
|
|
|
|
|
* bkwds[5] = U |
51
|
|
|
|
|
|
|
* --- |
52
|
|
|
|
|
|
|
* such that: |
53
|
|
|
|
|
|
|
* --- |
54
|
|
|
|
|
|
|
* x1 = P + Q * x2 + R * y2 |
55
|
|
|
|
|
|
|
* y1 = S + T * x2 + U * y2 |
56
|
|
|
|
|
|
|
* --- |
57
|
|
|
|
|
|
|
* Two successive calls to palInvf will thus deliver a set |
58
|
|
|
|
|
|
|
* of coefficients equal to the starting values. |
59
|
|
|
|
|
|
|
|
60
|
|
|
|
|
|
|
* See also: |
61
|
|
|
|
|
|
|
* palFitxy, palPxy, palXy2xy and palDcmpf |
62
|
|
|
|
|
|
|
|
63
|
|
|
|
|
|
|
* Authors: |
64
|
|
|
|
|
|
|
* PTW: Pat Wallace (STFC) |
65
|
|
|
|
|
|
|
* GSB: Graham Bell (EAO) |
66
|
|
|
|
|
|
|
|
67
|
|
|
|
|
|
|
* History: |
68
|
|
|
|
|
|
|
* 1990-04-11 (PTW): |
69
|
|
|
|
|
|
|
* SLALIB implementation. |
70
|
|
|
|
|
|
|
* 2004-12-26 (PTW): |
71
|
|
|
|
|
|
|
* Documentation updated. |
72
|
|
|
|
|
|
|
* 2018-10-23 (GSB): |
73
|
|
|
|
|
|
|
* Initial version in C. |
74
|
|
|
|
|
|
|
|
75
|
|
|
|
|
|
|
* Copyright: |
76
|
|
|
|
|
|
|
* Copyright P.T.Wallace. All rights reserved. |
77
|
|
|
|
|
|
|
* Copyright (C) 2018 East Asian Observatory. |
78
|
|
|
|
|
|
|
|
79
|
|
|
|
|
|
|
* Licence: |
80
|
|
|
|
|
|
|
* This program is free software; you can redistribute it and/or modify |
81
|
|
|
|
|
|
|
* it under the terms of the GNU General Public License as published by |
82
|
|
|
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or |
83
|
|
|
|
|
|
|
* (at your option) any later version. |
84
|
|
|
|
|
|
|
* |
85
|
|
|
|
|
|
|
* This program is distributed in the hope that it will be useful, |
86
|
|
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
87
|
|
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
88
|
|
|
|
|
|
|
* GNU General Public License for more details. |
89
|
|
|
|
|
|
|
* |
90
|
|
|
|
|
|
|
* You should have received a copy of the GNU General Public License |
91
|
|
|
|
|
|
|
* along with this program (see SLA_CONDITIONS); if not, write to the |
92
|
|
|
|
|
|
|
* Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
93
|
|
|
|
|
|
|
* Boston, MA 02110-1301 USA |
94
|
|
|
|
|
|
|
*- |
95
|
|
|
|
|
|
|
*/ |
96
|
|
|
|
|
|
|
|
97
|
1
|
|
|
|
|
|
void palInvf ( double fwds[6], double bkwds[6], int *j ) { |
98
|
|
|
|
|
|
|
double a, b, c, d, e, f, det; |
99
|
|
|
|
|
|
|
|
100
|
1
|
|
|
|
|
|
a = fwds[0]; |
101
|
1
|
|
|
|
|
|
b = fwds[1]; |
102
|
1
|
|
|
|
|
|
c = fwds[2]; |
103
|
1
|
|
|
|
|
|
d = fwds[3]; |
104
|
1
|
|
|
|
|
|
e = fwds[4]; |
105
|
1
|
|
|
|
|
|
f = fwds[5]; |
106
|
1
|
|
|
|
|
|
det = b * f - c * e; |
107
|
|
|
|
|
|
|
|
108
|
1
|
50
|
|
|
|
|
if ( det != 0.0 ) { |
109
|
1
|
|
|
|
|
|
bkwds[0] = (c * d - a * f) / det; |
110
|
1
|
|
|
|
|
|
bkwds[1] = f / det; |
111
|
1
|
|
|
|
|
|
bkwds[2] = -c / det; |
112
|
1
|
|
|
|
|
|
bkwds[3] = (a * e - b * d) / det; |
113
|
1
|
|
|
|
|
|
bkwds[4] = -e / det; |
114
|
1
|
|
|
|
|
|
bkwds[5] = b / det; |
115
|
1
|
|
|
|
|
|
*j = 0; |
116
|
|
|
|
|
|
|
} else { |
117
|
0
|
|
|
|
|
|
*j = -1; |
118
|
|
|
|
|
|
|
} |
119
|
1
|
|
|
|
|
|
} |