randequivalent.cc
979 Bytes
// See www.openfst.org for extensive documentation on this weighted
// finite-state transducer library.
#include <fst/script/fst-class.h>
#include <fst/script/randequivalent.h>
#include <fst/script/script-impl.h>
namespace fst {
namespace script {
bool RandEquivalent(const FstClass &fst1, const FstClass &fst2, int32 npath,
float delta, time_t seed,
const RandGenOptions<RandArcSelection> &opts) {
if (!internal::ArcTypesMatch(fst1, fst2, "RandEquivalent")) return false;
RandEquivalentInnerArgs iargs(fst1, fst2, npath, delta, seed, opts);
RandEquivalentArgs args(iargs);
Apply<Operation<RandEquivalentArgs>>("RandEquivalent", fst1.ArcType(), &args);
return args.retval;
}
REGISTER_FST_OPERATION(RandEquivalent, StdArc, RandEquivalentArgs);
REGISTER_FST_OPERATION(RandEquivalent, LogArc, RandEquivalentArgs);
REGISTER_FST_OPERATION(RandEquivalent, Log64Arc, RandEquivalentArgs);
} // namespace script
} // namespace fst