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

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

?? tracking.m

?? This toolbox is used to develop software defined radio for GPS receiver
?? 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)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲一区二区在线观看| 制服.丝袜.亚洲.中文.综合| 蜜桃传媒麻豆第一区在线观看| 一区二区日韩电影| 亚洲欧美综合网| 亚洲自拍偷拍图区| 亚洲一区二区欧美| 亚洲成av人片一区二区| 亚洲一区二区三区视频在线播放 | 久久蜜桃av一区二区天堂| 日韩欧美中文字幕精品| 精品国产一区二区精华| 久久久国产一区二区三区四区小说| 精品国产欧美一区二区| 国产三级久久久| 成人免费在线观看入口| 亚洲第一成人在线| 精品一区二区在线播放| 成人动漫视频在线| 99re视频精品| 欧美日本在线视频| 精品国免费一区二区三区| 国产日韩欧美a| 亚洲色图欧美偷拍| 天天综合日日夜夜精品| 国产精品一区二区在线观看不卡| 成人av一区二区三区| 欧美日韩一区久久| 久久久国产午夜精品 | 日韩高清国产一区在线| 91免费版pro下载短视频| 国产午夜精品一区二区三区四区| 亚洲精品国久久99热| 国产91精品精华液一区二区三区 | 亚洲卡通动漫在线| 国产综合色产在线精品| 成人黄色网址在线观看| 91国模大尺度私拍在线视频| 欧美精品第一页| 久久精品男人的天堂| 亚洲国产精品欧美一二99| 国产一区在线视频| 色嗨嗨av一区二区三区| 久久这里只精品最新地址| 亚洲精品福利视频网站| 蜜桃视频第一区免费观看| 色哟哟日韩精品| 久久精品一区二区三区不卡牛牛 | 欧美成人性福生活免费看| 国产精品久久99| 久久精品国产成人一区二区三区| 日本高清不卡aⅴ免费网站| 日韩一区二区三区观看| 一区二区三区在线观看动漫| 久久99九九99精品| 欧美美女bb生活片| 亚洲综合在线免费观看| 成年人午夜久久久| 国产校园另类小说区| 免费看日韩a级影片| 欧美调教femdomvk| 亚洲欧美电影一区二区| 成人精品视频一区二区三区尤物| 精品国产精品网麻豆系列| 香蕉av福利精品导航| 亚洲美女屁股眼交| 精品成人佐山爱一区二区| 亚洲最新视频在线观看| 成人a区在线观看| 久久夜色精品国产噜噜av| 毛片不卡一区二区| 欧美一级高清片| 蜜臀久久久99精品久久久久久| 欧美三级三级三级爽爽爽| 亚洲亚洲人成综合网络| 99麻豆久久久国产精品免费优播| 国产欧美日本一区视频| 国产98色在线|日韩| 国产精品久久久久桃色tv| 高清在线成人网| 亚洲欧洲精品一区二区精品久久久| 大白屁股一区二区视频| 中文字幕日韩av资源站| 色婷婷久久综合| 亚洲自拍偷拍麻豆| 91精品国产综合久久蜜臀| 美女国产一区二区三区| 欧美喷潮久久久xxxxx| 美女看a上一区| 欧美成人aa大片| 韩国成人在线视频| 国产精品视频一二三| 91丨九色丨国产丨porny| 一卡二卡三卡日韩欧美| 欧美美女网站色| 国产一区二区三区免费看| 欧美国产日本视频| 欧美在线免费视屏| 蜜臀av国产精品久久久久| 欧美国产成人在线| 在线观看一区二区视频| 久久国产免费看| 中文字幕制服丝袜成人av| 欧美三级电影一区| 精品一区二区三区视频| 亚洲欧洲成人av每日更新| 911精品国产一区二区在线| 国产麻豆精品95视频| 一区二区三区四区不卡在线| 日韩欧美的一区二区| 99国产精品久久久久久久久久| 首页欧美精品中文字幕| 中文字幕欧美国产| 日韩一区二区三区视频在线| 成人免费毛片app| 偷拍自拍另类欧美| 国产精品人妖ts系列视频| 欧美亚洲一区二区在线观看| 国产乱码字幕精品高清av | 蜜桃视频在线观看一区| 亚洲视频综合在线| 久久影院视频免费| 国产91丝袜在线观看| 色综合视频一区二区三区高清| 精品久久久久久久久久久院品网 | 91精品在线免费| 国产一区视频在线看| 日本精品视频一区二区三区| 国产色爱av资源综合区| 久久99久久久欧美国产| 亚洲欧洲色图综合| 国产毛片精品视频| 中文乱码免费一区二区| 一道本成人在线| 一区二区三区国产精品| 欧美另类久久久品| 日韩国产欧美在线播放| 国产欧美日韩卡一| 国产乱淫av一区二区三区| 亚洲嫩草精品久久| 日韩欧美国产综合在线一区二区三区| 亚洲成人1区2区| 94色蜜桃网一区二区三区| 亚洲一区视频在线| 综合分类小说区另类春色亚洲小说欧美 | 欧美日韩国产影片| 蜜桃视频在线一区| 国产欧美一区二区在线观看| 欧美猛男超大videosgay| 亚洲欧美一区二区三区国产精品| 日韩精品视频网站| 国产色综合一区| 欧美videos大乳护士334| 欧美亚洲国产怡红院影院| 国产精品麻豆视频| 99视频有精品| 亚洲一区影音先锋| 日韩精品一区二区在线观看| 欧美日韩电影在线播放| 欧美肥妇bbw| 精品国产一区二区三区不卡| 国产婷婷色一区二区三区四区| 久久先锋影音av| 国产人妖乱国产精品人妖| 国产视频一区在线观看 | 天天影视色香欲综合网老头| 午夜精品影院在线观看| 蜜臀91精品一区二区三区| 国产精品一线二线三线精华| 99re热视频精品| 青青草国产精品亚洲专区无| 蜜桃av一区二区| 国产成人亚洲综合色影视| 亚洲国产精品二十页| 欧美成人猛片aaaaaaa| 欧美一a一片一级一片| 国产成人免费在线| 国产成a人亚洲| 91日韩在线专区| 欧美裸体一区二区三区| 国产亚洲欧美一级| 亚洲三级电影网站| 无码av免费一区二区三区试看| 极品美女销魂一区二区三区免费| 久久99久久99小草精品免视看| 国产在线一区观看| 午夜国产精品影院在线观看| 337p亚洲精品色噜噜| 久久久久久久久岛国免费| 国产精品免费aⅴ片在线观看| 九色综合狠狠综合久久| 99国产精品久久久久久久久久久| 久久嫩草精品久久久精品一| 成人av在线电影| 欧美精品第1页| 7799精品视频| 亚洲人成亚洲人成在线观看图片| 亚洲一区在线免费观看| 国产成人av一区| 一区二区三区不卡视频 |