Skip to content
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

Find, Query and BNINDEX #12

Open
SamGG opened this issue May 3, 2020 · 5 comments
Open

Find, Query and BNINDEX #12

SamGG opened this issue May 3, 2020 · 5 comments

Comments

@SamGG
Copy link

SamGG commented May 3, 2020

Dear Aaron,
Thanks fo this package. After having worked with RccpAnnoy, I finally ended up with your package, as it is more general and avoids errors concerning index starting at in C.
Currently, I was misleaded by the use of findKNN. I am used to define the index using buildHsnw. I thought that findKNN allows me to query a new dataset X when I provide the precomputed index. But it is clearly indicated in the details that it does not. Blame on me, I didn't read the details.
Nevertheless, I think that others will make the same shortcut. Therefore it would be kind of you if the documentation links findKNN and queryKNN and both functions raise a warning stating that X is ignored when BNINDEX is provided.
Thanks.

@SamGG
Copy link
Author

SamGG commented May 3, 2020

Could you also explain the benefit of specifying both BN arguments as in the example
str(a.out3 <- queryKNN(Y,Z, k=10, BNINDEX=a.dex, BNPARAM=AnnoyParam()))
Best.

@LTLA
Copy link
Member

LTLA commented May 4, 2020

Therefore it would be kind of you if the documentation links findKNN and queryKNN and both functions raise a warning stating that X is ignored when BNINDEX is provided.

I suppose that would be possible.

Could you also explain the benefit of specifying both BN arguments as in the example

There is none, I just implemented that method so that developers wouldn't have to go out of their way to omit the BNPARAM argument if BNINDEX was supplied.

@SamGG
Copy link
Author

SamGG commented May 4, 2020

Thanks for your answer. It would be kind to get a warning.
I still didn't get the point of the example. Too much negative words in your last sentence make me loose the meaning. Could you elaborate an example where providing BNINDEX and BNPRAM could be useful?

@LTLA
Copy link
Member

LTLA commented May 4, 2020

It's not useful so much as it's just allowed. If I raised an error or warning, a developer would have to omit the BNPARAM argument every time they passed a BNINDEX argument, which is annoying.

@SamGG
Copy link
Author

SamGG commented May 4, 2020

OK. Do what you think is the best.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants