mirror of https://github.com/pvnis/srsRAN_4G.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
1.5 KiB
C
57 lines
1.5 KiB
C
11 years ago
|
/**
|
||
11 years ago
|
*
|
||
11 years ago
|
* \section COPYRIGHT
|
||
11 years ago
|
*
|
||
9 years ago
|
* Copyright 2013-2015 Software Radio Systems Limited
|
||
11 years ago
|
*
|
||
|
* \section LICENSE
|
||
|
*
|
||
10 years ago
|
* This file is part of the srsLTE library.
|
||
11 years ago
|
*
|
||
10 years ago
|
* srsLTE is free software: you can redistribute it and/or modify
|
||
10 years ago
|
* it under the terms of the GNU Affero General Public License as
|
||
11 years ago
|
* published by the Free Software Foundation, either version 3 of
|
||
|
* the License, or (at your option) any later version.
|
||
|
*
|
||
10 years ago
|
* srsLTE is distributed in the hope that it will be useful,
|
||
11 years ago
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
10 years ago
|
* GNU Affero General Public License for more details.
|
||
11 years ago
|
*
|
||
10 years ago
|
* A copy of the GNU Affero General Public License can be found in
|
||
11 years ago
|
* the LICENSE file in the top-level directory of this distribution
|
||
|
* and at http://www.gnu.org/licenses/.
|
||
|
*
|
||
11 years ago
|
*/
|
||
|
|
||
11 years ago
|
|
||
11 years ago
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
10 years ago
|
#include "srslte/sync/sfo.h"
|
||
11 years ago
|
|
||
|
/* Estimate SFO based on the array of time estimates t0
|
||
|
* of length len. The parameter period is the time between t0 samples
|
||
|
*/
|
||
10 years ago
|
float srslte_sfo_estimate(int *t0, int len, float period) {
|
||
11 years ago
|
int i;
|
||
|
float sfo=0.0;
|
||
|
for (i=1;i<len;i++) {
|
||
|
sfo += (t0[i]-t0[i-1])/period/len;
|
||
|
}
|
||
|
return sfo;
|
||
11 years ago
|
}
|
||
11 years ago
|
|
||
10 years ago
|
/* Same as srslte_sfo_estimate but period is non-uniform.
|
||
11 years ago
|
* Vector t is the sampling time times period for each t0
|
||
|
*/
|
||
10 years ago
|
float srslte_sfo_estimate_period(int *t0, int *t, int len, float period) {
|
||
11 years ago
|
int i;
|
||
|
float sfo=0.0;
|
||
|
for (i=1;i<len;i++) {
|
||
|
if (abs(t0[i]-t0[i-1]) < 5000) {
|
||
|
sfo += (t0[i]-t0[i-1])/(t[i] - t[i-1])/period;
|
||
|
}
|
||
|
}
|
||
|
return sfo/(len-2);
|
||
11 years ago
|
}
|