Commit f5b7d103 authored by Tom Lane's avatar Tom Lane

Improve performance of fixempties() pass in regular-expression compiler.

The previous coding took something like O(N^4) time to fully process a
chain of N EMPTY arcs.  We can't really do much better than O(N^2) because
we have to insert about that many arcs, but we can do lots better than
what's there now.  The win comes partly from using mergeins() to amortize
de-duplication of arcs across multiple source states, and partly from
exploiting knowledge of the ordering of arcs for each state to avoid
looking at arcs we don't need to consider during the scan.  We do have
to be a bit careful of the possible reordering of arcs introduced by
the sort-merge coding of the previous commit, but that's not hard to
deal with.

Back-patch to all supported branches.
parent 579840ca
This diff is collapsed.
...@@ -129,8 +129,6 @@ static struct arc *allocarc(struct nfa *, struct state *); ...@@ -129,8 +129,6 @@ static struct arc *allocarc(struct nfa *, struct state *);
static void freearc(struct nfa *, struct arc *); static void freearc(struct nfa *, struct arc *);
static void changearctarget(struct arc *, struct state *); static void changearctarget(struct arc *, struct state *);
static int hasnonemptyout(struct state *); static int hasnonemptyout(struct state *);
static int nonemptyouts(struct state *);
static int nonemptyins(struct state *);
static struct arc *findarc(struct state *, int, pcolor); static struct arc *findarc(struct state *, int, pcolor);
static void cparc(struct nfa *, struct arc *, struct state *, struct state *); static void cparc(struct nfa *, struct arc *, struct state *, struct state *);
static void sortins(struct nfa *, struct state *); static void sortins(struct nfa *, struct state *);
...@@ -160,8 +158,8 @@ static int push(struct nfa *, struct arc *); ...@@ -160,8 +158,8 @@ static int push(struct nfa *, struct arc *);
#define COMPATIBLE 3 /* compatible but not satisfied yet */ #define COMPATIBLE 3 /* compatible but not satisfied yet */
static int combine(struct arc *, struct arc *); static int combine(struct arc *, struct arc *);
static void fixempties(struct nfa *, FILE *); static void fixempties(struct nfa *, FILE *);
static struct state *emptyreachable(struct nfa *, struct state *, struct state *); static struct state *emptyreachable(struct nfa *, struct state *,
static void replaceempty(struct nfa *, struct state *, struct state *); struct state *, struct arc **);
static int isconstraintarc(struct arc *); static int isconstraintarc(struct arc *);
static int hasconstraintout(struct state *); static int hasconstraintout(struct state *);
static void fixconstraintloops(struct nfa *, FILE *); static void fixconstraintloops(struct nfa *, FILE *);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment