polylist number of row limit

LiveCode is the premier environment for creating multi-platform solutions for all major operating systems - Windows, Mac OS X, Linux, the Web, Server environments and Mobile platforms. Brand new to LiveCode? Welcome!

Moderators: FourthWorld, heatherlaine, Klaus, kevinmiller, robinmiller

terryho
Posts: 126
Joined: Mon Nov 05, 2012 2:53 pm

polylist number of row limit

Post by terryho » Sat Dec 24, 2022 1:46 pm

Hi All,

I see an example for widget "polylist" - "InfiniteList", does there is limit to load number of row in the polylist?

In datagrid, there is a limit to load number of row in the datagrid, does this have the same limit in polylist?

Regards

Terry Ho

prometheus
Posts: 40
Joined: Sun Dec 13, 2015 6:05 pm

Re: polylist number of row limit

Post by prometheus » Sat Dec 24, 2022 4:04 pm

Hi terryho, I think theoretically there is a limit, it all depends on how much memory the computer has, and how much memory the program can handle/address, I have tested it with about 100 000 rows without issues, please let me know if you go further and if you find a limit :)

stam
Posts: 3140
Joined: Sun Jun 04, 2006 9:39 pm

Re: polylist number of row limit

Post by stam » Sat Dec 24, 2022 7:07 pm

What is the limitation on the datagrid's number of rows?

terryho
Posts: 126
Joined: Mon Nov 05, 2012 2:53 pm

Re: polylist number of row limit

Post by terryho » Sun Dec 25, 2022 9:41 am

Hi

Has I know datagrid has a limit of row around 32,000 row, also it will depend of the formatted height of the datagrid. If each row is more height, then the number of row will be decrease.

I see there is a parameter of Polylist which is the "item cache", I think it will increase the performance. But need more test to prove it.

As I see there have example for polylist to load more row, is anyone know there is a limit on polygrid ?

I had make a test of loading random numeric data for 10,000 row and each row is 12 column, then show the data into a field, datagrid, polygrid, polylist, the result as follow :

Polygrid 36ms
DataGrid 82ms
Polylist 452ms
Field 523ms

Regards

Terry Ho

prometheus
Posts: 40
Joined: Sun Dec 13, 2015 6:05 pm

Re: polylist number of row limit

Post by prometheus » Sun Dec 25, 2022 8:12 pm

Hello everyone, No, there is no such limit for any of the 'Poly' widgets, both of them are built on LCB so they draw at a low level, their rows and columns has no the limitations present on DataGrid with the number of rows/columns.
Regarding the itemCache, it speeds up the performance on PolyList but there are some rendering problems with texts when transparencies are used, so if you use this property make sure you have a solid background on the items

Another thing I have noticed, PolyList is not good rendering tables, so I always try to use a PolyGrid when rendering tabulated content

terryho
Posts: 126
Joined: Mon Nov 05, 2012 2:53 pm

Re: polylist number of row limit

Post by terryho » Mon Dec 26, 2022 8:40 am

Hi,

Thanks your hints.

Yes, I have test on Polygrid and Polylist. Discover that :
Polygrid is good for table
Polylist can have more option on table style, fonts and graphic. Also it can design to not load all data in one time.

So under different situation, we can use datagrid, polygrid and polylist.

Regards

Terry Ho

FourthWorld
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 10065
Joined: Sat Apr 08, 2006 7:05 am
Contact:

Re: polylist number of row limit

Post by FourthWorld » Thu Dec 29, 2022 12:23 am

terryho wrote:
Sun Dec 25, 2022 9:41 am
Has I know datagrid has a limit of row around 32,000 row, also it will depend of the formatted height of the datagrid. If each row is more height, then the number of row will be decrease.
I don't believe that's true. Indeed, the DG was invented to get past the 32k pixel limit on rendered group objects.
I had make a test of loading random numeric data for 10,000 row and each row is 12 column, then show the data into a field, datagrid, polygrid, polylist, the result as follow :

Polygrid 36ms
DataGrid 82ms
Polylist 452ms
Field 523ms
Can you share the test stack?
Richard Gaskin
LiveCode development, training, and consulting services: Fourth World Systems
LiveCode Group on Facebook
LiveCode Group on LinkedIn

terryho
Posts: 126
Joined: Mon Nov 05, 2012 2:53 pm

Re: polylist number of row limit

Post by terryho » Thu Dec 29, 2022 3:49 pm

Hi

> I don't believe that's true. Indeed, the DG was invented to get past the 32k pixel limit on rendered group objects.
In the past I had this problem. But did not make a full test on DG2. If I'm wrong, please correct me.

Attach is the stack, which I change the speedtest to add polylist in the test. Please correct me, if some wrong in my script.

Regards

Terry Ho
Attachments
SpeedTest.livecode.zip
(236.53 KiB) Downloaded 219 times

FourthWorld
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 10065
Joined: Sat Apr 08, 2006 7:05 am
Contact:

Re: polylist number of row limit

Post by FourthWorld » Thu Dec 29, 2022 3:59 pm

terryho wrote:
Thu Dec 29, 2022 3:49 pm
Attach is the stack, which I change the speedtest to add polylist in the test. Please correct me, if some wrong in my script.
As long as it executes there is no wrong, only degrees of better. :)

Thank you for posting that. I'll make time to review is after my morning meetings.
Richard Gaskin
LiveCode development, training, and consulting services: Fourth World Systems
LiveCode Group on Facebook
LiveCode Group on LinkedIn

paul@researchware.com
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 153
Joined: Wed Aug 26, 2009 7:42 pm
Contact:

Re: polylist number of row limit

Post by paul@researchware.com » Thu Dec 29, 2022 5:08 pm

FourthWorld wrote:
Thu Dec 29, 2022 12:23 am
terryho wrote:
Sun Dec 25, 2022 9:41 am
Has I know datagrid has a limit of row around 32,000 row, also it will depend of the formatted height of the datagrid. If each row is more height, then the number of row will be decrease.
I don't believe that's true. Indeed, the DG was invented to get past the 32k pixel limit on rendered group objects.
Richard is correct. Any limit on Datagrid ROWS is in excess of 32,000. There may be a limit in the number of VISIBLE ROWS of 32,767px due to the rendering limits of the group object, but I doubt anyone has ever run into that limit. The DG is designed to cache rows much greater than 32K and just display the visible ones. There is, however, a 32,767px limit on COLUMNS. See https://quality.livecode.com/show_bug.cgi?id=23875
Paul Dupuis
Researchware, Inc.

stam
Posts: 3140
Joined: Sun Jun 04, 2006 9:39 pm

Re: polylist number of row limit

Post by stam » Thu Dec 29, 2022 5:40 pm

terryho wrote:
Thu Dec 29, 2022 3:49 pm
Hi

> I don't believe that's true. Indeed, the DG was invented to get past the 32k pixel limit on rendered group objects.
In the past I had this problem. But did not make a full test on DG2. If I'm wrong, please correct me.

Attach is the stack, which I change the speedtest to add polylist in the test. Please correct me, if some wrong in my script.

Regards

Terry Ho
Hi Terry,

I can see your stack is pretty much the same as the speed test example stack released with polygrid, only with polylist added as well. Interesting to see that it performs slightly faster than PG - but also not sure what this gains? PL is really a version of the DG form (but the ability to show columns of rows) and is a different beast from PG and its use case is different. As you say we now have more options - although for pure customisability the DG is still king.

What was the question regarding your test stack?

For what it's worth, I changed the number of records created from 10,000 to 40,000 - the DG did very well at 65 ms. So your impression about the limitations of the DG seems incorrect. There is also a fixed speed difference between PG and PL in the order of 8-10 ms, which is unaffected by number of rows. In fact the rendering of both DG, PG and PL seem relatively independent of number of rows, whereas the text field slows progressively. These are the results with 40,000 rows :
speed test 40,000 rows.jpg

stam
Posts: 3140
Joined: Sun Jun 04, 2006 9:39 pm

Re: polylist number of row limit

Post by stam » Thu Dec 29, 2022 5:55 pm

Actually just out of curiosity I increased the number of rows to 80,000 - everything does get a bit slower but clearly the tableField is a dog, 2 whole orders of magnitude slower:
speed test - 80,000 rows.jpg

Clearly the DG is able to render 80,000 rows in just 130 ms - so your assumption about the limitation of the DG is not correct... And while the PG is faster, it only gains you 73 milliseconds for the 80,000 rows. If anything this reaffirms what a great tool the DG is ;)
Last edited by stam on Thu Dec 29, 2022 6:22 pm, edited 1 time in total.

stam
Posts: 3140
Joined: Sun Jun 04, 2006 9:39 pm

Re: polylist number of row limit

Post by stam » Thu Dec 29, 2022 6:04 pm

paul@researchware.com wrote:
Thu Dec 29, 2022 5:08 pm
Richard is correct. Any limit on Datagrid ROWS is in excess of 32,000. There may be a limit in the number of VISIBLE ROWS of 32,767px due to the rendering limits of the group object, but I doubt anyone has ever run into that limit. The DG is designed to cache rows much greater than 32K and just display the visible ones. There is, however, a 32,767px limit on COLUMNS. See https://quality.livecode.com/show_bug.cgi?id=23875
Thanks Paul, that's very interesting.
Out of curiosity I checked to see how long a width of 32,767 pixels is in reality:
Assuming 1 pixel = 0.0002645833 m (which is what I found online), this would equate to 8.7 meters.
Has anyone really come up against this limit?
I would suggest that if yes, there are more serious issues with the UI design used that with the datagrid itself... No one could possible need an app to use 8.7 m of columns, surely?
Or have I misunderstood the limitation?

S.
Last edited by stam on Thu Dec 29, 2022 6:20 pm, edited 1 time in total.

FourthWorld
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 10065
Joined: Sat Apr 08, 2006 7:05 am
Contact:

Re: polylist number of row limit

Post by FourthWorld » Thu Dec 29, 2022 6:18 pm

stam wrote:
Thu Dec 29, 2022 6:04 pm
Out of curiosity I checked to see how long a width of 32,767 pixels is in reality:
Assuming 1 pixel = 0.0002645833 m (which is what I found online), this would equate to 8.7 meters.
Has anyone really come up against this limit?
I would suggest that if yes, there are more serious issues with the UI design used that with the datagrid itself... No one could possible need an app to use 8.7 m of columns, surely?
A similar question may be worth pondering for record count: what exactly do we expect anyone to actually do with a list of 32,000 records? Read them? :)

Of course what we'd want there is filtering.

And if the filtering is done up front, we never need to render 32,000 records.
Richard Gaskin
LiveCode development, training, and consulting services: Fourth World Systems
LiveCode Group on Facebook
LiveCode Group on LinkedIn

FourthWorld
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 10065
Joined: Sat Apr 08, 2006 7:05 am
Contact:

Re: polylist number of row limit

Post by FourthWorld » Thu Dec 29, 2022 6:26 pm

terryho wrote:
Thu Dec 29, 2022 3:49 pm
Attach is the stack, which I change the speedtest to add polylist in the test. Please correct me, if some wrong in my script.
Thanks again for the stack. Terry.

Off the top I cut the field rendering sped by about 1/3 with a checkbox: turning on the dontWrap field property bypasses the engine's need to calculate line wraps. In this case I think that's a better comparative representation.

Field rendering time drops another 15% or so if I turn on the xGrid and yGrid properties (I used a tabstops of 50), which is possibly an even better parity to the other displays.


I can't yet compare PolyGrid or PolyList as those don't appear here. Normally such omissions are a result of incomplete inclusion during standalone building, but in this case I'm running in the IDE.

Anyone have enough experience with either of those to have an opinion on why they don't render here? I've never needed either (or any other widget) yet, so there may be some odd thing the widget-using customer is expected to do that I simply haven't done.
Richard Gaskin
LiveCode development, training, and consulting services: Fourth World Systems
LiveCode Group on Facebook
LiveCode Group on LinkedIn

Post Reply