// 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 #include #include // for RandArcSelection #include namespace fst { namespace script { // 1 typedef args::Package RandEquivalentInnerArgs1; typedef args::WithReturnValue RandEquivalentArgs1; template void RandEquivalent(RandEquivalentArgs1 *args) { const Fst &fst1 = *(args->args.arg1.GetFst()); const Fst &fst2 = *(args->args.arg2.GetFst()); args->retval = RandEquivalent(fst1, fst2, args->args.arg3, args->args.arg4, args->args.arg5, args->args.arg6); } // 2 typedef args::Package &> RandEquivalentInnerArgs2; typedef args::WithReturnValue RandEquivalentArgs2; template void RandEquivalent(RandEquivalentArgs2 *args) { const Fst &fst1 = *(args->args.arg1.GetFst()); const Fst &fst2 = *(args->args.arg2.GetFst()); const RandGenOptions &opts = args->args.arg6; int32 seed = args->args.arg3; if (opts.arc_selector == UNIFORM_ARC_SELECTOR) { UniformArcSelector arc_selector(seed); RandGenOptions< UniformArcSelector > 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_selector(seed); RandGenOptions< FastLogProbArcSelector > ropts(arc_selector, opts.max_length, opts.npath); args->retval = RandEquivalent(fst1, fst2, args->args.arg4, args->args.arg5, ropts); } else { LogProbArcSelector arc_selector(seed); RandGenOptions< LogProbArcSelector > 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_