aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llcommon/llcriticaldamp.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:44:46 -0500
committerJacek Antonelli2008-08-15 23:44:46 -0500
commit38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4 (patch)
treeadca584755d22ca041a2dbfc35d4eca01f70b32c /linden/indra/llcommon/llcriticaldamp.cpp
parentREADME.txt (diff)
downloadmeta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.zip
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.gz
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.bz2
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.xz
Second Life viewer sources 1.13.2.12
Diffstat (limited to 'linden/indra/llcommon/llcriticaldamp.cpp')
-rw-r--r--linden/indra/llcommon/llcriticaldamp.cpp91
1 files changed, 91 insertions, 0 deletions
diff --git a/linden/indra/llcommon/llcriticaldamp.cpp b/linden/indra/llcommon/llcriticaldamp.cpp
new file mode 100644
index 0000000..2f83192
--- /dev/null
+++ b/linden/indra/llcommon/llcriticaldamp.cpp
@@ -0,0 +1,91 @@
1/**
2 * @file llcriticaldamp.cpp
3 * @brief Implementation of the critical damping functionality.
4 *
5 * Copyright (c) 2002-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#include "linden_common.h"
29#include <math.h>
30
31#include "llcriticaldamp.h"
32
33//-----------------------------------------------------------------------------
34// static members
35//-----------------------------------------------------------------------------
36LLFrameTimer LLCriticalDamp::sInternalTimer;
37std::map<F32, F32> LLCriticalDamp::sInterpolants;
38F32 LLCriticalDamp::sTimeDelta;
39
40//-----------------------------------------------------------------------------
41// LLCriticalDamp()
42//-----------------------------------------------------------------------------
43LLCriticalDamp::LLCriticalDamp()
44{
45 sTimeDelta = 0.f;
46}
47
48// static
49//-----------------------------------------------------------------------------
50// updateInterpolants()
51//-----------------------------------------------------------------------------
52void LLCriticalDamp::updateInterpolants()
53{
54 sTimeDelta = sInternalTimer.getElapsedTimeAndResetF32();
55
56 F32 time_constant;
57
58 for (std::map<F32, F32>::iterator iter = sInterpolants.begin();
59 iter != sInterpolants.end(); iter++)
60 {
61 time_constant = iter->first;
62 F32 new_interpolant = 1.f - pow(2.f, -sTimeDelta / time_constant);
63 new_interpolant = llclamp(new_interpolant, 0.f, 1.f);
64 sInterpolants[time_constant] = new_interpolant;
65 }
66}
67
68//-----------------------------------------------------------------------------
69// getInterpolant()
70//-----------------------------------------------------------------------------
71F32 LLCriticalDamp::getInterpolant(const F32 time_constant, BOOL use_cache)
72{
73 if (time_constant == 0.f)
74 {
75 return 1.f;
76 }
77
78 if (use_cache && sInterpolants.count(time_constant))
79 {
80 return sInterpolants[time_constant];
81 }
82
83 F32 interpolant = 1.f - pow(2.f, -sTimeDelta / time_constant);
84 interpolant = llclamp(interpolant, 0.f, 1.f);
85 if (use_cache)
86 {
87 sInterpolants[time_constant] = interpolant;
88 }
89
90 return interpolant;
91}