File: dmaxe.c

package info (click to toggle)
grass 6.0.2-6
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 40,044 kB
  • ctags: 31,303
  • sloc: ansic: 321,125; tcl: 25,676; sh: 11,176; cpp: 10,098; makefile: 5,025; fortran: 1,846; yacc: 493; lex: 462; perl: 133; sed: 1
file content (37 lines) | stat: -rw-r--r-- 739 bytes parent folder | download | duplicates (2)
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
33
34
35
36
37
#include<stdio.h>
#include<stdlib.h>
#include<math.h>

double *dmax_exp (x, n)
  double *x;
  int n;
{
  static double y[2];
  double mean=0.0, zmax, tmax, *xcopy, t, z, fx;
  int i, dcmp();

  if ((xcopy = (double *) malloc (n * sizeof (double))) == NULL)
    fprintf (stderr, "Memory error in dmax_exp\n"), exit (-1);
 
  for (i = 0; i < n; ++i)
  {
    xcopy[i] = x[i];
    mean += x[i];
  }
  mean /=n;
  qsort (xcopy, n, sizeof (double), dcmp);
  for (i = 0; i < n; ++i)
  {
    fx = 1-exp(-xcopy[i]/mean);
    z = (double) (i+1) / (double) n - fx;
    t = fx - (double) i / (double) n;
    if (i == 0 || z > zmax)
      zmax = z;
    if (i == 0 || t > tmax)
      tmax = t;
  }
  y[0]=zmax;
  y[1]=tmax;
  free(xcopy);
  return y;
}