forked from stepmania/stepmania
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSampleHistory.cpp
95 lines (84 loc) · 3.04 KB
/
SampleHistory.cpp
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
#include "global.h"
#include "SampleHistory.h"
#include "RageMath.hpp"
#include "RageLog.h"
#include "RageUtil.h"
inline float sample_step_size(int samples_per_second)
{
return 1.0f / samples_per_second;
}
SampleHistory::SampleHistory()
{
m_iLastHistory = 0;
m_iHistorySamplesPerSecond = 60;
m_fHistorySeconds = 0.0f;
m_fToSample = sample_step_size(m_iHistorySamplesPerSecond);
m_fHistorySeconds = 10.0f;
int iSamples = std::lrint( m_iHistorySamplesPerSecond * m_fHistorySeconds );
m_afHistory.resize( iSamples );
}
float SampleHistory::GetSampleNum( float fSamplesAgo ) const
{
using std::min;
fSamplesAgo = min( fSamplesAgo, (float) m_afHistory.size() - 1 );
if( fSamplesAgo < 0 )
fSamplesAgo = 0;
if( m_afHistory.size() == 0 )
return 0.0f;
float fSample = m_iLastHistory - fSamplesAgo - 1;
float f = std::floor( fSample );
int iSample = std::lrint(f);
int iNextSample = iSample + 1;
wrap( iSample, m_afHistory.size() );
wrap( iNextSample, m_afHistory.size() );
float p = fSample - f;
float fRet = Rage::lerp( p, m_afHistory[iSample], m_afHistory[iNextSample] );
// LOG->Trace( "%.3f: %i, %i, %.3f (f %.3f, %.3f)", fSample, iSample, iNextSample, fRet, f, p );
return fRet;
}
float SampleHistory::GetSample( float fSecondsAgo ) const
{
float fSamplesAgo = fSecondsAgo * m_iHistorySamplesPerSecond;
return GetSampleNum( fSamplesAgo );
}
void SampleHistory::AddSample( float fSample, float fDeltaTime )
{
using std::min;
while( fDeltaTime > 0.0001f )
{
float fTime = min( m_fToSample, fDeltaTime );
m_fToSample -= fTime;
fDeltaTime -= fTime;
if( m_fToSample < 0.0001f )
{
++m_iLastHistory;
m_iLastHistory %= m_afHistory.size();
m_fToSample += sample_step_size(m_iHistorySamplesPerSecond);
}
m_afHistory[m_iLastHistory] = fSample;
}
}
/*
* (c) 2006-2007 Glenn Maynard
* All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, and/or sell copies of the Software, and to permit persons to
* whom the Software is furnished to do so, provided that the above
* copyright notice(s) and this permission notice appear in all copies of
* the Software and that both the above copyright notice(s) and this
* permission notice appear in supporting documentation.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF
* THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS
* INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT
* OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
* OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/