Re: BUG #17334: Assert failed inside computeDistance() on gist index scanning

From: Tomas Vondra <tomas(dot)vondra(at)enterprisedb(dot)com>
To: exclusion(at)gmail(dot)com, pgsql-bugs(at)lists(dot)postgresql(dot)org, PG Bug reporting form <noreply(at)postgresql(dot)org>
Subject: Re: BUG #17334: Assert failed inside computeDistance() on gist index scanning
Date: 2021-12-12 22:59:43
Message-ID: 7c191fd2-9103-ae81-8f4f-22f39edd3c90@enterprisedb.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

On 12/12/21 17:00, PG Bug reporting form wrote:
> The following bug has been logged on the website:
>
> Bug reference: 17334
> Logged by: Alexander Lakhin
> Email address: exclusion(at)gmail(dot)com
> PostgreSQL version: 14.1
> Operating system: Ubuntu 20.04
> Description:
>
> When executing the following queries:
> CREATE TABLE point_tbl(f1 point);
> CREATE INDEX gpointind ON point_tbl USING gist(f1);
> INSERT INTO point_tbl SELECT ('0,0') FROM generate_series(1, 185);
> INSERT INTO point_tbl VALUES ('0,NaN');
> SET enable_seqscan=off; SELECT f1 <-> point '(0,0)' AS dist FROM point_tbl
> ORDER BY dist;
>

FWIW I can reproduce this on master too. The failure happens because of
NaN value in the index:

#3 0x00000000004d3e72 in computeDistance (isLeaf=false,
box=0x760f5ce13b28, point=0x1f99608) at gistproc.c:1240
1240 Assert(box->low.y <= box->high.y);
(gdb) p box->high
$1 = {x = 0, y = nan(0x8000000000000)}

and indeed, pageinspect says this:

test=# select * from gist_page_items(get_raw_page('gpointind', 2),
'gpointind'::regclass);
itemoffset | ctid | itemlen | dead | keys
------------+---------+---------+------+----------------
1 | (0,94) | 40 | f | (f1)=((0,0))
2 | (0,95) | 40 | f | (f1)=((0,0))
...
92 | (0,185) | 40 | f | (f1)=((0,0))
93 | (1,1) | 40 | f | (f1)=((0,NaN))
(93 rows)

I'm not sure if the issue is in allowing the NaN to be added to the
index, or not handling it correctly during the index scan.

It's interesting btree_gist does not have issues (for NaN in float8
columns). It seems not to store NaN in the index, It seems to replace
them with tiny values, at least according to pageinspect.

regards

--
Tomas Vondra
EnterpriseDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Tom Lane 2021-12-12 23:37:21 Re: BUG #17334: Assert failed inside computeDistance() on gist index scanning
Previous Message PG Bug reporting form 2021-12-12 16:00:01 BUG #17334: Assert failed inside computeDistance() on gist index scanning