u_math.c

Go to the documentation of this file.
00001 /**************************************************************************
00002  * 
00003  * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
00004  * All Rights Reserved.
00005  * 
00006  * Permission is hereby granted, free of charge, to any person obtaining a
00007  * copy of this software and associated documentation files (the
00008  * "Software"), to deal in the Software without restriction, including
00009  * without limitation the rights to use, copy, modify, merge, publish,
00010  * distribute, sub license, and/or sell copies of the Software, and to
00011  * permit persons to whom the Software is furnished to do so, subject to
00012  * the following conditions:
00013  * 
00014  * The above copyright notice and this permission notice (including the
00015  * next paragraph) shall be included in all copies or substantial portions
00016  * of the Software.
00017  * 
00018  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
00019  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
00020  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
00021  * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
00022  * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
00023  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
00024  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
00025  * 
00026  **************************************************************************/
00027 
00028 
00029 
00030 #include "util/u_math.h"
00031 
00032 
00034 float pow2_table[POW2_TABLE_SIZE];
00035 
00036 
00037 static void
00038 init_pow2_table(void)
00039 {
00040    int i;
00041    for (i = 0; i < POW2_TABLE_SIZE; i++)
00042       pow2_table[i] = (float) pow(2.0, (i - POW2_TABLE_OFFSET) / POW2_TABLE_SCALE);
00043 }
00044 
00045 
00047 float log2_table[LOG2_TABLE_SIZE];
00048 
00049 
00050 static void 
00051 init_log2_table(void)
00052 {
00053    unsigned i;
00054    for (i = 0; i < LOG2_TABLE_SIZE; i++)
00055       log2_table[i] = (float) log2(1.0 + i * (1.0 / LOG2_TABLE_SCALE));
00056 }
00057 
00058 
00062 void
00063 util_init_math(void)
00064 {
00065    static boolean initialized = FALSE;
00066    if (!initialized) {
00067       init_pow2_table();
00068       init_log2_table();
00069       initialized = TRUE;
00070    }
00071 }
00072 
00073 

Generated on Tue Sep 29 06:25:15 2009 for Gallium3D by  doxygen 1.5.4