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

Composition of Petri Nets #13

Open
vanrein opened this issue Feb 1, 2018 · 1 comment
Open

Composition of Petri Nets #13

vanrein opened this issue Feb 1, 2018 · 1 comment

Comments

@vanrein
Copy link
Owner

vanrein commented Feb 1, 2018

A few mechanisms can be thought of for composing Petri Nets:

  • Combining same-named transitions. Transitions fire unpredictably, and additional arcs add nothing but constraints to that.
  • Combining same-named places? This would seem to tap and inject tokens from places when viewing a partial Petri Net. May be a break with the concept, if not carefully done.
  • Refinement of the atomic (not zero-time) transition into smaller transitions. May be a break with the concept, if not carefully done.

These can be really helpful in managing complexity. When the models are supplied as a list, the compiler can, wel, er... compile them into a larger one. Since the editor and simulator are likely to not follow this, the emphasis on predictable semantics has been added above.

At the present time, it may be that the only thing we shall consider are the same-named transitions.

@vanrein
Copy link
Owner Author

vanrein commented Feb 1, 2018

In the interest of automated analysis of the composed Petri Net, a combined PNML file will be output. That is the one to run deadlock and liveness analysis against, if you are so inclined.

Not many of these tools seem to be around, but research exists so this may be a matter of having tools like these to draw attention to Petri Nets for practical applications.

A bad approach would be to sit back and wait for the perfect solution from science; very often, there are fundamental problems (that cannot be solved, hence fundamental) or corner cases that have little bearing on practical systems.

A better approach would be to guide designers towards structures that can be proven to do what they want, or that require human oversight to erradicate or specially-handle corner cases.

The task for Perpetuum is to integrate well with feedback mechanisms, for instance by retaining symbols from the original design, and perhaps include annotations inasfar as PNML will allow them in the composed output.

As an example of what we're open to, my own PhD work on model checking has made it clear that concrete (counter) examples work well for human consumption. This may require simple means, like a list of instance names to make these concrete runs of problem cases more pallatable to end users.

Though not a primary purpose of this project, Perpetuum is likely to welcome extensions that perform analysis as part of the compiler.

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

No branches or pull requests

1 participant