* src/tgbaalgos/postproc.hh, src/tgbaalgos/postproc.cc: Honor the "simul" option in the option_map. (do_simul, do_degen): New method to wrap the algorithms that may be altered via option_map. * src/bin/man/ltl2tgba.x (simul): Document this option.
108 lines
3.4 KiB
C++
108 lines
3.4 KiB
C++
// -*- coding: utf-8 -*-
|
|
// Copyright (C) 2012, 2013 Laboratoire de Recherche et Développement
|
|
// de l'Epita (LRDE).
|
|
//
|
|
// This file is part of Spot, a model checking library.
|
|
//
|
|
// Spot is free software; you can redistribute it and/or modify it
|
|
// under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation; either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Spot is distributed in the hope that it will be useful, but WITHOUT
|
|
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
// License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#ifndef SPOT_TGBAALGOS_POSTPROC_HH
|
|
# define SPOT_TGBAALGOS_POSTPROC_HH
|
|
|
|
#include "tgba/tgba.hh"
|
|
|
|
namespace spot
|
|
{
|
|
class option_map;
|
|
|
|
/// \addtogroup tgba_reduction
|
|
/// @{
|
|
|
|
/// \brief Wrap TGBA/BA/Monitor post-processing algorithms in an
|
|
/// easy interface.
|
|
///
|
|
/// This class is a shell around scc_filter(),
|
|
/// minimize_obligation(), simulation(), iterated_simulations(), and
|
|
/// degeneralize(). These different algorithms will be combined
|
|
/// depending on the various options set with set_type(),
|
|
/// set_pref(), and set_level().
|
|
///
|
|
/// This helps hiding some of the logic required to combine these
|
|
/// simplifications efficiently (e.g., there is no point calling
|
|
/// degeneralize() or any simulation when minimize_obligation()
|
|
/// succeeded.)
|
|
///
|
|
/// Use set_pref() method to specify whether you favor
|
|
/// deterministic automata or small automata. If you don't care,
|
|
/// less post processing will be done.
|
|
///
|
|
/// The set_level() method lets you set the optimization level.
|
|
/// A higher level enables more costly post-processings. For instance
|
|
/// pref=Small,level=High will try two different post-processings
|
|
/// (one with minimize_obligation(), and one with
|
|
/// iterated_simulations()) an keep the smallest result.
|
|
/// pref=Small,level=Medium will only try the iterated_simulations()
|
|
/// when minimized_obligation failed to produce an automaton smaller
|
|
/// than its input. pref=Small,level=Low will only run
|
|
/// simulation().
|
|
class postprocessor
|
|
{
|
|
public:
|
|
/// \brief Construct a postprocessor.
|
|
///
|
|
/// The \a opt argument can be used to pass extra fine-tuning
|
|
/// options used for debugging or benchmarking.
|
|
postprocessor(const option_map* opt = 0);
|
|
|
|
enum output_type { TGBA, BA, Monitor };
|
|
void
|
|
set_type(output_type type)
|
|
{
|
|
type_ = type;
|
|
}
|
|
|
|
enum output_pref { Any, Small, Deterministic };
|
|
void
|
|
set_pref(output_pref pref)
|
|
{
|
|
pref_ = pref;
|
|
}
|
|
|
|
enum optimization_level { Low, Medium, High };
|
|
void
|
|
set_level(optimization_level level)
|
|
{
|
|
level_ = level;
|
|
}
|
|
|
|
/// Return the optimized automaton and delete \a input_disown.
|
|
const tgba* run(const tgba* input_disown, const ltl::formula* f);
|
|
|
|
private:
|
|
const tgba* do_simul(const tgba* input);
|
|
const tgba* do_degen(const tgba* input);
|
|
|
|
output_type type_;
|
|
output_pref pref_;
|
|
optimization_level level_;
|
|
// Fine-tuning options fetched from the option_map.
|
|
bool degen_reset_;
|
|
bool degen_order_;
|
|
bool degen_cache_;
|
|
int simul_;
|
|
};
|
|
/// @}
|
|
}
|
|
|
|
#endif // SPOT_TGBAALGOS_POSTPROC_HH
|