× 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.


  • Subject: Re: Expensive op codes
  • From: bmorris@xxxxxxxxxx
  • Date: Mon, 18 Oct 1999 10:41:51 -0400




I agree that code clarity and maintainability are usually paramount.  Even if
there were trivial differences sometimes between ADD 1 X and EVAL X = X + 1,
such differences aren't even remotely significant for 99.99...9999% of
applications.  But the difference between "READ + IF" and "READE" (for some
files, depending on the nature of the actual keys in the file (*) ) CAN be
significant.  Knowing a bit about which areas to look at can help on the
occasions where performance does become an issue.

(*) Note that READE outperforms READ + IF in some cases.  I'm not an expert, so
I can't say what the criteria are, but I wouldn't advocate a wholesale switch
from using READE to READ + IF.  You might lose both code simplicity AND
performance.

Date operations are expensive.  I wouldn't ever advocate replacing date
operations with a few lines of overlay manipulation, but I do advocate replacing
a sequence requiring 3 date operations to one requiring only 1 date operation if
the total code has about the same understandability.  If there had been a
version of "find the last day in the month" that didn't require any thinking to
understand the code, I'd say go with that one, but since they all require some
thinking to understand that they work (in the cases where they did work :), we
can consider which ones are faster, especially since we're thinking about
writing a procedure.

If you are writing a general-purpose procedure that will be called by every
application you write, I think you have the responsibility to spend a bit of
extra time to at least consider performance.  When you write the same code
inline, you know whether it's performance critical at the time you write it, so
you can discount performance in some cases.  But when you write a
general-purpose function, you should write it as though it's going to be called
in performance-critical situations, because it probably IS going to be.

How do you know what opcodes are expensive?  Experience.  At the end of this
note, I'll put a little shell that you can use to do rough performance tests.

Just to throw a final spanner in: if A is faster than B today, it isn't
necessarily true tomorrow.  Not so much because A gets slower, but B might get
faster.  So, unless the difference in performance is significant, go with what's
"better" (using criteria like understandability, maintainability, extendability
etc).

Whew  - that's enough of this for a Monday!  :-)
Barbara Morris

Simple shell for doing performance tests.  If you are comparing 2 ways of
doing something, write 2 programs whose only difference is the code within
the loops.  You can also use a single program to see the general cost of
"doing something X times".

Avoid doing anything in the loops that isn't what you are testing.

Call like this: CALL PERFTEST 100
Call it with sufficiently large numbers that a call with 2 * X takes
about twice as long as a call with X.  That way you can be sure you
are measuring what's in the loop and not just the setup stuff.  Normally
you should let it run for at least half a minute to be able to draw any
significance from the results.

When comparing two methods, once you have a good number of iterations,
run the two versions several times each, and take the quickest time for
each.  Any slower times are caused by other demands on the system, and
aren't of interest for comparisons.  (They ARE of interest if you want
to know in general how long a task takes.)

H DATEDIT(*YMD.)
C     *ENTRY        PLIST
C                   PARM                    timesParm        15 5
C                   Z-ADD     timesParm     numTimes         11 0

C                   TIME                    T6_A              6 0
C                   DO        numTimes
 *---- do your thing here - avoid calling another program or
 *---- procedure since the call time will cloud your results
C                   ENDDO
C                   TIME                    T6_B              6 0

C                   EVAL      msg = 'Start = ' + %EDITC(T6_A : 'Y')
C                                 + ' Finish = ' + %EDITC(T6_B : 'Y')
C                   DSPLY                   MSG              50
C                   SETON                                        LR


+---
| This is the RPG/400 Mailing List!
| To submit a new message, send your mail to RPG400-L@midrange.com.
| To subscribe to this list send email to RPG400-L-SUB@midrange.com.
| To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

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.