亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? tracking.m

?? software for book "A Software-Defined GPS and Galileo Receiver" free software
?? M
字號:
function [trackResults, channel]= tracking(fid, channel, settings)
% Performs code and carrier tracking for all channels.
%
%[trackResults, channel] = tracking(fid, channel, settings)
%
%   Inputs:
%       fid             - file identifier of the signal record.
%       channel         - PRN, carrier frequencies and code phases of all
%                       satellites to be tracked (prepared by preRum.m from
%                       acquisition results).
%       settings        - receiver settings.
%   Outputs:
%       trackResults    - tracking results (structure array). Contains
%                       in-phase prompt outputs and absolute spreading
%                       code's starting positions, together with other
%                       observation data from the tracking loops. All are
%                       saved every millisecond.

%--------------------------------------------------------------------------
%                           SoftGNSS v3.0
% 
% Copyright (C) Dennis M. Akos
% Written by Darius Plausinaitis and Dennis M. Akos
% Based on code by DMAkos Oct-1999
%--------------------------------------------------------------------------
%This program is free software; you can redistribute it and/or
%modify it under the terms of the GNU General Public License
%as published by the Free Software Foundation; either version 2
%of the License, or (at your option) any later version.
%
%This program is distributed in the hope that it will be useful,
%but WITHOUT ANY WARRANTY; without even the implied warranty of
%MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
%GNU General Public License for more details.
%
%You should have received a copy of the GNU General Public License
%along with this program; if not, write to the Free Software
%Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301,
%USA.
%--------------------------------------------------------------------------

%CVS record:
%$Id: tracking.m,v 1.14.2.31 2006/08/14 11:38:22 dpl Exp $

%% Initialize result structure ============================================

% Channel status
trackResults.status         = '-';      % No tracked signal, or lost lock

% The absolute sample in the record of the C/A code start:
trackResults.absoluteSample = zeros(1, settings.msToProcess);

% Freq of the C/A code:
trackResults.codeFreq       = inf(1, settings.msToProcess);

% Frequency of the tracked carrier wave:
trackResults.carrFreq       = inf(1, settings.msToProcess);

% Outputs from the correlators (In-phase):
trackResults.I_P            = zeros(1, settings.msToProcess);
trackResults.I_E            = zeros(1, settings.msToProcess);
trackResults.I_L            = zeros(1, settings.msToProcess);

% Outputs from the correlators (Quadrature-phase):
trackResults.Q_E            = zeros(1, settings.msToProcess);
trackResults.Q_P            = zeros(1, settings.msToProcess);
trackResults.Q_L            = zeros(1, settings.msToProcess);

% Loop discriminators
trackResults.dllDiscr       = inf(1, settings.msToProcess);
trackResults.dllDiscrFilt   = inf(1, settings.msToProcess);
trackResults.pllDiscr       = inf(1, settings.msToProcess);
trackResults.pllDiscrFilt   = inf(1, settings.msToProcess);

%--- Copy initial settings for all channels -------------------------------
trackResults = repmat(trackResults, 1, settings.numberOfChannels);

%% Initialize tracking variables ==========================================

codePeriods = settings.msToProcess;     % For GPS one C/A code is one ms

%--- DLL variables --------------------------------------------------------
% Define early-late offset (in chips)
earlyLateSpc = settings.dllCorrelatorSpacing;

% Summation interval
PDIcode = 0.001;

% Calculate filter coefficient values
[tau1code, tau2code] = calcLoopCoef(settings.dllNoiseBandwidth, ...
                                    settings.dllDampingRatio, ...
                                    1.0);

%--- PLL variables --------------------------------------------------------
% Summation interval
PDIcarr = 0.001;

% Calculate filter coefficient values
[tau1carr, tau2carr] = calcLoopCoef(settings.pllNoiseBandwidth, ...
                                    settings.pllDampingRatio, ...
                                    0.25);
hwb = waitbar(0,'Tracking...');

%% Start processing channels ==============================================
for channelNr = 1:settings.numberOfChannels
    
    % Only process if PRN is non zero (acquisition was successful)
    if (channel(channelNr).PRN ~= 0)
        % Save additional information - each channel's tracked PRN
        trackResults(channelNr).PRN     = channel(channelNr).PRN;
        
        % Move the starting point of processing. Can be used to start the
        % signal processing at any point in the data record (e.g. for long
        % records). In addition skip through that data file to start at the
        % appropriate sample (corresponding to code phase). Assumes sample
        % type is schar (or 1 byte per sample) 
        fseek(fid, ...
              settings.skipNumberOfBytes + channel(channelNr).codePhase-1, ...
              'bof');


        % Get a vector with the C/A code sampled 1x/chip
        caCode = generateCAcode(channel(channelNr).PRN);
        % Then make it possible to do early and late versions
        caCode = [caCode(1023) caCode caCode(1)];

        %--- Perform various initializations ------------------------------

        % define initial code frequency basis of NCO
        codeFreq      = settings.codeFreqBasis;
        % define residual code phase (in chips)
        remCodePhase  = 0.0;
        % define carrier frequency which is used over whole tracking period
        carrFreq      = channel(channelNr).acquiredFreq;
        carrFreqBasis = channel(channelNr).acquiredFreq;
        % define residual carrier phase
        remCarrPhase  = 0.0;

        %code tracking loop parameters
        oldCodeNco   = 0.0;
        oldCodeError = 0.0;

        %carrier/Costas loop parameters
        oldCarrNco   = 0.0;
        oldCarrError = 0.0;

        %=== Process the number of specified code periods =================
        for loopCnt =  1:codePeriods
            
%% GUI update -------------------------------------------------------------
            % The GUI is updated every 50ms. This way Matlab GUI is still
            % responsive enough. At the same time Matlab is not occupied
            % all the time with GUI task.
            if (rem(loopCnt, 50) == 0)
                try
                    waitbar(loopCnt/codePeriods, ...
                            hwb, ...
                            ['Tracking: Ch ', int2str(channelNr), ...
                            ' of ', int2str(settings.numberOfChannels), ...
                            '; PRN#', int2str(channel(channelNr).PRN), ...
                            '; Completed ',int2str(loopCnt), ...
                            ' of ', int2str(codePeriods), ' msec']);                       
                catch
                    % The progress bar was closed. It is used as a signal
                    % to stop, "cancel" processing. Exit.
                    disp('Progress bar closed, exiting...');
                    return
                end
            end

%% Read next block of data ------------------------------------------------            
            % Find the size of a "block" or code period in whole samples
            
            % Update the phasestep based on code freq (variable) and
            % sampling frequency (fixed)
            codePhaseStep = codeFreq / settings.samplingFreq;
            
            blksize = ceil((settings.codeLength-remCodePhase) / codePhaseStep);
            
            % Read in the appropriate number of samples to process this
            % interation 
            [rawSignal, samplesRead] = fread(fid, ...
                                             blksize, settings.dataType);
            rawSignal = rawSignal';  %transpose vector
            
            % If did not read in enough samples, then could be out of 
            % data - better exit 
            if (samplesRead ~= blksize)
                disp('Not able to read the specified number of samples  for tracking, exiting!')
                fclose(fid);
                return
            end

%% Set up all the code phase tracking information -------------------------
            % Define index into early code vector
            tcode       = (remCodePhase-earlyLateSpc) : ...
                          codePhaseStep : ...
                          ((blksize-1)*codePhaseStep+remCodePhase-earlyLateSpc);
            tcode2      = ceil(tcode) + 1;
            earlyCode   = caCode(tcode2);
            
            % Define index into late code vector
            tcode       = (remCodePhase+earlyLateSpc) : ...
                          codePhaseStep : ...
                          ((blksize-1)*codePhaseStep+remCodePhase+earlyLateSpc);
            tcode2      = ceil(tcode) + 1;
            lateCode    = caCode(tcode2);
            
            % Define index into prompt code vector
            tcode       = remCodePhase : ...
                          codePhaseStep : ...
                          ((blksize-1)*codePhaseStep+remCodePhase);
            tcode2      = ceil(tcode) + 1;
            promptCode  = caCode(tcode2);
            
            remCodePhase = (tcode(blksize) + codePhaseStep) - 1023.0;

%% Generate the carrier frequency to mix the signal to baseband -----------
            time    = (0:blksize) ./ settings.samplingFreq;
            
            % Get the argument to sin/cos functions
            trigarg = ((carrFreq * 2.0 * pi) .* time) + remCarrPhase;
            remCarrPhase = rem(trigarg(blksize+1), (2 * pi));
            
            % Finally compute the signal to mix the collected data to bandband
            carrCos = cos(trigarg(1:blksize));
            carrSin = sin(trigarg(1:blksize));

%% Generate the six standard accumulated values ---------------------------
            % First mix to baseband
            qBasebandSignal = carrCos .* rawSignal;
            iBasebandSignal = carrSin .* rawSignal;

            % Now get early, late, and prompt values for each
            I_E = sum(earlyCode  .* iBasebandSignal);
            Q_E = sum(earlyCode  .* qBasebandSignal);
            I_P = sum(promptCode .* iBasebandSignal);
            Q_P = sum(promptCode .* qBasebandSignal);
            I_L = sum(lateCode   .* iBasebandSignal);
            Q_L = sum(lateCode   .* qBasebandSignal);
            
%% Find PLL error and update carrier NCO ----------------------------------

            % Implement carrier loop discriminator (phase detector)
            carrError = atan(Q_P / I_P) / (2.0 * pi);
            
            % Implement carrier loop filter and generate NCO command
            carrNco = oldCarrNco + (tau2carr/tau1carr) * ...
                (carrError - oldCarrError) + carrError * (PDIcarr/tau1carr);
            oldCarrNco   = carrNco;
            oldCarrError = carrError;

            % Modify carrier freq based on NCO command
            carrFreq = carrFreqBasis + carrNco;

            trackResults(channelNr).carrFreq(loopCnt) = carrFreq;

%% Find DLL error and update code NCO -------------------------------------
            codeError = (sqrt(I_E * I_E + Q_E * Q_E) - sqrt(I_L * I_L + Q_L * Q_L)) / ...
                (sqrt(I_E * I_E + Q_E * Q_E) + sqrt(I_L * I_L + Q_L * Q_L));
            
            % Implement code loop filter and generate NCO command
            codeNco = oldCodeNco + (tau2code/tau1code) * ...
                (codeError - oldCodeError) + codeError * (PDIcode/tau1code);
            oldCodeNco   = codeNco;
            oldCodeError = codeError;
            
            % Modify code freq based on NCO command
            codeFreq = settings.codeFreqBasis - codeNco;
            
            trackResults(channelNr).codeFreq(loopCnt) = codeFreq;

%% Record various measures to show in postprocessing ----------------------
            % Record sample number (based on 8bit samples)
            trackResults(channelNr).absoluteSample(loopCnt) = ftell(fid);

            trackResults(channelNr).dllDiscr(loopCnt)       = codeError;
            trackResults(channelNr).dllDiscrFilt(loopCnt)   = codeNco;
            trackResults(channelNr).pllDiscr(loopCnt)       = carrError;
            trackResults(channelNr).pllDiscrFilt(loopCnt)   = carrNco;

            trackResults(channelNr).I_E(loopCnt) = I_E;
            trackResults(channelNr).I_P(loopCnt) = I_P;
            trackResults(channelNr).I_L(loopCnt) = I_L;
            trackResults(channelNr).Q_E(loopCnt) = Q_E;
            trackResults(channelNr).Q_P(loopCnt) = Q_P;
            trackResults(channelNr).Q_L(loopCnt) = Q_L;
        end % for loopCnt

        % If we got so far, this means that the tracking was successful
        % Now we only copy status, but it can be update by a lock detector
        % if implemented
        trackResults(channelNr).status  = channel(channelNr).status;        
        
    end % if a PRN is assigned
end % for channelNr 

% Close the waitbar
close(hwb)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美激情一区二区在线| 91污在线观看| 日韩一区二区不卡| 日本不卡一二三区黄网| 日韩无一区二区| 国产精品一级在线| 中文字幕一区二区在线观看| 成人美女在线观看| 亚洲另类在线视频| 精品污污网站免费看| 日韩va亚洲va欧美va久久| 制服.丝袜.亚洲.中文.综合| 国产一区二区在线观看视频| 久久国产精品第一页| 精品乱人伦一区二区三区| 成人精品视频一区二区三区| 亚洲免费在线播放| 欧美一区二区播放| 国产·精品毛片| 亚洲高清在线精品| 久久色在线观看| 色哟哟精品一区| 久久成人精品无人区| 亚洲婷婷国产精品电影人久久| 精品1区2区3区| 国产成人在线观看| 亚洲一级在线观看| 久久色.com| 在线精品视频免费观看| 久久99精品久久久久久动态图 | 一区免费观看视频| 欧美性xxxxxxxx| 国产伦精品一区二区三区在线观看| 1000部国产精品成人观看| 欧美一区2区视频在线观看| 成人a免费在线看| 奇米888四色在线精品| 亚洲欧洲av在线| 精品国产乱码久久久久久免费 | 久草精品在线观看| 亚洲免费电影在线| 久久精子c满五个校花| 国产精品久久久久精k8| 欧美一级久久久久久久大片| 91麻豆福利精品推荐| 激情伊人五月天久久综合| 亚洲图片欧美色图| 国产精品久久一卡二卡| 精品久久久久一区| 欧美日韩国产天堂| 91网站视频在线观看| 国产麻豆精品视频| 青青草成人在线观看| 亚洲第一狼人社区| 国产精品麻豆一区二区| 久久综合资源网| 制服丝袜亚洲精品中文字幕| 日本道免费精品一区二区三区| 东方欧美亚洲色图在线| 激情综合网最新| 欧美bbbbb| 天堂一区二区在线免费观看| 一区二区在线观看免费 | 欧美日韩国产首页在线观看| 91小视频在线观看| av色综合久久天堂av综合| 国产成人啪免费观看软件| 狠狠色狠狠色合久久伊人| 天天综合色天天| 亚洲二区在线视频| 亚洲成人av一区二区| 一区二区三区毛片| 亚洲麻豆国产自偷在线| 亚洲视频免费观看| 亚洲精品亚洲人成人网| 中文字幕一区二| 亚洲天堂网中文字| 亚洲精品成人悠悠色影视| 一区二区三区不卡视频| 夜夜嗨av一区二区三区四季av | 久久嫩草精品久久久久| 精品毛片乱码1区2区3区| 久久久久88色偷偷免费| 国产亚洲欧美中文| 国产精品国产三级国产aⅴ入口 | 一区二区三区四区视频精品免费| 中文字幕一区二区三区乱码在线| 亚洲欧洲一区二区在线播放| 亚洲特级片在线| 亚洲国产欧美一区二区三区丁香婷| 亚洲一卡二卡三卡四卡| 首页亚洲欧美制服丝腿| 久久超碰97中文字幕| 国产成人激情av| 91女厕偷拍女厕偷拍高清| 欧美激情一区二区三区四区| 国产精品国产馆在线真实露脸| 亚洲精品免费看| 日韩高清不卡一区| 国产又粗又猛又爽又黄91精品| 国产大片一区二区| 色婷婷久久久综合中文字幕| 欧美三区在线观看| 精品国产乱子伦一区| 中文字幕av资源一区| 一区二区三区在线看| 日韩电影在线免费观看| 国产乱子轮精品视频| 一本到一区二区三区| 欧美一区二区三区不卡| 欧美国产日韩一二三区| 亚洲五月六月丁香激情| 韩国成人精品a∨在线观看| bt7086福利一区国产| 欧美精品一级二级| 中文字幕av资源一区| 调教+趴+乳夹+国产+精品| 国产高清精品网站| 欧美日韩中文一区| 国产亚洲精品福利| 亚洲超碰97人人做人人爱| 国产伦精品一区二区三区免费| 欧美偷拍一区二区| 国产清纯在线一区二区www| 亚洲福利一二三区| 成人综合婷婷国产精品久久免费| 欧美日韩视频在线观看一区二区三区 | 欧美性xxxxxxxx| 国产无一区二区| 日韩精品色哟哟| 91麻豆成人久久精品二区三区| 精品国产乱码久久久久久闺蜜| 一区二区三区欧美| 成人在线综合网站| 欧美成人精品福利| 亚洲综合图片区| 99久久99久久精品免费看蜜桃| 日韩免费看的电影| 亚洲一区二区精品视频| 99这里都是精品| 国产欧美一区视频| 九九**精品视频免费播放| 欧美日韩亚洲综合在线| 亚洲欧美视频一区| 成人av集中营| 久久网这里都是精品| 麻豆国产精品视频| 欧美电影在线免费观看| 亚洲午夜久久久久中文字幕久| 波波电影院一区二区三区| 久久久不卡网国产精品二区| 美国一区二区三区在线播放| 欧美高清激情brazzers| 亚洲一区电影777| 欧洲一区二区三区在线| 亚洲男人都懂的| 不卡一区在线观看| 国产精品久久久久久久久晋中| 国产精品一区不卡| 日本一区二区三区四区| 国产福利电影一区二区三区| 精品国产一区久久| 国内精品久久久久影院色| 欧美大度的电影原声| 麻豆精品新av中文字幕| 欧美大片顶级少妇| 狠狠色丁香婷婷综合久久片| 2023国产精华国产精品| 国产在线国偷精品免费看| 欧美精品一区二| 国产一区二区不卡老阿姨| 久久久亚洲欧洲日产国码αv| 国产精品一区在线观看乱码| 久久久久久黄色| 成人在线视频首页| 综合欧美亚洲日本| 在线免费精品视频| 亚洲国产视频网站| 91麻豆精品国产自产在线| 日韩av一区二区在线影视| 欧美一区二区福利视频| 国产做a爰片久久毛片| 欧美国产综合一区二区| 色综合一区二区| 亚洲国产日韩av| 日韩一区和二区| 国产精品一二三在| 亚洲日本在线天堂| 欧美猛男男办公室激情| 激情六月婷婷久久| 国产精品毛片a∨一区二区三区| 色综合久久久久综合体| 三级精品在线观看| 国产亚洲欧洲一区高清在线观看| 成人免费福利片| 性做久久久久久久免费看| 亚洲精品一区在线观看| 91玉足脚交白嫩脚丫在线播放| 性做久久久久久久免费看| 久久久久久麻豆|