GithubHelp home page GithubHelp logo

Not finding correct elbow about kneed HOT 12 CLOSED

arvkevi avatar arvkevi commented on May 22, 2024
Not finding correct elbow

from kneed.

Comments (12)

MattConflitti avatar MattConflitti commented on May 22, 2024 1

The array is about 6000+ elements. If I have some time, I will do that. Thanks for the confirmation!

from kneed.

MattConflitti avatar MattConflitti commented on May 22, 2024 1

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

Hi @MattConflitti thanks for posting, would you mind sharing which version you are using?

import kneed
print(kneed.__version__)

^^^somehow I managed to not include this in the source code^^^
I'll make a PR to update this.

You could try this from the command line though:
pip freeze | grep kneed

from kneed.

MattConflitti avatar MattConflitti commented on May 22, 2024

It looks like that attribute wasn't set.

---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
<ipython-input-63-b9a19a10a516> in <module>()
      1 import kneed
----> 2 print(kneed.__version__)

AttributeError: module 'kneed' has no attribute '__version__'

I installed with pip and that says I have kneed==0.3.1

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

Great, that's the latest version. The last question, have you tried setting interp_method='polynomial' in KneeLocator?

from kneed.

MattConflitti avatar MattConflitti commented on May 22, 2024

I did, this is the result. Similar to the previous one.

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

Thanks for checking.
Do you want to post x, y here so we're working off the same arrays?

You are correct, the knee should be located at the max of the distance curve yd.
Feel free to hack away on this bug with a pull request, otherwise, I'll try to reproduce the errors as soon as a can.

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

It should be easy enough to reproduce, thanks again, hope to jump on this soon.

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

This x and y reproduce a similar error:

n = 6000
x = range(1, n+1)
y = sorted(np.random.gamma(0.5, 1.0, n), reverse=True)

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

This sparked a long-overdue refactor, working on this in #34

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

Hi, @MattConflitti thanks again for raising this issue, the package really needed this update! I spent some time re-reading the paper to ensure that I understood the algorithm correctly. The issue was that kneed was finding all knees and reporting the most recent (or last) knee point. As a result, setting the S parameter had no effect because the last knee was always returned.

I added your example to the README in #34 because it highlights how tuning the S parameter has an effect on the detected knee.

from kneed.

arvkevi avatar arvkevi commented on May 22, 2024

@MattConflitti going to close this for now, but I'm happy to re-open if this doesn't solve the issue.

from kneed.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.