-
Notifications
You must be signed in to change notification settings - Fork 1
/
float.c
50 lines (40 loc) · 1.43 KB
/
float.c
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
////////////////////////////////////////////////////////////////////////////
// **** WAVPACK **** //
// Hybrid Lossless Wavefile Compressor //
// Copyright (c) 1998 - 2006 Conifer Software. //
// All Rights Reserved. //
// Distributed under the BSD Software License (see license.txt) //
////////////////////////////////////////////////////////////////////////////
// float.c
#include "wavpack.h"
int read_float_info (WavpackStream *wps, WavpackMetadata *wpmd)
{
int bytecnt = wpmd->byte_length;
char *byteptr = wpmd->data;
if (bytecnt != 4)
return FALSE;
wps->float_flags = *byteptr++;
wps->float_shift = *byteptr++;
wps->float_max_exp = *byteptr++;
wps->float_norm_exp = *byteptr;
return TRUE;
}
void float_values (WavpackStream *wps, int32_t *values, int32_t num_values)
{
int shift = wps->float_max_exp - wps->float_norm_exp + wps->float_shift;
if (shift > 32)
shift = 32;
else if (shift < -32)
shift = -32;
while (num_values--) {
if (shift > 0)
*values <<= shift;
else if (shift < 0)
*values >>= -shift;
if (*values > 8388607L)
*values = 8388607L;
else if (*values < -8388608L)
*values = -8388608L;
values++;
}
}