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



See inline comments:

On Wed, Oct 14, 2020 at 2:01 PM <smith5646midrange@xxxxxxxxx> wrote:

We have an RPGLE program that I have been asked to evaluate for performance
issues. I want to propose some changes to it but I'm having a hard time
performance testing the changes to prove my theory. Therefore, I thought I
would ask the group some questions and make sure that I am not off track or
misinformed, especially the logic behind the first change that I want to
make.



The first change.

The program currently uses native RPG reads (FSpec). There are 7,328,305
records in the driver file which contains 174 fields for a total of 1,172
bytes. Of those 174 fields, the program only uses 18 of them for a total
of
125 bytes. It is my understanding when using SQL that if I build a cursor
selecting these 18 fields, that is the only data the system reads
(generically speaking) vs reading all 1,172 bytes and extracting out the
125
bytes that it needs so changing to SQL would eliminate reading 1,047 bytes
per record or about 7.6G.



You're probably aware that you can easily create a logical over the
physical file that contains only the 18 columns. That would reduce the
record buffer size in your program.

Join logicals perform better than read->chain->chain sequences by pushing
work into the DBMS, for example. But I question whether reducing the record
buffer size would have any impact on performance.




The second change.

As it reads the 7,328,305 records, it is reading by the key and
accumulating
totals. When the key changes, it dumps the totals to a summary file,
clears
the arrays, and accumulates for the next key. Would changing this to SQL
using SUM() and GROUP BY make this faster?


Continuing the logical file approach, you could create an SQL View from an
SQL select statement that contains SUM() and GROUP BY. Then process that
file with an RPG F spec and READ opcode. I think that externalizing SQL
into a View is more readable than embedding SQL into RPG programs. Just a
preference.








I've left out some details but bear with me and look at the what I am
asking
and don't try to figure out the link between the above two changes and this
third change. It is all linked together but I didn't provide the details
of
how.



The third change.

There are 22 arrays in the program for the rolling totals.
The total of a single occurrence of the arrays is 318 bytes. Each array is
dim(32,767) for a total of 10,419,906 bytes. Since there are a maximum of
5,000 index values, I am going to change the dim(32,767) to dim(5,000).
That reduces the memory consumption of the program by about 8M. This is on
a huge machine and I don't know how much memory it has or how it is
configured but I'm sure it has a lot. Generally speaking, could a program
requiring 10,419,906 bytes of memory also be a performance hog even if
there
was ample memory in the subsystem?



Thanks in advance for all of your help and knowledge.



--
This is the RPG programming on IBM i (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/rpg400-l.

Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related
questions.

Help support midrange.com by shopping at amazon.com with our affiliate
link: https://amazon.midrange.com


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.