-
Notifications
You must be signed in to change notification settings - Fork 47
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
Deinflection of 見とれていたら #1966
Comments
@enellis Any ideas what went wrong here? We certainly should fix 見とれる too. I thought we had a rule that prioritized longer matches so I'm surprised that 見とれる comes before 見る. |
It would probably be useful to take the number of deinflection steps into account for result sorting - in cases where a verb form can be deinflected in more than one way, the simpler deinflection chains should sort higher. |
Also, recognizing the continuous form twice doesn't make any sense grammatically, right? So we should probably add a rule to prevent this. |
Yeah, there's something off there. I added some logic to prioritize kana-only entries when searching with kana and it seems to be throwing the result off here. I have an alternative implementation that gets this case right so I'll have to look into exactly why. Unfortunately I'm mostly unavailable this week so it might be a few days. |
I had a look into this and here's what I worked out so far. Firstly, the 見とれる/見る case is different to the なる/成る case. The 見とれる/見る caseThis comes about due to the fix for #1722. That is, after deinflecting, we sort within the results by priority. For the input 見とれる we end up producing deinflection candidates "見とれる, 見とれるる, 見とる, 見る". We look each up to see what matching results we find and then sort the results. For the issue in #1722, that allows us to sort 進む before 進ぶ when deinflecting 進んでいます。 For this case, however, it will mean we'll sort the result for 見る before the result for 見とれる. I think it's legitimate to address that by first sorting by the length of the matched text. I've implemented that locally and so far it seems to work. (Edit: Now pushed to the The なる/成る caseThis comes about because of #1610 and #1657. That is, when you look up a kana result, we'll favor words that have kana-only headwords. In that sense, it's sort-of doing the right thing. The first result is 生る whose only sense is marked as "usually kana" so it gets the special "kana match" treatment. It's unfortunate, however, because 成る has 11 senses, 10 of which are marked as "usually kana". If all 11 senses were marked as "usually kana" it would have gotten the special treatment. So I suspect the sorting heuristic needs some tweaking to so that if some portion of the matched senses are marked as "usually kana" we give it the special "kana match" ranking. |
Without this, when deinflecting 見とれる we'll end up sorting the results for 見る before the results for 見とれる itself. See #1966.
Ironically, that was reported by me as well...
I.e. longer matches sort first? Wouldn't this still lead to ties within candidate matches of equal length? That's where my idea came from to take into account the length of the deinflection chain as well. |
Without this, when deinflecting 見とれる we'll end up sorting the results for 見る before the results for 見とれる itself. See #1966.
…king up by kana Without this, when we look up "なる" we'll fail to prioritize the entry for 成る because 1 of its 11 senses is not marked as "usually kana". This also ensures we don't consider non-English senses (which don't have "usually kana" annotations) or unmatched senses. See #1966.
If there are ties within candidate matches of equal length, they will be sorted by priority. I suspect there are some cases where the length of the deinflection chain makes sense but I haven't found any yet. |
Without this, when deinflecting 見とれる we'll end up sorting the results for 見る before the results for 見とれる itself. See #1966.
…king up by kana Without this, when we look up "なる" we'll fail to prioritize the entry for 成る because 1 of its 11 senses is not marked as "usually kana". This also ensures we don't consider non-English senses (which don't have "usually kana" annotations) or unmatched senses. See #1966.
I just stumbled upon this case: 同じ. I would expect 同じ to be the first result as it is more common, and then 同じる |
Oh, yes, that's definitely a regression. I'll have to investigate. Maybe we do need to sort by the length of the deinflection chain as suggested by @Tomalak after all. |
Shouldn't the match be determined by a word boundary first and then the frequency (commonness)? |
Could you explain what you mean by word boundary exactly? |
I mean Regex word boundary. E.g. when "同じ." is moused over in the examples above the definition is shown for "同じる" first, though "同じ." clearly bounded by non-word class character dot "." |
Yes, we don't read past the '.' as part of the regex that fetches text to lookup. The 同じ case has been fixed on |
I did not review the code, just judging by this thread I assume you still do de-inflection before dictionary lookup of the match? |
Yes, we generate all the deinflection candidates along with their word types, then we check which ones exist in the dictionary with the corresponding word type. |
Shouldn't be the other way around? Looking in the dictionary first, then doing frequency sort, and then doing de-inflection? |
I might be misunderstanding the suggestion but the trouble is you have to de-inflect first in order to have something to look up in the dictionary. For example, the input text is "食べちゃった" you have to de-inflect to 食べる first so you can look it up. (You could progressively shorten the input until you get to "食べ*" but then you'd have hundreds of matches to sort through.) |
I think it is more logical to lookup "食べちゃった" first, if no match is found then de-inflect to 食べる and look up again. |
I think it's good to look up both so that in cases like 預かり, for example, you'd get both the direct match and the root 預かる. (The current version will get those in the wrong order, but in the next version it will put 預かり before 預かる.) There are a lot of cases in JMdict where there is an entry for an inflected form so this comes up quite a bit. |
Yes, I agree, though the match lookup should be first, de-inflection is just additional info. |
I disagree with this one. Deinflected results are equally valid. This is especially true for the masu stem of verbs, which is used very often as a conjunction. |
You are correct, if you do de-inflection anyway, it does not matter in what order you do lookup: the match or the de-inflection results. With two competing entry, your decision on the display order based on frequency is correct. Probably you already have pre-computed de-inflection results for "to be" as the DB index with the order display weight? |
@birtles I'm so sorry for bringing this up again, but after reconsidering—particularly regarding the あり case—I believe the initial approach of sorting by the length of the matched text was actually the right choice. The issue with 同じ arises from the unique behavior of Ichidan verbs, which effectively drop their final kana during inflections. I suggest we revert to sorting by matched text length, with an adjustment to subtract 1 from this value if the result is a deinflection and an Ichidan verb. |
Thanks for looking into this. I'm not sure I'm quite convinced. あり seems like more of an edge case to me. Without any context, if you look up あり I think the first result should be 蟻. For example, if you're looking up the words for おつかいありさん then I think it would be odd if it presented you with 有る first. |
This is currently (v 1.20.0) deinflected as (< humble or Kansai dialect < continuous < potential < continuous < -tara) from 見る, which seems a little weird, not at least because of the duplicated "continuous",
Deinflecting as (< continuous < -tara) from 見とれる makes more sense. This is only the second hit in the result list - even for itself.
The text was updated successfully, but these errors were encountered: