weighting.h revision 9559dd2e30de288a9ff7069bfc59f8500b949a88
1/* 2 * Copyright (C) 2013 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17#ifndef LATINIME_WEIGHTING_H 18#define LATINIME_WEIGHTING_H 19 20#include "defines.h" 21 22namespace latinime { 23 24class DicNode; 25class DicTraverseSession; 26struct DicNode_InputStateG; 27class MultiBigramMap; 28 29class Weighting { 30 public: 31 static void addCostAndForwardInputIndex(const Weighting *const weighting, 32 const CorrectionType correctionType, 33 const DicTraverseSession *const traverseSession, 34 const DicNode *const parentDicNode, DicNode *const dicNode, 35 MultiBigramMap *const multiBigramMap); 36 37 protected: 38 virtual float getTerminalSpatialCost(const DicTraverseSession *const traverseSession, 39 const DicNode *const dicNode) const = 0; 40 41 virtual float getOmissionCost( 42 const DicNode *const parentDicNode, const DicNode *const dicNode) const = 0; 43 44 virtual float getMatchedCost( 45 const DicTraverseSession *const traverseSession, const DicNode *const dicNode, 46 DicNode_InputStateG *inputStateG) const = 0; 47 48 virtual bool isProximityDicNode(const DicTraverseSession *const traverseSession, 49 const DicNode *const dicNode) const = 0; 50 51 virtual float getTranspositionCost( 52 const DicTraverseSession *const traverseSession, const DicNode *const parentDicNode, 53 const DicNode *const dicNode) const = 0; 54 55 virtual float getInsertionCost( 56 const DicTraverseSession *const traverseSession, 57 const DicNode *const parentDicNode, const DicNode *const dicNode) const = 0; 58 59 virtual float getNewWordCost(const DicTraverseSession *const traverseSession, 60 const DicNode *const dicNode) const = 0; 61 62 virtual float getNewWordBigramCost( 63 const DicTraverseSession *const traverseSession, const DicNode *const dicNode, 64 MultiBigramMap *const multiBigramMap) const = 0; 65 66 virtual float getCompletionCost( 67 const DicTraverseSession *const traverseSession, 68 const DicNode *const dicNode) const = 0; 69 70 virtual float getTerminalLanguageCost( 71 const DicTraverseSession *const traverseSession, const DicNode *const dicNode, 72 float dicNodeLanguageImprobability) const = 0; 73 74 virtual bool needsToNormalizeCompoundDistance() const = 0; 75 76 virtual float getAdditionalProximityCost() const = 0; 77 78 virtual float getSubstitutionCost() const = 0; 79 80 virtual float getSpaceSubstitutionCost(const DicTraverseSession *const traverseSession, 81 const DicNode *const dicNode) const = 0; 82 83 virtual ErrorType getErrorType(const CorrectionType correctionType, 84 const DicTraverseSession *const traverseSession, 85 const DicNode *const parentDicNode, const DicNode *const dicNode) const = 0; 86 87 Weighting() {} 88 virtual ~Weighting() {} 89 90 private: 91 DISALLOW_COPY_AND_ASSIGN(Weighting); 92 93 static float getSpatialCost(const Weighting *const weighting, 94 const CorrectionType correctionType, const DicTraverseSession *const traverseSession, 95 const DicNode *const parentDicNode, const DicNode *const dicNode, 96 DicNode_InputStateG *const inputStateG); 97 static float getLanguageCost(const Weighting *const weighting, 98 const CorrectionType correctionType, const DicTraverseSession *const traverseSession, 99 const DicNode *const parentDicNode, const DicNode *const dicNode, 100 MultiBigramMap *const multiBigramMap); 101 // TODO: Move to TypingWeighting and GestureWeighting? 102 static int getForwardInputCount(const CorrectionType correctionType); 103}; 104} // namespace latinime 105#endif // LATINIME_WEIGHTING_H 106