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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tracking.m

?? GNSS_SDR是一套不可多得的matlab代碼。它給出了接收機每一部分的子函數
?? 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 starting 
%                       positions of spreading codes, 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.32 2007/01/30 09:45:12 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)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区欧美二区| 日韩精品一区二区三区在线| 欧美精品一区二区三区一线天视频| 丁香六月久久综合狠狠色| 日韩欧美在线123| 裸体一区二区三区| 日韩欧美在线123| 国产成人精品免费视频网站| 中文字幕巨乱亚洲| 91尤物视频在线观看| 一区二区高清视频在线观看| 欧美丰满美乳xxx高潮www| 蜜桃av噜噜一区| 国产欧美久久久精品影院| www.一区二区| 舔着乳尖日韩一区| 精品福利一区二区三区免费视频| 国产成人综合亚洲网站| 亚洲青青青在线视频| 欧美电影在哪看比较好| 国产一区二区在线观看视频| 美女国产一区二区三区| 中文字幕在线不卡一区二区三区 | 成人黄色a**站在线观看| 亚洲婷婷国产精品电影人久久| 精品1区2区3区| 激情欧美一区二区| 亚洲人123区| 久久综合色天天久久综合图片| k8久久久一区二区三区| 日韩成人免费电影| 日本一区二区动态图| 欧美久久婷婷综合色| 国产精品乡下勾搭老头1| 亚洲一二三区视频在线观看| 久久夜色精品国产欧美乱极品| 日本久久电影网| 国产美女娇喘av呻吟久久| 一区二区三区四区不卡在线 | 国内精品视频666| 精品99一区二区| 亚洲成精国产精品女| 久久久久久97三级| 日本精品视频一区二区| 国产麻豆视频一区| 亚洲va韩国va欧美va| 国产精品美女久久久久aⅴ| 欧美一区二区三区四区久久| 99天天综合性| 国产精品一区二区久久不卡 | 久久国产欧美日韩精品| 亚洲自拍偷拍网站| 中文一区二区完整视频在线观看| 欧美老女人第四色| 一本到三区不卡视频| 国产成人在线影院| 久久国产精品露脸对白| 午夜精品久久久久久久99樱桃| 中文字幕色av一区二区三区| 久久久国产午夜精品| 日韩免费一区二区三区在线播放| 欧美丝袜丝交足nylons| 国产一区二区三区免费在线观看| 一区二区三区国产精华| 亚洲欧洲三级电影| 国产区在线观看成人精品| 日韩精品中文字幕在线一区| 欧美精品免费视频| 欧美在线播放高清精品| 91麻豆视频网站| 99久久精品费精品国产一区二区| 国产成人精品影院| 国产福利91精品一区二区三区| 美国一区二区三区在线播放| 日韩电影一区二区三区四区| 亚洲电影一区二区三区| 亚洲国产精品一区二区www| 亚洲美女视频一区| 一区二区三区在线播放| 亚洲精品视频在线看| 亚洲欧美一区二区三区久本道91| 1000精品久久久久久久久| 国产精品久久精品日日| 1024精品合集| 一级中文字幕一区二区| 亚洲一区视频在线观看视频| 亚洲电影中文字幕在线观看| 午夜激情久久久| 免费在线观看不卡| 国产综合色在线视频区| 成人深夜福利app| 91在线国产福利| 欧美亚洲综合另类| 8v天堂国产在线一区二区| 欧美一级精品大片| 亚洲国产精品久久久久婷婷884| 国产日韩欧美精品在线| 国产视频一区二区在线| 国产精品国产三级国产三级人妇| 精品一区二区三区免费| 国产精品系列在线观看| av在线不卡网| 欧美日韩三级一区二区| 日韩女优电影在线观看| 国产日韩欧美电影| 亚洲男人都懂的| 亚洲h在线观看| 久久精品国产一区二区三| 国产超碰在线一区| 欧美亚洲综合另类| 精品国产电影一区二区| 国产精品久久久久影院亚瑟| 亚洲午夜久久久| 麻豆一区二区99久久久久| 国产在线日韩欧美| 一本到高清视频免费精品| 欧美一区午夜视频在线观看| 国产欧美日韩精品在线| 亚洲一本大道在线| 懂色中文一区二区在线播放| 在线观看亚洲一区| 2023国产精品| 亚洲国产精品一区二区尤物区| 国产一区二区三区日韩| 欧美日韩一区二区三区不卡| 国产三级一区二区| 日韩va亚洲va欧美va久久| 成人18精品视频| 日韩一区二区三区免费看| 最新热久久免费视频| 久久av中文字幕片| 欧洲精品一区二区| 中文字幕av一区二区三区| 日韩国产欧美三级| 色综合久久六月婷婷中文字幕| 精品国产91洋老外米糕| 亚洲一区二区三区国产| 成人动漫精品一区二区| 欧美v亚洲v综合ⅴ国产v| 亚洲国产精品欧美一二99| 懂色av一区二区三区蜜臀 | 亚洲成在人线在线播放| 成人午夜碰碰视频| 精品久久国产老人久久综合| 亚洲一级不卡视频| 91在线视频免费91| wwwwww.欧美系列| 免费国产亚洲视频| 欧美日韩国产免费一区二区| 亚洲精品国产品国语在线app| 国产精品系列在线观看| 欧美成人欧美edvon| 日韩精品国产欧美| 欧美色倩网站大全免费| 亚洲私人黄色宅男| 成人午夜免费视频| 久久精品一区二区三区av| 久久精品国产久精国产| 在线电影院国产精品| 亚洲成人精品影院| 欧美性受极品xxxx喷水| 亚洲欧美日韩国产中文在线| av中文字幕不卡| 日韩一区日韩二区| 99在线精品免费| 成人免费在线视频观看| 97se亚洲国产综合在线| 日韩毛片精品高清免费| 99精品欧美一区| 亚洲视频免费看| 色综合久久综合| 亚洲资源中文字幕| 色婷婷综合久久| 亚洲综合区在线| 欧美视频在线一区二区三区| 亚洲一区二区av在线| 欧美午夜精品一区二区三区 | 欧美日韩国产三级| 香蕉久久一区二区不卡无毒影院| 欧美日韩电影在线播放| 三级久久三级久久| 日韩欧美成人激情| 国产精品69毛片高清亚洲| 中文一区在线播放| 色婷婷综合久久久中文字幕| 亚洲动漫第一页| 日韩欧美亚洲国产精品字幕久久久 | 亚洲人成精品久久久久| 在线观看国产精品网站| 日韩黄色一级片| 精品国产不卡一区二区三区| 国产精品亚洲人在线观看| 亚洲国产激情av| 色噜噜夜夜夜综合网| 日本欧洲一区二区| 久久久久久久网| 色哟哟国产精品| 美女网站色91| 国产精品久久久久天堂| 在线观看日韩电影|