summaryrefslogtreecommitdiff
path: root/contrib/pg_buffercache/pg_buffercache.control
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2015-10-16 14:43:18 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2015-10-16 14:43:18 -0400
commita2ad467ae4a09c79488044c552edfa40724f41c6 (patch)
tree953b3ff3bb88dd3190e834721f058d7b8269d5bf /contrib/pg_buffercache/pg_buffercache.control
parent83c34825e5b02880bdad2afdba7861590abe7fe7 (diff)
Fix O(N^2) performance problems in regular-expression compiler.
Change the singly-linked in-arc and out-arc lists to be doubly-linked, so that arc deletion is constant time rather than having worst-case time proportional to the number of other arcs on the connected states. Modify the bulk arc transfer operations copyins(), copyouts(), moveins(), moveouts() so that they use a sort-and-merge algorithm whenever there's more than a small number of arcs to be copied or moved. The previous method is O(N^2) in the number of arcs involved, because it performs duplicate checking independently for each copied arc. The new method may change the ordering of existing arcs for the destination state, but nothing really cares about that. Provide another bulk arc copying method mergeins(), which is unused as of this commit but is needed for the next one. It basically is like copyins(), but the source arcs might not all come from the same state. Replace the O(N^2) bubble-sort algorithm used in carcsort() with a qsort() call. These changes greatly improve the performance of regex compilation for large or complex regexes, at the cost of extra space for arc storage during compilation. The original tradeoff was probably fine when it was made, but now we care more about speed and less about memory consumption. Back-patch to all supported branches.
Diffstat (limited to 'contrib/pg_buffercache/pg_buffercache.control')
0 files changed, 0 insertions, 0 deletions