forked from eden-emu/eden
		
	perf_stats: Rework FPS counter to be more accurate
The FPS counter was based on metrics in the nvdisp swapbuffers call. This metric would be accurate if the gpu thread/renderer were synchronous with the nvdisp service, but that's no longer the case. This commit moves the frame counting responsibility onto the concrete renderers after their frame draw calls. Resulting in more meaningful metrics. The displayed FPS is now made up of the average framerate between the previous and most recent update, in order to avoid distracting FPS counter updates when framerate is oscillating between close values. The status bar update frequency was also changed from 2 seconds to 500ms.
This commit is contained in:
		
							parent
							
								
									a9c9d56a35
								
							
						
					
					
						commit
						453e90ef6f
					
				
					 10 changed files with 26 additions and 14 deletions
				
			
		|  | @ -215,7 +215,7 @@ void EmuWindow_SDL2::WaitEvent() { | |||
|         const auto results = Core::System::GetInstance().GetAndResetPerfStats(); | ||||
|         const auto title = | ||||
|             fmt::format("yuzu {} | {}-{} | FPS: {:.0f} ({:.0f}%)", Common::g_build_fullname, | ||||
|                         Common::g_scm_branch, Common::g_scm_desc, results.game_fps, | ||||
|                         Common::g_scm_branch, Common::g_scm_desc, results.average_game_fps, | ||||
|                         results.emulation_speed * 100.0); | ||||
|         SDL_SetWindowTitle(render_window, title.c_str()); | ||||
|         last_time = current_time; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ameerj
						ameerj