print_rms.cc
Go to the documentation of this file.
1 // Copyright (c) 2017, The Regents of the University of California
2 // All rights reserved.
3 //
4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are met:
6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above copyright
9 // notice, this list of conditions and the following disclaimer in the
10 // documentation and/or other materials provided with the distribution.
11 // * Neither the name of the University of California nor the
12 // names of its contributors may be used to endorse or promote products
13 // derived from this software without specific prior written permission.
14 //
15 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 // ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OF THE UNIVERSITY OF CALIFORNIA
19 // BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 // POSSIBILITY OF SUCH DAMAGE.
26 
27 #include <cmath>
28 
30 #include "third_party/gflags.h"
31 #include "third_party/glog.h"
33 
34 namespace speech = ::cogrob::cloud::speech;
36 
37 int main(int argc, char *argv[]) {
38  google::InitGoogleLogging(argv[0]);
39  google::LogToStderr();
40  gflags::SetUsageMessage("PrintRMS utility for testing microphone.");
41  gflags::SetVersionString("1.0.0");
42  gflags::ParseCommandLineFlags(&argc, &argv, true);
43 
45  speech::AudioRecorder recorder(&audio_queue);
46  while (true) {
47  std::unique_ptr<AudioSample> sample = std::move(audio_queue.blocking_pop());
48  double square_sum = 0;
49  for (size_t i = 0; i < sample->size(); i += 2) {
50  int s = (static_cast<int8_t>((*sample)[i + 1])) << 8 | (*sample)[i];
51  square_sum += s * s;
52  }
53  double rms = std::sqrt(square_sum / (sample->size() / 2));
54  LOG(INFO) << "RMS: " << rms;
55  }
56 }
XmlRpcServer s
std::vector< uint8_t > AudioSample
Definition: audio_sample.h:43


gcloud_speech_utils
Author(s):
autogenerated on Mon Jun 10 2019 13:20:56