× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.






I suspect you are looking at some old documentation as several releases ago
the MI timestamp was enhanced with 8 microsecond granularity.  As for
converting to more readable formats, the Convert Date and Time API
(QWCCVTDT) can handle that with an input format of *DTS.

Bruce Vining



                                                                           
             "Jevgeni                                                      
             Astanovski"                                                   
             <Jevgeni.Astanovs                                          To 
             ki@xxxxxxxx>              <c400-l@xxxxxxxxxxxx>               
             Sent by:                                                   cc 
             c400-l-bounces+bv                                             
             ining=us.ibm.com@                                     Subject 
             midrange.com              [C400-L] How to calculate process   
                                       duration?                           
                                                                           
             04/18/2005 07:39                                              
             AM                                                            
                                                                           
                                                                           
             Please respond to                                             
               C programming                                               
              iSeries / AS400                                              
                                                                           
                                                                           




My problem is how to get duration of a certain part of the program.
It is my program and I'll put timestamping into it myself.

So idea is:

.....
time(&Time1) ;
processing...
processing...
processing...
time(&Time2) ;
Duration = GetTimeDifference(Time1, Time2) ;

But I know, that the processing takes surely less than a second, so time()
function, returning seconds is not OK.

Looked at mattod(). It is said, that it's tick is 1/1000 sec. Fine. But
isn't there somewhere a way to convert _MI_Time to something usable? Or if
not, can anyone tell me, what are the arithmetical rules for _MI_Time - I
need to subtract one from another?


I did some bit fiddling and finally got a piece, that seems to work, but it
is really ugly:

mattod(Time1) ;
    mitime(&WaitTime, 0, 0, 0, 50) ;  /*hours,minutes,seconds,1/100*/
    waittime(&WaitTime, _WAIT_NORMAL) ;
mattod(Time2) ;
memcpy(Buf, &Time1, 8) ;
memcpy(&Tim11, Buf, 4) ;
memcpy(&TimShift, &Buf[4], 4) ;
Tim12 = TimShift >> 22 ;
memcpy(Buf, &Time2, 8) ;
memcpy(&Tim21, Buf, 4) ;
memcpy(&TimShift, &Buf[4], 4) ;
Tim22 = TimShift >> 22 ;
Diff = (Tim21 - Tim11) * 1000 + Tim22 - Tim12 ;
printf("Diff : %d ms\n", Diff) ;

The idea of mitime and waittime is simply to compare printed result to
500ms delay.
Isn't it ugly?
Is it the only way?

TIA,

Jevgeni Astanovski

_______________________________________________
This is the C programming iSeries / AS400 (C400-L) mailing list
To post a message email: C400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/c400-l
or email: C400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/c400-l.




As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.