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