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

Is it intended that create_pi() does not trigger on_add events? #568

Open
marcelwa opened this issue Aug 8, 2022 · 5 comments
Open

Is it intended that create_pi() does not trigger on_add events? #568

marcelwa opened this issue Aug 8, 2022 · 5 comments
Labels
discussion Discussions on design decisions with open conclusions

Comments

@marcelwa
Copy link
Contributor

marcelwa commented Aug 8, 2022

Describe the bug
First of all, I'm not sure whether this is a bug or intended behavior.

I have noticed that the default network implementations do not trigger the on_add events when their create_pi() function is called.

I found this behavior misleading as, e.g., depth_view makes explicit usage of this event type to recompute levels on creation of new nodes. There is a test case in depth_view.cpp that tests this feature which of course works because PIs are placed in level 0 anyway, i.e., the default-constructed value for the level data type (uint32_t). To be more precise, PIs show their intended level on creation even though on_add was never called on them.

I'm currently implementing a view that's similar to depth_view and I wanted to rely on this event to process new nodes (including PIs) on creation. @lee30sonia recommended to override the create_pi function and manually call on_add (many thanks for this idea!). While that provides intended behavior for my use case, it would break as soon as someone introduced a new network type that did trigger on_add events on create_pi() because it'd then process PIs twice.

Any input on this matter is welcome. Many thanks in advance!

@lee30sonia
Copy link
Member

So I just discussed with Heinz about this. As I guessed, it was not a conscious decision, but has simply evolved with needs.
I think (though I haven't tried) calling the on_add events in create_pi should not break any existing code. A drawback would be perhaps unnecessary overhead whenever create_pi is called. Thus, I would lean towards the solution I suggested (i.e. overloading create_pi in your view) for now.

We could, of course, re-discuss again in the future if there are more cases where calling on_add in create_pi would make sense.

@lee30sonia lee30sonia added the discussion Discussions on design decisions with open conclusions label Aug 10, 2022
@marcelwa
Copy link
Contributor Author

marcelwa commented Aug 11, 2022

Yes, from an architectural perspective that makes sense. Usually, though, the number of PIs should not be the dominating factor in a logic network compared to the number of nodes. Thus, I think the computational overhead of calling on_add on create_pi would be negligible. Either way, many thanks for your insights 🙏

@lee30sonia
Copy link
Member

Indeed, the overhead should not be too big, so I'm not totally against it. However, small overheads accumulate. The balance between pros and cons is not so clear to me at this point, so I tend to avoid fundamental changes to reduce inconvenience.

@marcelwa
Copy link
Contributor Author

Totally agree with your points. Thanks a lot again. This issue can then be closed.

@lee30sonia
Copy link
Member

I will leave it open in case there will be more discussions from other cases/applications in the future, as I see this as an unsettled decision.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
discussion Discussions on design decisions with open conclusions
Projects
None yet
Development

No branches or pull requests

2 participants