|
|
// Copyright 2005-2024 Google LLC
//
// 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.
//
// See www.openfst.org for extensive documentation on this weighted
// finite-state transducer library.
#ifndef FST_SCRIPT_MAP_H_
#define FST_SCRIPT_MAP_H_
#include <cstdint>
#include <memory>
#include <tuple>
#include <utility>
#include <fst/arc-map.h>
#include <fst/arc.h>
#include <fst/fst.h>
#include <fst/state-map.h>
#include <fst/vector-fst.h>
#include <fst/script/arg-packs.h>
#include <fst/script/fst-class.h>
#include <fst/script/weight-class.h>
namespace fst { namespace script {
template <class M> std::unique_ptr<Fst<typename M::ToArc>> ArcMap( const Fst<typename M::FromArc> &fst, const M &mapper) { using ToArc = typename M::ToArc; auto ofst = std::make_unique<VectorFst<ToArc>>(); ArcMap(fst, ofst.get(), mapper); return ofst; }
template <class M> std::unique_ptr<Fst<typename M::ToArc>> StateMap( const Fst<typename M::FromArc> &fst, const M &mapper) { using ToArc = typename M::ToArc; auto ofst = std::make_unique<VectorFst<ToArc>>(); StateMap(fst, ofst.get(), mapper); return ofst; }
enum class MapType : uint8_t { ARC_SUM, ARC_UNIQUE, IDENTITY, INPUT_EPSILON, INVERT, OUTPUT_EPSILON, PLUS, POWER, QUANTIZE, RMWEIGHT, SUPERFINAL, TIMES, TO_LOG, TO_LOG64, TO_STD };
using FstMapInnerArgs = std::tuple<const FstClass &, MapType, float, double, const WeightClass &>;
using FstMapArgs = WithReturnValue<std::unique_ptr<FstClass>, FstMapInnerArgs>;
template <class Arc> void Map(FstMapArgs *args) { using Weight = typename Arc::Weight; const Fst<Arc> &ifst = *std::get<0>(args->args).GetFst<Arc>(); const auto map_type = std::get<1>(args->args); switch (map_type) { case MapType::ARC_SUM: { auto ofst = StateMap(ifst, ArcSumMapper<Arc>(ifst)); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::ARC_UNIQUE: { auto ofst = StateMap(ifst, ArcUniqueMapper<Arc>(ifst)); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::IDENTITY: { auto ofst = ArcMap(ifst, IdentityArcMapper<Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::INPUT_EPSILON: { auto ofst = ArcMap(ifst, InputEpsilonMapper<Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::INVERT: { auto ofst = ArcMap(ifst, InvertWeightMapper<Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::OUTPUT_EPSILON: { auto ofst = ArcMap(ifst, OutputEpsilonMapper<Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::PLUS: { const auto weight = *std::get<4>(args->args).GetWeight<Weight>(); auto ofst = ArcMap(ifst, PlusMapper<Arc>(weight)); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::POWER: { const auto power = std::get<3>(args->args); auto ofst = ArcMap(ifst, PowerMapper<Arc>(power)); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::QUANTIZE: { const auto delta = std::get<2>(args->args); auto ofst = ArcMap(ifst, QuantizeMapper<Arc>(delta)); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::RMWEIGHT: { auto ofst = ArcMap(ifst, RmWeightMapper<Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::SUPERFINAL: { auto ofst = ArcMap(ifst, SuperFinalMapper<Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::TIMES: { const auto weight = *std::get<4>(args->args).GetWeight<Weight>(); auto ofst = ArcMap(ifst, TimesMapper<Arc>(weight)); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::TO_LOG: { auto ofst = ArcMap(ifst, WeightConvertMapper<Arc, LogArc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::TO_LOG64: { auto ofst = ArcMap(ifst, WeightConvertMapper<Arc, Log64Arc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } case MapType::TO_STD: { auto ofst = ArcMap(ifst, WeightConvertMapper<Arc, StdArc>()); args->retval = std::make_unique<FstClass>(std::move(ofst)); return; } } }
std::unique_ptr<FstClass> Map(const FstClass &ifst, MapType map_type, float delta, double power, const WeightClass &weight);
} // namespace script
} // namespace fst
#endif // FST_SCRIPT_MAP_H_
|