Re: [PATCH] Use optimized single-datum tuplesort in ExecSort

Поиск
Список
Период
Сортировка
От Ranier Vilela
Тема Re: [PATCH] Use optimized single-datum tuplesort in ExecSort
Дата
Msg-id CAEudQApJky5BpZ_HVXbHbc0Gz=VfKvqD7YwGYJkSZdotB6idDQ@mail.gmail.com
обсуждение исходный текст
Ответ на Re: [PATCH] Use optimized single-datum tuplesort in ExecSort  (Ranier Vilela <ranier.vf@gmail.com>)
Список pgsql-hackers
Em ter., 13 de jul. de 2021 às 14:42, Ranier Vilela <ranier.vf@gmail.com> escreveu:
Em ter., 13 de jul. de 2021 às 09:44, Ranier Vilela <ranier.vf@gmail.com> escreveu:
Em ter., 13 de jul. de 2021 às 09:24, David Rowley <dgrowleyml@gmail.com> escreveu:
On Wed, 14 Jul 2021 at 00:06, Ranier Vilela <ranier.vf@gmail.com> wrote:
>
> Em ter., 13 de jul. de 2021 às 04:19, Ronan Dunklau <ronan.dunklau@aiven.io> escreveu:
>> I would be
>> surprised the check adds that much to the whole execution though.
>
> I think this branch is a misprediction.

It could be.  I wondered that myself when I saw Ronan's results were
better than mine for 2,4 and 7.  However, I think Ronan had quite a
bit of noise in his results as there's no reason for the speedup in
tests 2,4 and 7. 

> In most cases is it not datumSort?

who knows.  Maybe someone's workload always requires the datum sort.

> That's why I would like to use unlikely.

We really only use unlikely() in cases where we want to move code out
of line to a cold area because it's really never executed under normal
circumstances. We tend to do that for ERROR cases as we don't ever
really want to optimise for errors. We also sometimes do it when some
function has a branch to initialise something during the first call.
The case in question here does not fit for either of those two cases.
Hum, I understand the usage cases now.
Thanks for the hint.
 

> IMO all the tests should all be to verify past behavior first.

I'm not quire sure what you mean there.
I'm saying we could help the branch by keeping the same testing logic as before and not reversing it.
Attached is a version to demonstrate this, I don't pretend to be v7.

I couldn't find a good phrase to the contrary:
"are we *not* using the single value optimization ?"

I don't have time to take the tests right now.
Finally I had time to benchmark (David's benchsort.sh)

ubuntu 64 bits (20.04) 8gb ram SSD 256GB.
Table with the best results of each.


         HEAD           v6           v7            v7b        v6 vs master              v7 vs v6           v7b vs v6
Test1288,149636449,018541469,757169550,48505155,83%104,62%122,60%
Test294,76695595,45140694,55624994,718982100,72%99,06%99,23%
Test3190,521319260,279802259,597067278,115296136,61%99,74%106,85%
Test478,77934478,25345578,11406877,94148299,33%99,82%99,60%
Test5131,362614142,662223136,436347149,639041108,60%95,64%104,89%
Test6112,884298124,181671115,528328127,58497110,01%93,03%102,74%
Test769,30858768,64306766,1019569,08754499,04%96,30%100,65%
Test8243,674171364,681142371,928453419,259703149,66%101,99%114,97%

I have no idea why v7 failed with test6?
v6 slowdown with test4 and test7.
v7b slowdown with test2 and test4, in relation with v7.
 v7b slowdown with test2 and test4, in relation with *v6*.


If field struct datumSort is not absolutely necessary, I think that v7 will be better.
 *v7b* will be better.

Sorry for the noise.

regards,
Ranier Vilela

В списке pgsql-hackers по дате отправления:

Предыдущее
От: Ranier Vilela
Дата:
Сообщение: Re: [PATCH] Use optimized single-datum tuplesort in ExecSort
Следующее
От: Tom Lane
Дата:
Сообщение: Re: proposal - psql - use pager for \watch command