Class: PgVerify::Model::DCCA
- Inherits:
-
Object
- Object
- PgVerify::Model::DCCA
- Defined in:
- lib/pg-verify/model/dcca.rb
Instance Method Summary collapse
- #calc_minimal_critical_sets(powerset, fault_set, hazard, level: 0, minimal_critical_sets: []) ⇒ Object
-
#initialize(graph, runner) ⇒ DCCA
constructor
A new instance of DCCA.
- #perform ⇒ Object
- #select_critical(sets, fault_set, hazard) ⇒ Object
Constructor Details
#initialize(graph, runner) ⇒ DCCA
Returns a new instance of DCCA.
6 7 8 |
# File 'lib/pg-verify/model/dcca.rb', line 6 def initialize(graph, runner) @graph, @runner = graph, runner end |
Instance Method Details
#calc_minimal_critical_sets(powerset, fault_set, hazard, level: 0, minimal_critical_sets: []) ⇒ Object
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/pg-verify/model/dcca.rb', line 19 def calc_minimal_critical_sets(powerset, fault_set, hazard, level: 0, minimal_critical_sets: []) to_check = powerset.select { |set| set.length == level } return minimal_critical_sets if to_check.empty? # Determine which of the sets to check can result in the hazard. critical = select_critical(to_check, fault_set, hazard) # Remove all super sets of the critical ones, as those must be critical as well, # but cannot be minimal. powerset = powerset.reject { |set| critical.any? { |crit_set| set.subset?(crit_set) } } # Keep track of the new critical sets minimal_critical_sets += critical # Continue with the next level. calc_minimal_critical_sets(powerset, fault_set, hazard, level: level+1, minimal_critical_sets: minimal_critical_sets) end |
#perform ⇒ Object
10 11 12 13 14 15 16 17 |
# File 'lib/pg-verify/model/dcca.rb', line 10 def perform() @graph.hazards.map { |hazard| fault_set = @graph.fault_components.map(&:name) powerset = fault_set.powerset sets = calc_minimal_critical_sets(powerset, fault_set, hazard) [hazard, sets] }.to_h end |
#select_critical(sets, fault_set, hazard) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/pg-verify/model/dcca.rb', line 39 def select_critical(sets, fault_set, hazard) specs = sets.map { |set| other_errors = fault_set.reject { |err| set.include?(err) } only_errors = other_errors.empty? \ ? "TRUE" \ : other_errors.map { |err| "#{err} == No" }.join(" && ") formula = "!( (#{only_errors}) U (#{hazard.expression}) )" formula = ParsedExpression.new(formula, ParsedExpression::TYPE_TL) Spec.new("Fault set {#{set.join(', ')}} is safe", formula, nil) } spec_set = SpecSet.wrap(specs) @graph.specification = Specification.new([spec_set]) results = @runner.run_specs(@graph) critical_sets = [] results.each_with_index { |result, index| critical_sets << sets[index] if result.failure? } return critical_sets end |