* src/tgbaalgos/Makefile.am, src/tgbaalgos/gtec/Makefile.am: Add $(VISIBILITY_CXXFLAGS). * src/tgbaalgos/bfssteps.hh, src/tgbaalgos/compsusp.hh, src/tgbaalgos/cutscc.hh, src/tgbaalgos/cycles.hh, src/tgbaalgos/degen.hh, src/tgbaalgos/dotty.hh, src/tgbaalgos/dottydec.hh, src/tgbaalgos/dupexp.hh, src/tgbaalgos/eltl2tgba_lacim.hh, src/tgbaalgos/emptiness.hh, src/tgbaalgos/gtec/ce.hh, src/tgbaalgos/gtec/explscc.hh, src/tgbaalgos/gtec/gtec.hh, src/tgbaalgos/gtec/nsheap.hh, src/tgbaalgos/gtec/sccstack.hh, src/tgbaalgos/gtec/status.hh, src/tgbaalgos/gv04.hh, src/tgbaalgos/isdet.hh, src/tgbaalgos/isweakscc.cc, src/tgbaalgos/isweakscc.hh, src/tgbaalgos/lbtt.hh, src/tgbaalgos/ltl2taa.hh, src/tgbaalgos/ltl2tgba_fm.hh, src/tgbaalgos/ltl2tgba_lacim.hh, src/tgbaalgos/magic.hh, src/tgbaalgos/minimize.hh, src/tgbaalgos/neverclaim.hh, src/tgbaalgos/postproc.hh, src/tgbaalgos/powerset.hh, src/tgbaalgos/projrun.hh, src/tgbaalgos/randomgraph.hh, src/tgbaalgos/reachiter.hh, src/tgbaalgos/reducerun.hh, src/tgbaalgos/reductgba_sim.cc, src/tgbaalgos/reductgba_sim.hh, src/tgbaalgos/replayrun.hh, src/tgbaalgos/rundotdec.hh, src/tgbaalgos/safety.hh, src/tgbaalgos/save.hh, src/tgbaalgos/scc.hh, src/tgbaalgos/sccfilter.hh, src/tgbaalgos/se05.hh, src/tgbaalgos/simulation.hh, src/tgbaalgos/stats.hh, src/tgbaalgos/stripacc.hh, src/tgbaalgos/tau03.hh, src/tgbaalgos/tau03opt.hh, src/tgbaalgos/translate.hh: Mark public symbol with SPOT_API.
112 lines
3.5 KiB
C++
112 lines
3.5 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 SPOT_API 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);
|
|
|
|
protected:
|
|
const tgba* do_simul(const tgba* input, int opt);
|
|
const tgba* do_ba_simul(const tgba* input, int opt);
|
|
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_;
|
|
int simul_limit_;
|
|
int scc_filter_;
|
|
int ba_simul_;
|
|
};
|
|
/// @}
|
|
}
|
|
|
|
#endif // SPOT_TGBAALGOS_POSTPROC_HH
|