[vc++6]timer haute résolution

Description

un chtit bout de code pour aider ceux qui cherche un timer très précis. En effet le GetTickCount n'est pas super. Avec ce timer vous pourrez tester des bouts de code qui s'exécutent trop rapidement pour le GetTickCount qui donnent bien souvent 0 ...
voili voilà bonne prog :)
(ds le zip il y a le dsw et dsp en +, pour vous éviter de configurer les settings)

Source / Exemple :


//NE PAS OUBLIER :
// dans Project | Settings | onglet Général,
//choisir "Use MFC in a shared dll"
///////////////////////////////////////////////////

#define VC_EXTRALEAN// Exclude rarely-used stuff from Windows headers (+ rapide à recompiler)

#include <afx.h>	//si dans votre projet vous avez #include "stdAfx.h" alors pas la peine d'ajouter ça
#include <winbase.h>//header du compteur haute résolution
#include <iostream>	//flux cout, etc ...
using namespace std;//espace de nom...

int main(int argc, char* argv[])
{
	int a=0;
	cout << "programme de timers" << endl
		<<  "--------------------" << endl
		<< endl;
	
	bool	CHR = false;//Compteur Haute Résolution disponible ?
	LARGE_INTEGER	Compteur1,				//un compteur
					Compteur2,				//un compteur
					freq;					//le nombre de "tics" en une seconde(dépends de la machine)
	
	if(	QueryPerformanceFrequency(&freq) )	//test s'il existe un CHR, si oui enregistre le nbre de "tics" par secondes
		CHR = true;							//TESTER false, si vous souhaitez utiliser GetTickCount

	
	if(CHR)
		cout << "le Compteur Haute R?solution est disponible :)" << endl;//petite phrase pour indication

	else
		cout << "le Compteur Haute R?solution n'est pas disponible :(" << endl;
	
	
	if(CHR)
		QueryPerformanceCounter(&Compteur1);//on relève le temps au compteur, stocké dans Compteur1
	else
		Compteur1.QuadPart=GetTickCount();	//au cas ou le CHR ne fonctionne pas
	
	//code dont on veut tester le temps de calcul
	//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
	for(int i = 0; i < 10; ++i)		//avec une petite boucle for, le GetTickCount rends 0
		a +=3;								//mais pas le CHR

	//for(int i = 0; i < 1000000; ++i)//avec une grande boucle, les résultats sont équivalents
	//	a+=3;

	//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
	//fin du code

	if(CHR)
		QueryPerformanceCounter(&Compteur2);//le calcul est fini on relève le compteur :)
	else
		Compteur2.QuadPart=GetTickCount();	//idem avec GetTickCount
	

	if(CHR)
	{
		cout << "temps de calcul en nombre de \"tics\" : ";
		cout << static_cast <UINT>(Compteur2.QuadPart - Compteur1.QuadPart) << endl;
		cout << "en secondes : "<< static_cast <float>(Compteur2.QuadPart - Compteur1.QuadPart) / static_cast<float>(freq.QuadPart) << endl;
	}
	else
	{
		//explications pour getTickCount :
		//GetTickCount donne le nombre de tic au moment voulue, mais sa fréquence c'est 1000 tics /seconde = 1 milliseconde
		cout << "temps de calcul en millisecondes : ";
		cout << static_cast <UINT>(Compteur2.QuadPart - Compteur1.QuadPart) << endl;
		cout << "en secondes : "<< static_cast <float>(Compteur2.QuadPart - Compteur1.QuadPart) / 1000;

	}

	cout << endl << "Presser entr?e ..." << endl;
	cin.get();
	
	return 0;
}

Codes Sources

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.