annotate src/timefns.cc @ 1179:f070efd56c3d

[project @ 1995-03-23 21:45:33 by jwe]
author jwe
date Thu, 23 Mar 1995 21:45:33 +0000
parents dfe01093f657
children 1def0d0014bd
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
1 // timefns.cc -*- C++ -*-
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
2 /*
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
3
1009
dfe01093f657 [project @ 1995-01-04 04:05:12 by jwe]
jwe
parents: 940
diff changeset
4 Copyright (C) 1992, 1993, 1994, 1995 John W. Eaton
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
5
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
6 This file is part of Octave.
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
7
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
11 later version.
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
12
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
16 for more details.
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
17
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
19 along with Octave; see the file COPYING. If not, write to the Free
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
20 Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
21
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
22 */
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
23
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
24 #ifdef HAVE_CONFIG_H
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
25 #include "config.h"
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
26 #endif
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
27
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
28 #include "dMatrix.h"
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
29
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
30 #include "tree-const.h"
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
31 #include "oct-obj.h"
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
32 #include "systime.h"
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
33 #include "defun.h"
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
34
940
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 935
diff changeset
35 #ifdef HAVE_SYS_RESOURCE_H
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 935
diff changeset
36 extern "C"
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 935
diff changeset
37 {
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
38 #include <sys/resource.h>
940
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 935
diff changeset
39 }
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 935
diff changeset
40 #endif
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
41
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
42 #ifndef RUSAGE_SELF
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
43 #define RUSAGE_SELF 0
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
44 #endif
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
45
935
28e275222873 [project @ 1994-11-17 21:27:53 by jwe]
jwe
parents: 902
diff changeset
46
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
47 DEFUN ("clock", Fclock, Sclock, 1, 0,
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
48 "clock (): return current date and time in vector with elements\n\
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
49 \n\
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
50 [ year, month, day-of-month, hour, minute, second ]")
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
51 {
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
52 time_t now;
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
53 double fraction = 0.0;
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
54
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
55 #ifdef HAVE_GETTIMEOFDAY
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
56
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
57 struct timeval tp;
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
58
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
59 gettimeofday (&tp, 0);
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
60
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
61 now = tp.tv_sec;
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
62
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
63 fraction = tp.tv_usec / 1e6;
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
64
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
65 #else
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
66
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
67 time (&now);
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
68
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
69 #endif
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
70
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
71 struct tm *tm = localtime (&now);
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
72
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
73 Matrix m (1, 6);
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
74 m.elem (0, 0) = tm->tm_year + 1900;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
75 m.elem (0, 1) = tm->tm_mon + 1;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
76 m.elem (0, 2) = tm->tm_mday;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
77 m.elem (0, 3) = tm->tm_hour;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
78 m.elem (0, 4) = tm->tm_min;
792
ac49764105cf [project @ 1994-10-12 16:45:59 by jwe]
jwe
parents: 523
diff changeset
79 m.elem (0, 5) = tm->tm_sec + fraction;
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
80
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
81 return m;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
82 }
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
83
902
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
84 DEFUN ("cputime", Fcputime, Scputime, 0, 0,
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
85 "[total, user, system] = cputime ()\n\
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
86 \n\
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
87 Return CPU time statistics.")
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
88 {
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
89 Octave_object retval (3, Matrix (1, 1, 0.0));
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
90
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
91 #if defined (HAVE_GETRUSAGE)
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
92
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
93 struct rusage resource_stats;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
94
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
95 getrusage (RUSAGE_SELF, &resource_stats);
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
96
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
97 struct timeval usr = resource_stats.ru_utime;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
98 struct timeval sys = resource_stats.ru_stime;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
99
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
100 double usr_time = usr.tv_sec + usr.tv_usec / 1e6;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
101 double sys_time = sys.tv_sec + sys.tv_usec / 1e6;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
102
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
103 retval (2) = sys_time;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
104 retval (1) = usr_time;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
105 retval (0) = usr_time + sys_time;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
106
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
107 #endif
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
108
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
109 return retval;
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
110 }
6923bd0a6ea2 [project @ 1994-11-09 19:55:36 by jwe]
jwe
parents: 792
diff changeset
111
523
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
112 DEFUN ("date", Fdate, Sdate, 1, 0,
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
113 "date (): return current date in a string, in the form `18-Jul-94'")
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
114 {
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
115 Octave_object retval;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
116
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
117 time_t now;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
118 struct tm *tm;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
119
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
120 time (&now);
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
121 tm = localtime (&now);
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
122 char date[32];
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
123 int len = strftime (date, 31, "%d-%b-%y", tm);
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
124 if (len > 0)
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
125 retval = date;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
126
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
127 return retval;
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
128 }
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
129
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
130 /*
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
131 ;;; Local Variables: ***
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
132 ;;; mode: C++ ***
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
133 ;;; page-delimiter: "^/\\*" ***
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
134 ;;; End: ***
4a07f0083ab0 [project @ 1994-07-20 18:33:47 by jwe]
jwe
parents:
diff changeset
135 */