summaryrefslogtreecommitdiff
path: root/songdbj/de/jarnbjo/vorbis/Util.java
blob: 7e31c9495eeaf67f82c102907bc1164d06f2b1f0 (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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
 * $ProjectName$
 * $ProjectRevision$
 * -----------------------------------------------------------
 * $Id$
 * -----------------------------------------------------------
 *
 * $Author$
 *
 * Description:
 *
 * Copyright 2002-2003 Tor-Einar Jarnbjo
 * -----------------------------------------------------------
 *
 * Change History
 * -----------------------------------------------------------
 * $Log$
 * Revision 1.1  2005/07/11 15:42:36  hcl
 * Songdb java version, source. only 1.5 compatible
 *
 * Revision 1.1.1.1  2004/04/04 22:09:12  shred
 * First Import
 *
 * Revision 1.3  2003/04/10 19:49:04  jarnbjo
 * no message
 *
 * Revision 1.2  2003/03/16 01:11:12  jarnbjo
 * no message
 *
 *
 */

package de.jarnbjo.vorbis;

final public class Util {

   public static final int ilog(int x) {
      int res=0;
      for(; x>0; x>>=1, res++);
      return res;
   }

   public static final float float32unpack(int x) {
      float mantissa=x&0x1fffff;
      float e=(x&0x7fe00000)>>21;
      if((x&0x80000000)!=0) {
         mantissa=-mantissa;
      }
      return mantissa*(float)Math.pow(2.0, e-788.0);
   }

   public static final int lookup1Values(int a, int b) {
      int res=(int)Math.pow(Math.E, Math.log(a)/b);
      return intPow(res+1, b)<=a?res+1:res;
   }

   public static final int intPow(int base, int e) {
      int res=1;
      for(; e>0; e--, res*=base);
      return res;
   }

   public static final boolean isBitSet(int value, int bit) {
      return (value&(1<<bit))!=0;
   }

   public static final int icount(int value) {
      int res=0;
      while(value>0) {
         res+=value&1;
         value>>=1;
      }
      return res;
   }

   public static final int lowNeighbour(int[] v, int x) {
      int max=-1, n=0;
      for(int i=0; i<v.length && i<x; i++) {
         if(v[i]>max && v[i]<v[x]) {
            max=v[i];
            n=i;
         }
      }
      return n;
   }

   public static final int highNeighbour(int[] v, int x) {
      int min=Integer.MAX_VALUE, n=0;
      for(int i=0; i<v.length && i<x; i++) {
         if(v[i]<min && v[i]>v[x]) {
            min=v[i];
            n=i;
         }
      }
      return n;
   }

   public static final int renderPoint(int x0, int x1, int y0, int y1, int x) {
      int dy=y1-y0;
      int ady=dy<0?-dy:dy;
      int off=(ady*(x-x0))/(x1-x0);
      return dy<0?y0-off:y0+off;
   }

   public static final void renderLine(final int x0, final int y0, final int x1, final int y1, final float[] v) {
      final int dy=y1-y0;
      final int adx=x1-x0;
      final int base=dy/adx;
      final int sy=dy<0?base-1:base+1;
      int x=x0;
      int y=y0;
      int err=0;
      final int ady=(dy<0?-dy:dy)-(base>0?base*adx:-base*adx);

      v[x]*=Floor.DB_STATIC_TABLE[y];
      for(x=x0+1; x<x1; x++) {
         err+=ady;
         if(err>=adx) {
            err-=adx;
            v[x]*=Floor.DB_STATIC_TABLE[y+=sy];
         }
         else {
            v[x]*=Floor.DB_STATIC_TABLE[y+=base];
         }
      }
   }
}