summaryrefslogblamecommitdiff
path: root/kaldi_io/src/tools/openfst/include/fst/script/randequivalent.h
blob: b9296832eaab6b8eebfb37b74e8807d8c22b157e (plain) (tree)








































































































                                                                             
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Copyright 2005-2010 Google, Inc.
// Author: jpr@google.com (Jake Ratkiewicz)

#ifndef FST_SCRIPT_RANDEQUIVALENT_H_
#define FST_SCRIPT_RANDEQUIVALENT_H_

#include <fst/script/arg-packs.h>
#include <fst/script/fst-class.h>
#include <fst/script/randgen.h>  // for RandArcSelection
#include <fst/randequivalent.h>

namespace fst {
namespace script {

// 1
typedef args::Package<const FstClass&, const FstClass&,
                      int32, float, int, int> RandEquivalentInnerArgs1;
typedef args::WithReturnValue<bool,
                              RandEquivalentInnerArgs1> RandEquivalentArgs1;

template<class Arc>
void RandEquivalent(RandEquivalentArgs1 *args) {
  const Fst<Arc> &fst1 = *(args->args.arg1.GetFst<Arc>());
  const Fst<Arc> &fst2 = *(args->args.arg2.GetFst<Arc>());

  args->retval = RandEquivalent(fst1, fst2, args->args.arg3, args->args.arg4,
                                args->args.arg5, args->args.arg6);
}

// 2
typedef args::Package<const FstClass &, const FstClass &, int32,
                      ssize_t, float,
                      const RandGenOptions<RandArcSelection> &>
  RandEquivalentInnerArgs2;

typedef args::WithReturnValue<bool,
                              RandEquivalentInnerArgs2> RandEquivalentArgs2;

template<class Arc>
void RandEquivalent(RandEquivalentArgs2 *args) {
  const Fst<Arc> &fst1 = *(args->args.arg1.GetFst<Arc>());
  const Fst<Arc> &fst2 = *(args->args.arg2.GetFst<Arc>());
  const RandGenOptions<RandArcSelection> &opts = args->args.arg6;
  int32 seed = args->args.arg3;

  if (opts.arc_selector == UNIFORM_ARC_SELECTOR) {
    UniformArcSelector<Arc> arc_selector(seed);
    RandGenOptions< UniformArcSelector<Arc> >
        ropts(arc_selector, opts.max_length, opts.npath);

    args->retval = RandEquivalent(fst1, fst2, args->args.arg4,
                                  args->args.arg5, ropts);
  } else if (opts.arc_selector == FAST_LOG_PROB_ARC_SELECTOR) {
    FastLogProbArcSelector<Arc> arc_selector(seed);
    RandGenOptions< FastLogProbArcSelector<Arc> >
        ropts(arc_selector, opts.max_length, opts.npath);

    args->retval = RandEquivalent(fst1, fst2, args->args.arg4,
                                  args->args.arg5, ropts);
  } else {
    LogProbArcSelector<Arc> arc_selector(seed);
    RandGenOptions< LogProbArcSelector<Arc> >
        ropts(arc_selector, opts.max_length, opts.npath);
    args->retval = RandEquivalent(fst1, fst2, args->args.arg4,
                                  args->args.arg5, ropts);
  }
}


// 1
bool RandEquivalent(const FstClass &fst1,
                    const FstClass &fst2,
                    int32 seed = time(0),
                    ssize_t num_paths = 1,
                    float delta = fst::kDelta,
                    int path_length = INT_MAX);

// 2
bool RandEquivalent(const FstClass &fst1,
                    const FstClass &fst2,
                    int32 seed,
                    ssize_t num_paths,
                    float delta,
                    const fst::RandGenOptions<
                      fst::script::RandArcSelection> &opts);

}  // namespace script
}  // namespace fst



#endif  // FST_SCRIPT_RANDEQUIVALENT_H_