Blame view
tools/sctk-2.4.10/src/asclite/test/alignedsegment_test.cpp
1.97 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 |
/* * 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. */ #include "alignedsegment_test.h" #include "alignedsegment.h" #include "segment.h" #include "token.h" #include "speech.h" #include "speechset.h" void AlignedSegmentTest::TestAll() { SpeechSet* speechSet = new SpeechSet(); Speech* speech = new Speech(speechSet); Segment* seg = Segment::CreateWithDuration(0, 10000, speech); Segment* seg2 = Segment::CreateWithDuration(0, 10000, speech); AlignedSegment* as = new AlignedSegment(seg); assert(as->GetReferenceSegment() == seg); Token* ref1 = Token::CreateWithDuration(0, 5000, seg, "a"); Token* ref2 = Token::CreateWithDuration(0, 5000, NULL); Token* hyp1 = Token::CreateWithDuration(200, 4300, seg2, "a"); Token* hyp2 = Token::CreateWithDuration(100, 4800, seg2, "b"); // add improper ref (the parent segment of ref2 must be seg to be correct) assert(as->AddTokenAlignment(ref2, "hyp1", hyp1) < 0); // add correct ref assert(as->AddTokenAlignment(ref1, "hyp1", hyp1) > 0); assert(as->AddTokenAlignment(ref1, "hyp2", hyp2) > 0); delete speechSet; delete speech; delete seg; delete seg2; delete ref1; delete ref2; delete hyp1; delete hyp2; } |