Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F99104976
min_parabol.c
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Mon, Jan 20, 00:27
Size
1 KB
Mime Type
text/x-c
Expires
Wed, Jan 22, 00:27 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23706810
Attached To
R1448 Lenstool-HPC
min_parabol.c
View Options
#include<stdio.h>
#include<math.h>
#include<fonction.h>
#include<constant.h>
#include<dimension.h>
#include<structure.h>
/****************************************************************/
/* nom: min_parabol */
/* auteur: Jean-Paul Kneib */
/* date: 10/02/92 */
/* place: Toulouse */
/* */
/* recherche d'un minimum dans le cas ou on a 3 points */
/* tels que (x1<x0<x2 ou x1>x0>x2) et (y0<y1<y2 ou y1>y2>y0) */
/****************************************************************/
double
min_parabol
(
double
x0
,
double
y0
,
double
x1
,
double
y1
,
double
x2
,
double
y2
)
{
const
extern
struct
g_mode
M
;
double
D1
,
D2
,
a
,
xmin
;
D1
=
slope
(
x0
,
y0
,
x1
,
y1
);
D2
=
slope
(
x0
,
y0
,
x2
,
y2
);
if
(
D1
*
D2
>
0.
)
{
NPRINTF
(
stderr
,
"ERROR: x0 not an estimated minimum"
);
NPRINTF
(
stderr
,
"
\t
%lf %lf %lf %lf %lf %lf %.3lf %.3lf
\n
"
,
x0
,
y0
,
x1
,
y1
,
x2
,
y2
,
D1
,
D2
);
return
(
x0
);
};
if
(
D1
==
0.
)
xmin
=
.5
*
(
x0
+
x1
);
else
if
(
D2
==
0.
)
xmin
=
.5
*
(
x0
+
x2
);
else
{
a
=
slope
(
x1
,
D1
,
x2
,
D2
);
xmin
=
.5
*
(
x0
+
.5
*
(
x1
+
x2
-
(
D1
+
D2
)
/
a
));
};
return
(
xmin
);
}
Event Timeline
Log In to Comment