Blame view
tools/sctk-2.4.10/src/asclite/core/segmentsgroup.h
4.05 KB
8dcb6dfcb first commit |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 |
/* * ASCLITE * Author: Jerome Ajot, Jon Fiscus, Nicolas Radde, Chris Laprun * * This software was developed at the National Institute of Standards and Technology by * employees of the Federal Government in the course of their official duties. Pursuant * to title 17 Section 105 of the United States Code this software is not subject to * copyright protection and is in the public domain. ASCLITE is an experimental system. * NIST assumes no responsibility whatsoever for its use by other parties, and makes no * guarantees, expressed or implied, about its quality, reliability, or any other * characteristic. We would appreciate acknowledgement if the software is used. * * THIS SOFTWARE IS PROVIDED "AS IS." With regard to this software, NIST MAKES NO EXPRESS * OR IMPLIED WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING MERCHANTABILITY, * OR FITNESS FOR A PARTICULAR PURPOSE. */ #ifndef SEGMENTSGROUP_H #define SEGMENTSGROUP_H #include "token.h" #include "segment.h" #include "id.h" #include "logger.h" /** * This class represent a group of segments with the information * about ref/hyp if this information exist. */ class SegmentsGroup { public: // class constructor SegmentsGroup() { s_id = ID::GetID(); } // class destructor ~SegmentsGroup(); /** * Add an Hypothesis into the SegmentGroup. */ void AddHypothesis(Segment* hypothesis); /** * Add a list of Hypothesis into the SegmentGroup. * This list should be under the same Speech object. */ void AddHypothesis(const vector<Segment*> & hypothesis) { hypothesiss.push_back(hypothesis); } /** * Add a reference segment into the SegmentGroup. */ void AddReference(Segment* reference); /** * Add a list of reference segment into the SegmentGroup. * This list should be under the same Speech object. */ void AddReference(const vector<Segment*> & reference) { references.push_back(reference); } /** * Return the Segments for the reference nb index */ vector<Segment*> GetReference(const size_t& index) { return references[index]; } /** * Return the Segments for the hypothesis nb index */ vector<Segment*> GetHypothesis(const size_t& index) { return hypothesiss[index]; } /** * Return the List of Token by topological order for the Reference no i */ vector<Token*> ToTopologicalOrderedStructRef(const size_t& index); /** * Return the List of Token by topological order for the Hypothesis no i */ vector<Token*> ToTopologicalOrderedStructHyp(const size_t& index); /** * Return the number of references */ size_t GetNumberOfReferences() { return references.size(); } /** * Return the number of hypothesis */ size_t GetNumberOfHypothesis() { return hypothesiss.size(); } /** * Return a possible Reference for the given Hyp token. * The Segment returned is the first that match the token time * This method should always return a Segment as an Reference should always contain a Segment at a given time. */ Segment* GetRefSegmentByTime(Token* token); /** * Return true if the Group contains segment to ignore in scoring */ bool isIgnoreInScoring(); /** * Get the guessed difficulty number of this alignement * linear number > with difficulty */ ullint GetDifficultyNumber(); /* * Return a String definint the difficulty number */ string GetDifficultyString(); /** Returns a string representation of this SegmentGroup. */ string ToString(); /** Log display Alignment */ void LoggingAlignment(const bool& bgeneric, const string& type); ulint GetsID() { return s_id; } int GetTotalDuration(); int GetMinTime(); int GetMaxTime(); private: /** * Vector that contain all the segments (ref) */ vector<vector<Segment*> > references; /** * Vector that contain all the segments (hyp) */ vector<vector<Segment*> > hypothesiss; /** the logger */ static Logger* logger; ulint s_id; }; #endif // SEGMENTSGROUP_H |