blob: 819ec3863e5385d3d300358e0035b21ec7bd26bf (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
/* PR target/10114 */
/* Originator: James Troup <james@nocrew.org> */
/* { dg-do compile } */
/* { dg-options "-g -O1" } */
extern __inline double sqrt (double __x)
{
register double __r;
__asm ("fsqrtd %1,%0" : "=f" (__r) : "f" (__x));
return __r;
}
static double our_skew, max_update_skew;
static double Sqr(double x)
{
return x*x;
}
void REF_SetReference(double skew)
{
double previous_skew, new_skew;
double old_weight, new_weight, sum_weight;
double delta_freq1, delta_freq2;
double skew1, skew2;
previous_skew = our_skew;
skew1 = sqrt((Sqr(delta_freq1) * old_weight + Sqr(delta_freq2) * new_weight) / sum_weight);
skew2 = (previous_skew * old_weight + new_skew * new_weight) / sum_weight;
our_skew = skew1 + skew2;
}
|