Home | History | Annotate | Download | only in script
      1 
      2 // Licensed under the Apache License, Version 2.0 (the "License");
      3 // you may not use this file except in compliance with the License.
      4 // You may obtain a copy of the License at
      5 //
      6 //     http://www.apache.org/licenses/LICENSE-2.0
      7 //
      8 // Unless required by applicable law or agreed to in writing, software
      9 // distributed under the License is distributed on an "AS IS" BASIS,
     10 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     11 // See the License for the specific language governing permissions and
     12 // limitations under the License.
     13 //
     14 // Copyright 2005-2010 Google, Inc.
     15 // Author: jpr (at) google.com (Jake Ratkiewicz)
     16 
     17 #include <fst/script/text-io.h>
     18 
     19 #include <cstring>
     20 #include <sstream>
     21 #include <utility>
     22 using std::pair; using std::make_pair;
     23 
     24 #include <fst/types.h>
     25 #include <fst/util.h>
     26 
     27 namespace fst {
     28 namespace script {
     29 
     30 // Reads vector of weights; returns true on success.
     31 bool ReadPotentials(const string &weight_type,
     32                     const string& filename,
     33                     vector<WeightClass>* potential) {
     34   ifstream strm(filename.c_str());
     35   if (!strm) {
     36     LOG(ERROR) << "ReadPotentials: Can't open file: " << filename;
     37     return false;
     38   }
     39 
     40   const int kLineLen = 8096;
     41   char line[kLineLen];
     42   size_t nline = 0;
     43 
     44   potential->clear();
     45   while (strm.getline(line, kLineLen)) {
     46     ++nline;
     47     vector<char *> col;
     48     SplitToVector(line, "\n\t ", &col, true);
     49     if (col.size() == 0 || col[0][0] == '\0')  // empty line
     50       continue;
     51     if (col.size() != 2) {
     52       LOG(ERROR) << "ReadPotentials: Bad number of columns, "
     53                  << "file = " << filename << ", line = " << nline;
     54       return false;
     55     }
     56 
     57     ssize_t s = StrToInt64(col[0], filename, nline, false);
     58     WeightClass weight(weight_type, col[1]);
     59 
     60     while (potential->size() <= s)
     61       potential->push_back(WeightClass::Zero());
     62     (*potential)[s] = weight;
     63   }
     64   return true;
     65 }
     66 
     67 // Writes vector of weights; returns true on success.
     68 bool WritePotentials(const string& filename,
     69                      const vector<WeightClass>& potential) {
     70   ostream *strm = &std::cout;
     71   if (!filename.empty()) {
     72     strm = new ofstream(filename.c_str());
     73     if (!*strm) {
     74       LOG(ERROR) << "WritePotentials: Can't open file: " << filename;
     75       delete strm;
     76       return false;
     77     }
     78   }
     79 
     80   strm->precision(9);
     81   for (ssize_t s = 0; s < potential.size(); ++s)
     82     *strm << s << "\t" << potential[s] << "\n";
     83 
     84   if (!*strm)
     85     LOG(ERROR) << "WritePotentials: Write failed: "
     86                << (filename.empty() ? "standard output" : filename);
     87   bool ret = *strm;
     88   if (strm != &std::cout)
     89     delete strm;
     90   return ret;
     91 }
     92 
     93 
     94 }  // namespace script
     95 }  // namespace fst
     96