File: dB.c

package info (click to toggle)
siggen 2.3.10-5
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd, wheezy
  • size: 992 kB
  • ctags: 1,111
  • sloc: ansic: 5,551; makefile: 187; sh: 79
file content (52 lines) | stat: -rw-r--r-- 1,047 bytes parent folder | download | duplicates (6)
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/* dB.c
 * converts dB valuesgiven as parameters into linear ratio values
 * i.e. dB 20   will give the value 10
 *      dB 26   will give the value 20
 *      dB 0                        1
 */

#include <math.h>

#define db(x) pow(10,x/20.0)

main(argc,argv)
int argc;
char **argv;
{
  int i,j,k,n,inv;
  double x;

  argc--; argv++;
  for ( inv=0 ; argc; argc--, argv++) {
    if (strcmp(*argv,"-i")==0) { inv=1; continue; }
    x=(double)(atoi(*argv));
    if (inv==0)
      printf("%fdB = %f times\n",x,db(x));
    else
      printf("%fdB = %f times\n",20.0*log10(x),x);
  }
}

/*
double db(x)
double x;
{
  return(pow(10,x/20.0);
}
*/
/*
db(x)
int x;
{
  int i;
  static int dB_Conv[20]={
      100000000,  112201845,  125892541,  141253754,  158489319,
      177827941,  199526231,  223872114,  251188643,  281838293,
      316227766,  354813389,  398107171,  446683592,  501187234,
      562341325,  630957344,  707945784,  794328235,  891250938
  };

  for (i=100000000; i && x>=20; x-=20) { i/=10; }
  return((i)?(dB_Conv[x]/i):-1);
}
*/