-
Notifications
You must be signed in to change notification settings - Fork 143
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issue 665 #687
base: master
Are you sure you want to change the base?
Issue 665 #687
Conversation
- Changed SpanLabelView.addConstituent(Constituent) to enforce nonoverlapping constituents when appropriate, i.e. the flag is set. - Added a class with two basic tests to make sure that the changes work correctly.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The test looks great. Very minor changes requested.
@@ -60,6 +58,13 @@ public SpanLabelView(String viewName, String viewGenerator, TextAnnotation text, | |||
|
|||
@Override | |||
public void addConstituent(Constituent constituent) { | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
small improvement: please move start/end assignments inside if{} block, as they aren't being used otherwise.
import java.util.List; | ||
|
||
public class SpanLabelViewTest { | ||
// test that addConstituent(Constituent) does not allow overlapping spans |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
make the inline comment a class javadoc. comment can be exactly the same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wasn't this functionality already there? It's not clear what has changed.
@mayhewsw , there were ways to add constituents that sidestepped the overlap check. This issue is intended to fix the problem. |
Ah, I see it now. Yes, looks good. |
- Moved inline comment into JavaDoc comment above class in SpanLabelViewTest - Moved start, end variable initialization and overlap into conditional statement so that they only occur when overlapping spans are not allowed - Moved SpanLevelViewTest into correct module
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM.
@ChaseDuncan one test is failing in CI (teamcity build): please check into it and comment here if it is not related to the changes you made. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM.
- Fixed multiple places in MD and one place in corpus readers where overlapping spans were implicitly or explicitly forbidden but still being used
It looks like there are more places where this was being done unintentionally. Will look into it... |
- Added another ctor to TokenLabelView which has a parameter for specifying whether or not to allow overlapping spans - Changed the TokenLabelView ctor which is used in StanfordTrueCaseHandler since it was clear that overlapping spans are desired
@ChaseDuncan looks like CI build is failing -- please take a look... |
@mssammon I think the problem is a conflict in the design of mention detection and the some of the other CCG software like BasicAnnotatorService. For example: By default MD appears to create overlapping spans, e.g. For some (probably good) reason I don't understand, there's some View copying happening in BasicAnnotatorService. By default it creates Views which do not allow overlapping spans. It's not immediately clear to me how best to address this since the problem involves a bunch of complex system for which I have basically no knowledge. But, if no one else knows what to do, I can look into the code and see what I can figure out. |
I think it is reasonable to change any code that violates the assumption by changing it to explicitly allow overlapping constituents -- since that is going on anyway. For posterity, you could create a list of any such places you change, and an issue that notifies everyone these were changed -- that would ensure (in theory) that someone checks each one. If you want to make this your issue for the next k weeks, please go ahead and then ask anyone who seems likely to have a clue for each given component. @Slash0BZ and @danyaljj are likely candidates for who to ask w.r.t. the Mention view. |
Ah I didn't know that SpanLabelView by design discourages overlapped mentions. In MD, complete mention spans can overlap with each other, but mention heads cannot. I think we either need a special case for SpanLabelView that allows overlapped mentions, or I can try to only add mention heads to the view, and use separate function to generate the complete mention using information stored in the head. |
@Slash0BZ I think the mention view should allow overlap, and that you should provide a utility method in the relevant code that verifies no constraints are violated. |
constituents when appropriate, i.e. the flag is set.
correctly.
Closes #665