<div dir="ltr"><div><div><div>Hi Douglas,<br><br></div>At first glance, most of those look like useful changes that we should consider accepting. I do have some concerns about the changes to time dilation though. It's my (possibly incorrect) understanding that the time dilation value is used to adjust the velocity of interpolated movement in the viewers. A value of 1.0 (typically the maximum value) allows the avatar or object to move at the velocity specified in the last ObjectUpdate message for that entity. As time dilation decreases, that entity will move proportionally slower. If I interpret your message correctly, with your new implementation when the physics engine engine is running slower than normal due to excessive load, time dilation will increase. This would seem to have the opposite effect than desired; the affected entities would move faster than normal rather than slower and possibly induce a lot of "rubber banding". It would seem that if there is more time available than necessary to process physics and some sleep is allowed, then time dilation should be 1.0 and only go below 1.0 when the physics scene must be slowed down to accommodate inadequate physics processing time. This would apply to the time dilation value that is sent with many of the UDP packets to viewers. It may not need to apply to the value reported in the "show stats" command, however then I think it should be renamed to something other than "time dilation".<br><br></div>Regards,<br></div>-dahlia<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Apr 17, 2015 at 8:28 AM, Maxwell, Douglas CIV USARMY ARL (US) <span dir="ltr"><<a href="mailto:douglas.maxwell3.civ@mail.mil" target="_blank">douglas.maxwell3.civ@mail.mil</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Classification: UNCLASSIFIED<br>
Caveats: NONE<br>
<br>
Good Morning Everyone, I'd like to share with you a synopsis of a report<br>
prepared for me by Steven Zielinski and Sean Mondesire. This is the result<br>
of the discussions held with the dev list last month regarding frame rate<br>
and sampling. We are preparing to release a number of patches to the open<br>
simulator developers that will fix a number of inaccurate simulator<br>
statistics and data collection mechanisms we uncovered while profiling the<br>
code. These changes are critical to the correct sampling of the simulator's<br>
behavior and will affect future development as we introduce new scaling<br>
(think DSG-after-next) and fidelity enhancements.<br>
<br>
The code fixes have been rolled into the MOSES and testing has been positive<br>
thus far. Below is a brief discussion of each of the updates for your<br>
consideration and preparation for the coming patches. Your constructive<br>
feedback is welcome.<br>
<br>
Sim FPS:<br>
Previous Metric/Definition: This was the amount of frames being processed<br>
during a single second multiplied by a correction factor to make it look as<br>
though they were processing close to 60 frames per second.<br>
<br>
New Metric/Definition: This is the amount of frames being processed during<br>
a single second. This is calculated by adding a single frame to a counter<br>
inside the StatsReporter, and then dividing by the time between statistics<br>
heartbeats.<br>
<br>
Physics FPS:<br>
Previous: This was originally handled by the individual physics engines.<br>
There was a need for a change because there was no threading off of the<br>
physics engine. Each time the physics engine was updated the program would<br>
pause and wait for the calculations to complete. Looking into Bullet's<br>
calculation we found that there was an algorithm numSubSteps *<br>
m_fixedTimeStep * 1000 * NominalFrameRate. When looking at this further it<br>
was determined that numSubSteps was the minFrameTime / m_fixedTimeStep. Thus<br>
the above math becomes minFrameTime * 1000 * NominalFrameRate. This was then<br>
added to the SimStatsReporter where they divide by 1000. Which left us with<br>
minFrameTime * NominalFrameRate. This meant that every run through the<br>
update loop add .089 * 55 to the physics time value of SimStatsReporter.<br>
This equaled 4.895 so the number of frames times 4.895 resulted in the<br>
physics FPS for bullet.<br>
<br>
New: This is now the amount of frames being processed during a single<br>
second. This is calculated by adding a single frame to a counter inside the<br>
StatsReporter, and then dividing by the time between statistics heartbeats.<br>
This matches the Sim FPS because they are currently running on the same<br>
thread and only a single frame of physics is updated when a single frame of<br>
the simulation is updated.<br>
<br>
Total Frame Time:<br>
Previous: Here we needed to add a stopwatch instead of using the original<br>
EnvironmentTickCount. The reason for the change was that the<br>
EnvironmentTickCount only updates a few times a second while the stopwatch<br>
will get an exact time in milliseconds. This change was also done for the<br>
physics and simulation time. Also this used to only grab a single frame<br>
(including the sleep and statistics gathering) and display the result. The<br>
single frame was changed on both the physics and simulation time as well.<br>
<br>
New: This is now an average for the past N frames of the total time it took<br>
to complete a frame. Where N is the value given inside of the OpenSim.ini<br>
file by the variable NumberOfFrames inside of the Statistics section. This<br>
includes the time that opensim slept to match the current frame time.<br>
<br>
Physics Time:<br>
Previous: Only had the changes listed in total frame time.<br>
<br>
New: This is now an average for the past N frames of the total time it took<br>
to complete a physics update to the scene. Where N is the value given inside<br>
of the OpenSim.ini file by the variable NumberOfFrames inside of the<br>
Statistics section. This includes the time that opensim ran the<br>
preprocessing of physics and the physics update. If physics is disabled the<br>
time it took to check whether physics was disabled is used.<br>
<br>
Simulation Time:<br>
Previous: Changed the things listed in total frame time. Also changed that<br>
instead of calculating each section (tempOnRezMS, eventMS, backupMS,<br>
terrainMS, landMS) there were only two sections. The reason for two<br>
sections, the physics section separates parts of the simulation section.<br>
Each section that was originally included has remained the same.<br>
<br>
New: This is now an average for the past N frames of the total time it took<br>
for the simulation to run. Where N is the value given inside of the<br>
OpenSim.ini file by the variable NumberOfFrames inside of the Statistics<br>
section. This does not include the time that physics was running or the time<br>
that open sim slept to match the current frame time.<br>
<br>
Time Dilation:<br>
Previous: Originally just returned the PhysicsScene value for TimeDilation<br>
which is 1.0.<br>
<br>
New: The time it took for the physics and simulation to run not including<br>
the sleep time, divided by the minFrameTime passed into the program from the<br>
OpenSimDefaults.ini file variable MinFrameTime. This would mean that a value<br>
of 1 is no sleep necessary, less than 1 and the program slept for some<br>
remaining amount of time, and greater than 1 the physics and simulation took<br>
longer to run than the allotted time.<br>
((simulationFrameTime+physicsFrameTime)/minFrameTime) All times are based<br>
on a single frame and not averaged across multiple data points.<br>
<br>
<br>
v/r -doug<br>
<br>
Douglas Maxwell, MSME<br>
Science and Technology Manager<br>
Virtual World Strategic Applications<br>
U.S. Army Research Lab<br>
Simulation & Training Technology Center (STTC)<br>
(c) (407) 242-0209<br>
<br>
<br>
<br>
<br>
Classification: UNCLASSIFIED<br>
Caveats: NONE<br>
<br>
<br>
<br>_______________________________________________<br>
Opensim-dev mailing list<br>
<a href="mailto:Opensim-dev@opensimulator.org">Opensim-dev@opensimulator.org</a><br>
<a href="http://opensimulator.org/cgi-bin/mailman/listinfo/opensim-dev" target="_blank">http://opensimulator.org/cgi-bin/mailman/listinfo/opensim-dev</a><br>
<br></blockquote></div><br></div>