× 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: "extract" command enhancement (subfiles and BIFs)
  • From: "David Morris" <dmorris@xxxxxxxxxxxxx>
  • Date: Thu, 23 Sep 1999 16:07:06 -0600

Jim,

I recently spent some time trying to optimize a page by page subfile 
positioning 
routine.  I started by reading every 4096th record until I hit a greater key 
and then 
went back/forth by half until I hit 1 or the key.  Worked pretty good, but it 
was slower 
than my sequential search which just read every 64th record and then backed up 
when it found a key greater.  I found out that with a scrollable cursor, to get 
the 
record n records away the system actually performed I/O for all of the inner 
records.  Seems odd to that the system performs I/O when simply counting index 
entries would do. 

David Morris

>>> Jim Langston <jlangston@conexfreight.com> 09/23/99 01:24PM >>>
Incidentally, this "halving" technique is one I learned years ago in school 
from a
math teacher.  By using the halving technique, you can pick any number from 1
to 100 within 7 "guesses", with the average being 4 or 5 (not 3.5 because of the
refinement on each consecutive pick)..  On a simple sequential search, 1, 2, 3,
4, etc... it could take 100 picks, with the average being 50.  With 1000 records
the halving technique would take at most 10 guess, and I'm not even going to
try to figure out the average (7 maybe?).  With sequential search, max 1000 and
average of 500.

It's a really good technique, and I have used it in searches before, but there 
is
the necessity that your data is sorted on what you're looking for.  And this is
basically the exact same way the OS does it when it does a SETLL.

Regards,

Jim Langston


+---
| 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-2024 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.