.\"Copyright 2006, Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. .\" Copyright (c) 1996 Thinking Machines Corporation .TH MPI_Wtime 3OpenMPI "September 2006" "Open MPI 1.2" " " .SH NAME \fBMPI_Wtime\fP \- Returns an elapsed time on the calling processor. .SH SYNTAX .ft R .SH C Syntax .nf #include double MPI_Wtime() .SH Fortran Syntax .nf INCLUDE 'mpif.h' DOUBLE PRECISION MPI_WTIME() .SH C++ Syntax .nf #include double Wtime() .SH RETURN VALUE .ft R Time in seconds since an arbitrary time in the past. .SH DESCRIPTION .ft R MPI_Wtime returns a floating-point number of seconds, representing elapsed wall-clock time since some time in the past. .PP The "time in the past" is guaranteed not to change during the life of the process. The user is responsible for converting large numbers of seconds to other units if they are preferred. .PP This function is portable (it returns seconds, not "ticks"), it allows high resolution, and carries no unnecessary baggage. One would use it like this: .sp .nf { double starttime, endtime; starttime = MPI_Wtime(); \&.... stuff to be timed \&... endtime = MPI_Wtime(); printf("That took %f seconds\\n",endtime-starttime); } .fi .PP The times returned are local to the node that called them. There is no requirement that different nodes return the "same" time. .SH NOTES The boolean variable MPI_WTIME_IS_GLOBAL, a predefined attribute key that indicates whether clocks are synchronized, does not have a valid value in Open MPI, as the clocks are not guaranteed to be synchronized. .PP This is intended to be a high-resolution, elapsed (or wall) clock. See MPI_Wtick to determine the resolution of MPI_Wtime. .PP This function does not return an error value. Consequently, the result of calling it before MPI_Init or after MPI_Finalize is undefined. .SH SEE ALSO MPI_Wtick .br ' @(#)MPI_Wtime.3 1.25 06/03/09