/**************************************************************************** * * SciTech OS Portability Manager Library * * ======================================================================== * * The contents of this file are subject to the SciTech MGL Public * License Version 1.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.scitechsoft.com/mgl-license.txt * * Software distributed under the License is distributed on an * "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is Copyright (C) 1991-1998 SciTech Software, Inc. * * The Initial Developer of the Original Code is SciTech Software, Inc. * All Rights Reserved. * * ======================================================================== * * Language: C++ 3.0 * Environment: Any * * Description: Test program for the Zen Timer Library C++ interface. * ****************************************************************************/ #include #include "pmapi.h" #include "ztimer.h" /*-------------------------- Implementation -------------------------------*/ int i,j,k; /* NON register variables! */ void dummy() {} int main(void) { LZTimer ltimer; ULZTimer ultimer; ZTimerInit(); /* Test the long period Zen Timer (we don't check for overflow coz * it would take tooooo long!) */ cout << endl; ultimer.restart(); ltimer.start(); for (j = 0; j < 10; j++) for (i = 0; i < 20000; i++) dummy(); ltimer.stop(); ultimer.stop(); cout << "LCount: " << ltimer.count() << endl; cout << "Time: " << ltimer << " secs\n"; cout << "ULCount: " << ultimer.count() << endl; cout << "ULTime: " << ultimer << " secs\n"; cout << endl << "Timing ... \n"; ultimer.restart(); ltimer.restart(); for (j = 0; j < 200; j++) for (i = 0; i < 20000; i++) dummy(); ltimer.stop(); ultimer.stop(); cout << "LCount: " << ltimer.count() << endl; cout << "Time: " << ltimer << " secs\n"; cout << "ULCount: " << ultimer.count() << endl; cout << "ULTime: " << ultimer << " secs\n"; /* Test the lap function of the long period Zen Timer */ cout << endl << "Timing ... \n"; ultimer.restart(); ltimer.restart(); for (j = 0; j < 20; j++) { for (k = 0; k < 10; k++) for (i = 0; i < 20000; i++) dummy(); cout << "lap: " << ltimer.lap() << endl; } ltimer.stop(); ultimer.stop(); cout << "LCount: " << ltimer.count() << endl; cout << "Time: " << ltimer << " secs\n"; cout << "ULCount: " << ultimer.count() << endl; cout << "ULTime: " << ultimer << " secs\n"; #ifdef LONG_TEST /* Test the ultra long period Zen Timer */ ultimer.start(); delay(DELAY_SECS * 1000); ultimer.stop(); cout << "Delay of " << DELAY_SECS << " secs took " << ultimer.count() << " 1/10ths of a second\n"; cout << "Time: " << ultimer << " secs\n"; #endif return 0; }