Coder Social home page Coder Social logo

fransnygaard / grasshopperasynccomponent Goto Github PK

View Code? Open in Web Editor NEW

This project forked from specklesystems/grasshopperasynccomponent

0.0 0.0 0.0 99 KB

Jankless Grasshopper Components

Home Page: https://speckle.systems

License: Apache License 2.0

C# 100.00%

grasshopperasynccomponent's Introduction

GrasshopperAsyncComponent

Twitter Follow Discourse users Slack Invite website

Less Janky Grasshopper Components

See the companion blog post about the rationale behind this approach. This repo demonstrates how to create an eager and responsive async component that does not block the Grasshopper UI thread while doing heavy work in the background, reports on progress and - theoretically - makes your life easier.

We're not so sure about the last part! We've put this repo out in the hope that others will find something useful inside - even just inspiration for the approach.

uselesscycles

Looks nice, doesn't it? Notice that the solution runs "eagerly" - every time the input changes, the the computation restarts and cancels any previous tasks that are still running. Once everything is done calculating, the results are set. And the best parts:

  • Grasshopper and Rhino are still responsive!
  • There's progress reporting! (personally I hate waiting for Gh to unfreeze...).
  • Thread safe: 99% of the times this won't explode in your face. It still might though!

Approach

Provides an abstract GH_AsyncComponent which you can inherit from to scaffold your own async component. There's more info in the blogpost on how to go about it.

Checkout the sample implementation!

  • Prime number calculator Calculates the n'th prime. Can actually spin your computer's fans quite a bit for numbers > 100.000!
  • Usless spinner does no meaningfull CPU work, just keeps a thread busy with SpinWait().

Current limitations

Main current limitation is around data matching. Solved! See this PR. Components inheriting from the GH_AsyncComponent class can now nicely handle multiple runs and any kind of data matching:

oneproblemsolved

Flash of null data Solved! These Async Components now only expire their downstream dependants when they're done with their tasks.

lookmanoflash-2

Other limitations:

  • This approach is most efficient if you can batch together as many iterations as possible. Ideally you'd work with trees straight away.

  • Task cancellation is up to the developer: this approach won't be too well suited for components calling code from other libraries that you don't, or can't, manage.

FAQ

Q: Does this component use all my cores? A: OH YES. It goes WROOOM.

image

Q: Can I enable cancellation of a longer running task?

A: Yes, now you can! In your component, just add a right click menu action like so:

    public override void AppendAdditionalMenuItems(ToolStripDropDown menu)
    {
      base.AppendAdditionalMenuItems(menu);
      Menu_AppendItem(menu, "Cancel", (s, e) =>
      {
        RequestCancellation();
      });
    }

Debugging

Quite easy:

  • Clone this repository and open up the solution in Visual Studio.
  • Once you've built it, add the bin folder to the Grasshopper Developer Settings (type GrasshopperDeveloperSettings in the Rhino command line) and open up Grasshopper.
  • You should see a new component popping up under "Samples > Async" in the ribbon.
  • A simple

Contributing

Please make sure you read the contribution guidelines and Code of Conduct for an overview of the best practices we try to follow.

Community

The Speckle Community hangs out on the forum, do join and introduce yourself & feel free to ask us questions!

Security

For any security vulnerabilities or concerns, please contact us directly at security[at]speckle.systems.

License

Unless otherwise described, the code in this repository is licensed under the Apache-2.0 License. Please note that some modules, extensions or code herein might be otherwise licensed. This is indicated either in the root of the containing folder under a different license file, or in the respective file's header. If you have any questions, don't hesitate to get in touch with us via email.

grasshopperasynccomponent's People

Contributors

didimitrie avatar alanrynne avatar teocomi avatar

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.