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

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

?? tracking.m

?? this is a algoritham about using GPS receicers
?? 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...');

if (settings.fileType==1)
    dataAdaptCoeff=1;
else
    dataAdaptCoeff=2;
end

%% 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, ...
            dataAdaptCoeff*(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, ...
                dataAdaptCoeff*blksize, settings.dataType);
 
            rawSignal = rawSignal';

            if (dataAdaptCoeff==2)
                rawSignal1=rawSignal(1:2:end);
                rawSignal2=rawSignal(2:2:end);
                rawSignal = rawSignal1 + i .* rawSignal2;  %transpose vector
            end
            
            
            % If did not read in enough samples, then could be out of 
            % data - better exit 
            if (samplesRead ~= dataAdaptCoeff*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
            carrsig = exp(i .* trigarg(1:blksize));

%% Generate the six standard accumulated values ---------------------------
            % First mix to baseband
            qBasebandSignal = real(carrsig .* rawSignal);
            iBasebandSignal = imag(carrsig .* 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))/dataAdaptCoeff;

            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一区二区三区免费野_久草精品视频
日韩一区二区视频在线观看| 在线观看视频一区二区欧美日韩| 欧美日韩一级大片网址| 亚洲一级二级在线| 欧美日韩久久久| 极品销魂美女一区二区三区| 国产欧美一区视频| 91麻豆国产福利在线观看| 亚洲成人免费观看| 26uuu亚洲| 99热这里都是精品| 亚洲国产成人高清精品| 精品久久久久久无| 91亚洲精品一区二区乱码| 不卡一二三区首页| 美腿丝袜亚洲综合| 国产精品久久久久久久第一福利 | 国产农村妇女精品| 亚洲人成在线播放网站岛国| 欧美亚洲一区二区三区四区| 国产精品一品二品| 午夜在线成人av| 另类的小说在线视频另类成人小视频在线| 中文字幕免费观看一区| 777奇米四色成人影色区| 99精品欧美一区| 国产精一区二区三区| 成人免费视频视频| 国产精品一区二区在线观看网站| 成人av影视在线观看| 欧美亚洲日本一区| 久久蜜桃一区二区| 日韩欧美黄色影院| 在线视频一区二区三| 日韩欧美国产综合在线一区二区三区 | 亚洲在线视频网站| 奇米四色…亚洲| 日本不卡一二三| 成人中文字幕在线| 欧美电影在线免费观看| 欧美日韩性生活| 国产欧美精品一区二区色综合朱莉 | 成人精品视频网站| 欧美午夜在线一二页| 久久久亚洲午夜电影| 亚洲一区二区三区中文字幕在线| 狠狠色丁香久久婷婷综| 精品写真视频在线观看| 色噜噜夜夜夜综合网| 91蜜桃婷婷狠狠久久综合9色| 欧美一区二区三区免费视频| 欧美一区二区三区性视频| 中文字幕av不卡| 中文字幕一区av| 亚洲综合久久av| 美女视频黄久久| 91久久精品国产91性色tv| 国产亚洲精品bt天堂精选| 国产午夜精品一区二区三区嫩草 | 国产suv一区二区三区88区| 国产成人在线观看免费网站| 国产91精品久久久久久久网曝门| 欧美视频一区在线观看| 国产精品灌醉下药二区| 国内精品久久久久影院色| 色哟哟一区二区在线观看| 欧美私人免费视频| 国产精品久久久久久亚洲毛片| 精品亚洲成a人在线观看| 欧美日韩免费一区二区三区视频| 中文字幕欧美激情| 岛国精品一区二区| 久久久国际精品| 国产一区二区视频在线| av电影天堂一区二区在线观看| 久久精品在线观看| 国产精品亚洲一区二区三区在线| 精品免费视频一区二区| 久久er99热精品一区二区| 欧美一区二区播放| 麻豆freexxxx性91精品| 欧美精品一级二级三级| 视频一区在线播放| 成人一级片在线观看| 欧美国产成人精品| thepron国产精品| 樱桃国产成人精品视频| 精品一区二区三区av| 精品1区2区在线观看| 亚洲影院理伦片| 欧美无砖砖区免费| 蜜臀久久99精品久久久久久9| 欧美电影精品一区二区| 国产麻豆精品一区二区| 欧美激情一区不卡| 欧美在线小视频| 日本免费在线视频不卡一不卡二| 成人av一区二区三区| 亚洲人成精品久久久久| 欧美亚洲动漫精品| 狠狠色丁香婷婷综合久久片| 欧美激情一区二区| 欧美性猛交xxxx乱大交退制版| 五月天激情小说综合| 91极品视觉盛宴| 日韩高清在线不卡| 一区二区三区小说| 黑人巨大精品欧美黑白配亚洲| 国产欧美日韩三区| 色综合天天综合| 欧美国产一区二区| 在线观看亚洲一区| 国产盗摄视频一区二区三区| 中文字幕综合网| 99视频一区二区三区| 五月天欧美精品| 国产蜜臀97一区二区三区| 欧美日韩亚洲高清一区二区| 国产原创一区二区| 亚洲成人综合网站| 亚洲国产精品av| 911精品国产一区二区在线| 成人免费精品视频| 老色鬼精品视频在线观看播放| 日韩理论片中文av| 欧美精品一区在线观看| 欧美日韩成人综合在线一区二区| 国产成人激情av| 天天综合色天天| 亚洲欧美偷拍卡通变态| 26uuu色噜噜精品一区| 欧美日韩成人在线| 一本一道久久a久久精品 | 精品久久久久久久一区二区蜜臀| 91小视频免费观看| 国产成人精品影视| 免费成人av在线播放| 亚洲成av人片在线| 亚洲区小说区图片区qvod| 久久久国际精品| 欧美变态tickling挠脚心| 欧美日韩国产美| 在线精品国精品国产尤物884a| 国产麻豆精品在线观看| 麻豆高清免费国产一区| 日韩精彩视频在线观看| 一区二区三区四区在线| 亚洲三级理论片| 中文字幕欧美日韩一区| 国产日韩精品一区二区浪潮av| 日韩一区二区三区三四区视频在线观看| 色综合久久综合| 一本大道综合伊人精品热热| 成人av网站大全| 99久免费精品视频在线观看 | 国产精品美女视频| 一本一道久久a久久精品| 成人小视频在线观看| 国产mv日韩mv欧美| 成人一区二区在线观看| 成人深夜视频在线观看| 成人午夜视频在线| 成人av在线播放网站| 99精品久久只有精品| 97精品久久久久中文字幕| 91影院在线观看| 色婷婷av一区二区三区软件 | 日韩一级大片在线观看| 精品国产在天天线2019| 国产亚洲成av人在线观看导航 | 成人精品免费看| www.一区二区| 91免费视频网| 欧美日韩一本到| 欧美成人a∨高清免费观看| 精品日韩欧美在线| 国产精品国产三级国产普通话99 | 国产精品99久久久久久久vr | jvid福利写真一区二区三区| 99精品视频一区| 欧美色精品天天在线观看视频| 欧美精品aⅴ在线视频| 精品av久久707| 亚洲视频香蕉人妖| 免费av网站大全久久| 丁香五精品蜜臀久久久久99网站| 91丨九色丨国产丨porny| 欧美一区二区三区免费观看视频| 精品国产一区二区三区久久久蜜月| 久久精品一二三| 一区二区三区成人在线视频 | 精品美女一区二区| 国产精品久久久久毛片软件| 亚洲电影一区二区| 国产成人在线观看免费网站| 色综合 综合色| 精品福利av导航| 亚洲一区二区在线播放相泽 | 久久久精品蜜桃| 一区二区三区久久久|