Hi,

Am 01.05.2013 04:57, schrieb William Karl Thompson:
Hi,

I'm working with the cTAKES pipeline to annotate some clinical text. The cTAKES 
syntactic chunker generates overlapping and nested annotations with the same 
syntactic type. For example:

[NP ascending [NP colon polyps]]

What I would like to do is to use TextMarker rules to eliminate nested 
annotations, so at the end of the day just have the following:

[NP colon ascending polyps]

I've tried to use UNMARK, but the following two rules appear to remove all NPs 
starting at the first match, even the containing annotation:

NP{PARTOF(NP)->UNMARK(NP)};
NP{CONTAINS(NP)->UNMARK(NP)};

Is there way to accomplish this that I'm missing? Using loops perhaps?

The simplest solution in your situation would be:

NP{PARTOFNEQ(NP) -> UNMARK(NP)};

(PARTOFNEQ: part of, but not equal)

If it gets more complicated, then something with a loop and/or additional types is necessary:

BLOCK(forEach) Test{} {
    ANY+? Test{-> UNMARK(Test)};
    Test{-> UNMARK(Test)} ANY;
}


Best,

Peter

Thanks,

Will


Reply via email to