3 # measure_call_setup_time - measure time between dialing out and ringing in
 
   5 # Copyright (C) 2015  Antonio Ospite <ao2@ao2.it>
 
   7 # This program is free software: you can redistribute it and/or modify
 
   8 # it under the terms of the GNU General Public License as published by
 
   9 # the Free Software Foundation, either version 3 of the License, or
 
  10 # (at your option) any later version.
 
  12 # This program is distributed in the hope that it will be useful,
 
  13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  15 # GNU General Public License for more details.
 
  17 # You should have received a copy of the GNU General Public License
 
  18 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
  22 from savemysugar.cumulative_average import cumulative_average
 
  23 from savemysugar.Modem import Modem
 
  32         Ring.time = time.time()
 
  33         raise StopIteration("Got the ring we were waiting for")
 
  36 def measure_call_setup_time(ingoing_port, outgoing_port, destination_number):
 
  37     ingoing_modem = Modem(ingoing_port)
 
  38     ingoing_modem.register_callback("RING", on_ring)
 
  40     outgoing_modem = Modem(outgoing_port)
 
  44     min_call_setup_time = 10000
 
  45     max_call_setup_time = -1
 
  47     avg_call_setup_time = 0
 
  51         print("Call: %s" % (i + 1))
 
  52         outgoing_modem.send_command("ATDT" + destination_number + ";")
 
  53         dial_time = time.time()
 
  55         # Wait for the receiver to get a ring before terminating the call
 
  57             ingoing_modem.get_response_loop()
 
  58         except (StopIteration, KeyboardInterrupt):
 
  59             outgoing_modem.send_command("ATH")
 
  60             outgoing_modem.get_response()
 
  62         hangup_time = time.time()
 
  64         call_setup_time = Ring.time - dial_time
 
  65         min_call_setup_time = min(min_call_setup_time, call_setup_time)
 
  66         max_call_setup_time = max(max_call_setup_time, call_setup_time)
 
  67         avg_call_setup_time = cumulative_average(avg_call_setup_time,
 
  70         print("Call setup time: %f" % call_setup_time)
 
  71         print("Min call setup time: %f" % min_call_setup_time)
 
  72         print("Max call setup time: %f" % max_call_setup_time)
 
  73         print("Average call setup time: %f" % avg_call_setup_time)
 
  76         call_time = hangup_time - dial_time
 
  77         min_call_time = min(min_call_time, call_time)
 
  78         max_call_time = max(max_call_time, call_time)
 
  79         print("Total call time: %f" % call_time)
 
  80         print("Min call time: %f" % min_call_time)
 
  81         print("Max call time: %f" % max_call_time)
 
  86         # When dialing with an analog modem I noticed that if calls are
 
  87         # separated one from another they take less time to set up, this
 
  88         # may be due to how an analog modem works: getting it on-hook and
 
  89         # off-hook takes quite some time.
 
  90         inter_call_sleep = 5.2
 
  91         print("Sleeping %.2f sec before the next call..." % inter_call_sleep)
 
  92         time.sleep(inter_call_sleep)
 
  97     if len(sys.argv) != 4:
 
  98         print("usage: %s" % sys.argv[0],
 
  99               "<ingoing serial port> <outgoing serial port>",
 
 100               "<destination number>")
 
 103     measure_call_setup_time(sys.argv[1], sys.argv[2], sys.argv[3])
 
 106 if __name__ == "__main__":