Sha256: 567efc0f2a52310f2a6d19c1e4d5ec0d738a543c9825ba7db533852e14065910
Contents?: true
Size: 1.66 KB
Versions: 1
Compression:
Stored size: 1.66 KB
Contents
# encoding: utf-8 # Mixin for timed non-assignment timeless Petri net transitions. # module YPetri::Transition::Type_t # Result of the transition's "function", regardless of the #enabled? status. # def action if stoichiometric? then rslt = action_closure.( *domain_marking ) stoichiometry.map { |coeff| rslt * coeff } else action_closure.( *domain_marking ) end end # action # Fires the transition, honoring cocking. Returns true if the transition # fired, false if it wasn't cocked. # def fire cocked?.tap { |x| ( uncock; fire! ) if x } end # Fires the transition regardless of cocking. # def fire! act = Array( action ) fail TypeError, "Wrong output arity of the action " + "closure of #{self}!" if act.size != codomain.size codomain.each_with_index do |place, index| # adding action node no. index to place place.add act.fetch( index ) end return nil end # Timeless transition is _enabled_ if its action would result in a legal # codomain marking. # def enabled? codomain.zip( action ).all? do |place, change| begin; place.guard.( place.marking + change ) rescue YPetri::GuardError; false end end end # Transition's firing under current simulation. # def fir simulation=world.simulation simulation.net.State.Feature.Firing( self ) % simulation end # Prints the transition's action under current simulation. # def pa simulation=world.simulation, **nn ff = simulation.net.State.Features.Delta( codomain, transitions: self ) ( ff >> ff % simulation ).pretty_print_numeric_values **nn end end # class YPetri::Transition::Type_t
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
y_petri-2.4.3 | lib/y_petri/transition/t.rb |