1 /*
2  *  Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3  *
4  *  Use of this source code is governed by a BSD-style license
5  *  that can be found in the LICENSE file in the root of the source
6  *  tree. An additional intellectual property rights grant can be found
7  *  in the file PATENTS.  All contributing project authors may
8  *  be found in the AUTHORS file in the root of the source tree.
9  */
10 
11 #include "structs.h"
12 #include "bandwidth_estimator.h"
13 #include "entropy_coding.h"
14 #include "codec.h"
15 
16 
17 int
WebRtcIsac_EstimateBandwidth(BwEstimatorstr * bwest_str,Bitstr * streamdata,WebRtc_Word32 packet_size,WebRtc_UWord16 rtp_seq_number,WebRtc_UWord32 send_ts,WebRtc_UWord32 arr_ts,enum IsacSamplingRate encoderSampRate,enum IsacSamplingRate decoderSampRate)18 WebRtcIsac_EstimateBandwidth(
19     BwEstimatorstr*           bwest_str,
20     Bitstr*                   streamdata,
21     WebRtc_Word32               packet_size,
22     WebRtc_UWord16              rtp_seq_number,
23     WebRtc_UWord32              send_ts,
24     WebRtc_UWord32              arr_ts,
25     enum IsacSamplingRate encoderSampRate,
26     enum IsacSamplingRate decoderSampRate)
27 {
28   WebRtc_Word16  index;
29   WebRtc_Word16  frame_samples;
30   WebRtc_UWord32 sendTimestampIn16kHz;
31   WebRtc_UWord32 arrivalTimestampIn16kHz;
32   WebRtc_UWord32 diffSendTime;
33   WebRtc_UWord32 diffArrivalTime;
34   int err;
35 
36   /* decode framelength and BW estimation */
37   err = WebRtcIsac_DecodeFrameLen(streamdata, &frame_samples);
38   if(err < 0)  // error check
39   {
40     return err;
41   }
42   err = WebRtcIsac_DecodeSendBW(streamdata, &index);
43   if(err < 0)  // error check
44   {
45     return err;
46   }
47 
48   /* UPDATE ESTIMATES FROM OTHER SIDE */
49   err = WebRtcIsac_UpdateUplinkBwImpl(bwest_str, index, encoderSampRate);
50   if(err < 0)
51   {
52     return err;
53   }
54 
55   // We like BWE to work at 16 kHz sampling rate,
56   // therefore, we have to change the timestamps accordingly.
57   // translate the send timestamp if required
58   diffSendTime = (WebRtc_UWord32)((WebRtc_UWord32)send_ts -
59                                   (WebRtc_UWord32)bwest_str->senderTimestamp);
60   bwest_str->senderTimestamp = send_ts;
61 
62   diffArrivalTime = (WebRtc_UWord32)((WebRtc_UWord32)arr_ts -
63                                      (WebRtc_UWord32)bwest_str->receiverTimestamp);
64   bwest_str->receiverTimestamp = arr_ts;
65 
66   if(decoderSampRate == kIsacSuperWideband)
67   {
68     diffArrivalTime = (WebRtc_UWord32)diffArrivalTime >> 1;
69     diffSendTime = (WebRtc_UWord32)diffSendTime >> 1;
70   }
71   // arrival timestamp in 16 kHz
72   arrivalTimestampIn16kHz = (WebRtc_UWord32)((WebRtc_UWord32)
73                                              bwest_str->prev_rec_arr_ts + (WebRtc_UWord32)diffArrivalTime);
74   // send timestamp in 16 kHz
75   sendTimestampIn16kHz = (WebRtc_UWord32)((WebRtc_UWord32)
76                                           bwest_str->prev_rec_send_ts + (WebRtc_UWord32)diffSendTime);
77 
78   err = WebRtcIsac_UpdateBandwidthEstimator(bwest_str, rtp_seq_number,
79                                             (frame_samples * 1000) / FS, sendTimestampIn16kHz,
80                                             arrivalTimestampIn16kHz, packet_size);
81   // error check
82   if(err < 0)
83   {
84     return err;
85   }
86 
87   return 0;
88 }
89