| From: | John Naylor <johncnaylorls(at)gmail(dot)com> | 
|---|---|
| To: | David Rowley <dgrowleyml(at)gmail(dot)com> | 
| Cc: | David Fetter <david(at)fetter(dot)org>, Heikki Linnakangas <hlinnaka(at)iki(dot)fi>, PostgreSQL Development <pgsql-hackers(at)postgresql(dot)org> | 
| Subject: | Re: Shave a few cycles off our ilog10 implementation | 
| Date: | 2024-12-18 10:42:07 | 
| Message-ID: | CANWCAZbhrx+j1gKuyE3qNXJSFbyUp0QeyoZkwMkUtYoWZwSZMA@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
On Thu, Oct 31, 2024 at 3:14 AM David Rowley <dgrowleyml(at)gmail(dot)com> wrote:
>
> On Thu, 31 Oct 2024 at 09:02, David Fetter <david(at)fetter(dot)org> wrote:
> > This testing was basically just sending a bunch of appropriately sized
> > pseudo-random uints in a previously created array sent through a tight
> > loop that called the ilog10s and getting average execution times.
> >
> > Any suggestions for more thorough testing would be welcome.
>
> Maybe something similar to what I did in [1].
>
> David
>
> [1] https://postgr.es/m/CAApHDvopR=yPgNr4AbbN4HMOztuyVa+iFYRTvu49pxg9YO_tKw@mail.gmail.com
I tried this test as-is and saw no difference. I bumped it up to 10
columns and got (no turbo, about 30 transactions):
master:
6831.308 ms
patch:
6580.506 ms
The difference is small enough that normally I'd say it's likely
unrelated to the patch, but on the other hand it's consistent with
saving (3 * 10 * 10 million) cycles because of 1 less multiplication
each, which is not nothing, but for shoving bytes into /dev/null it's
not exciting either. The lookup for the 64-bit case has grown to 1024
bytes, which will compete for cache space. I don't have a strong
reason to be either for or against this patch. Anyone else want to
test?
create table bi (a bigint, b bigint, c bigint, d bigint, e bigint, f
bigint, g bigint, h bigint, i bigint, j bigint);
insert into bi select i,i,i,i,i,i,i,i,i,i from generate_Series(1,10_000_000) i;
vacuum freeze analyze bi;
pgbench -n -T 180 -f bench.sql
-- 
John Naylor
Amazon Web Services
| From | Date | Subject | |
|---|---|---|---|
| Next Message | David Rowley | 2024-12-18 10:45:40 | Re: Pg18 Recursive Crash | 
| Previous Message | Vladlen Popolitov | 2024-12-18 10:41:37 | Re: COPY performance on Windows |