Difference between revisions of "COPSkcloop"

From Pnb
Jump to navigation Jump to search
(Created page with "<pre> function COPSbscalcloop(infile) %loop for calling bscalc %Erik Stassinos %modified for C-OPScast 6-20-2013 scale = [1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,...")
 
 
Line 1: Line 1:
 
<pre>
 
<pre>
function COPSbscalcloop(infile)
+
function COPSkcloop(infile)
%loop for calling bscalc
 
%Erik Stassinos
 
 
 
 
 
%modified for C-OPScast 6-20-2013
 
 
 
 
 
 
 
scale = [1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1]; %will be changed to be read from a file.
 
%interval = [10,10,10,12,12,12,12,12,12,12,12,12,10,10,10,10,10,10,10,10,10,12,12,12,12,12,12,12,12,12,10,10,10,10,10,10];
 
interval = [5,5,5,5,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,2,2,2,2,2,2];
 
 
 
%%%% old
 
% -r EdZ320 1 10
 
% -r EdZ340 1 10
 
% -r EdZ380 1 10
 
% -r EdZ395 1 12
 
% -r EdZ412 1 12
 
% -r Edz443 1 12
 
% -r Edz465 1 12
 
% -r EdZ490 1 12
 
% -r EdZ510 1 12
 
% -r EdZ532 1 12
 
% -r EdZ555 1 12
 
% -r EdZ560 1 12
 
% -r EdZ625 1 10
 
% -r Edz665 1 10
 
% -r EdZ670 1 10
 
% -r EdZ683 1 10
 
% -r EdZ710 1 10
 
% -r EdZ780 1 10
 
 
 
% -r LuZ320 1 10
 
% -r LuZ340 1 10
 
% -r LuZ380 1 10
 
% -r LuZ395 1 12
 
% -r LuZ412 1 12
 
% -r Luz443 1 12
 
% -r Luz465 1 12
 
% -r LuZ490 1 12
 
% -r LuZ510 1 12
 
% -r LuZ532 1 12
 
% -r LuZ555 1 12
 
% -r LuZ560 1 12
 
% -r LuZ625 1 10
 
% -r 1lu665 1 10
 
% -r LuZ670 1 10
 
% -r LuZ683 1 10
 
% -r LuZ710 1 10
 
% -r LuZ780 1 10
 
%infile = 'akrmP101216B.lcd.1';
 
 
 
%rqfid = fopen('/home/data65/pb/REPROCESS_2010/PRR/rqclist.txt')
 
rqfid = fopen('/home/oceancolor/Plumes_and_Blooms/workspace/eriks/C-OPS/Copsrqclist.txt');
 
  
 +
%channels
 +
%={'0Ed412','0Ed443','0Ed490','0Ed510','0Ed555','0Ed665','1Lu412','1Lu443',
 +
%'1Lu490','1Lu510','1Lu555','1Lu665'}; %prr channels
 +
rqfid = fopen('/home/oceancolor/Plumes_and_Blooms/workspace/eriks/C-OPS/Copsrqclist.txt')
 
chin = 1;
 
chin = 1;
 
while ~feof(rqfid)
 
while ~feof(rqfid)
 
     chline = fgets(rqfid);
 
     chline = fgets(rqfid);
     channels3(chin,:) = {chline(1:6)};
+
     channels2(chin,:) = {chline(1:6)};
    %channels3 = channels3'
 
 
     chin = chin + 1;
 
     chin = chin + 1;
     if chin >= 37
+
     if chin > 36
 
         break
 
         break
 
     end
 
     end
 
end
 
end
channels3 = channels3';
+
channels2 = channels2';
 +
depth_width = [10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10];
 +
%interval = [12,12,12,12,12,10,12,12,12,12,12,10];
 +
% -r 1ed412 1 12
 +
% -r 1ed443 1 12
 +
% -r 1ed490 1 12
 +
% -r 1ed510 1 12
 +
% -r 1ed555 1 12
 +
% -r 1ed665 1 10
 +
% -r 1lu412 1 12
 +
% -r 1lu443 1 12
 +
% -r 1lu490 1 12
 +
% -r 1lu510 1 12
 +
% -r 1lu555 1 12
 +
% -r 1lu665 1 10
 +
%infile = 'bsakrmP101216B.lcd.1';
 +
s = struct('channel',channels2,'depthwidth',depth_width);
 +
valac = [];
 +
donebefore =0;
  
s = struct('channel',channels3,'scale',scale,'interval',interval);
 
valac = [];
 
for L = 1:size(scale,2)
 
   
 
%vars =%bscalcE(s(L).channel,s(L).scale(L),s(L).interval(L),'bananKrqcmmP101216B.l%cd.1')
 
vars = bscalcE_angQ(s(L).channel,s(L).scale(L),s(L).interval(L),infile);
 
  
valac = [valac;{vars}];
+
%=============main loop============
 +
for L = 1:size(depth_width,2)
 +
 
 +
%vars
 +
%=%bscalcE(s(L).channel,s(L).scale(L),s(L).interval(L),'bananKrqcmmP101216B.l%cd.1')
 +
%-------------end changed 12-4-12
 +
%valac = valac; %changed 12-4-12 from ' to not
  
 +
%===generate new file and checking what input files to use=======
 +
%========
  
if ~ischar(valac) % added by ES 9-18-2012
+
newfile = strcat('kc',infile);
%%char(valac) %why is this here??
+
infp = fopen(newfile,'r+');
 +
if infp ~= -1
 +
    infile = newfile;
 
end
 
end
 +
if infp ==-1 && donebefore == 0 %if first time through using "mbs" file
 +
    nf = fopen(newfile,'w+');  %open a new file for writing as usual
 +
    infp = fopen(infile,'r+'); %open original as usual
 +
else
 +
    if infp == -1 && donebefore == 1
 +
        newfile = infile;
 +
    end
 +
    temp = strcat('tempkclcd',newfile); %write stuff to this and then rename... to "kc"
 +
    nf = fopen(temp,'w+');%open a temp file that will be renaimed 'kc..'
 +
    if donebefore ==1 && L < 2 ;
 +
        infile = newfile;%just need to assign this once otherwise infile will keep having an extra kc on it.(kckckc..) 
 +
    end
 +
    infp = fopen(infile,'r+');
 +
end
 +
if donebefore ==1
 +
    %disp('done before')
 
end
 
end
 +
donebefore =1;
 +
vars = [];
  
%===generate new file=====
 
 
newfile = strcat('bs',infile);
 
nf = fopen(newfile,'w+');
 
infp = fopen(infile,'r+');
 
pull =[];
 
 
%write file and put in (0-) values "a"
 
%-----------------------
 
%Find index of Ed and Lu chans to generate 0- line
 
ct = 0;%channel index counter
 
p =1; %pulling index
 
infi = fopen(infile);
 
%for L2 = 1:size(scale,2)
 
  while ~feof(infi)
 
      s(p).channel;
 
      ckl = fgets(infi);
 
      %if strncmp(ckl,'1mer_time',9) ==1; %changed 12-3-12 1mer_time
 
      if strncmp(ckl,'FrameCount',10) ==1; %changed 12-3-12 1mer_time
 
        ct =1;
 
        %keyboard
 
      end
 
          if strncmp(ckl,s(p).channel,6) ==1
 
              %ct = ct+1
 
              pull(p) = ct;
 
              p = p +1;
 
             
 
          end
 
          if length(pull) >= size(scale,2) %should only be Ed and Lu
 
              break
 
          end
 
      if ct >=1
 
          ct = ct+1;
 
      end
 
  end
 
%=========++++++get # of columns
 
frewind(infi);
 
ctr =0;
 
flag = 0;
 
%while ~feof(infi)
 
for i = 1:1000
 
 
  tt = fgets(infi);
 
    %if strncmp(tt,'1mer_time',9) ==1; %changed 12-3-12 0prr_record from 1mer_time
 
    if strncmp(tt,'FrameCount',10) ==1; %changed 12-3-12 0prr_record from 1mer_time
 
        % ctr = ctr+1;
 
        flag =1;
 
    end
 
        %while strncmp(tt,'<data>',6) ~=1
 
        %  tt = fgets(infi);
 
        if flag == 1
 
            ctr = ctr+1;
 
 
        end
 
            if strncmp(tt,'<derived_parameters>',20) ==1
 
                ctr = ctr -1;
 
  
            end
+
%=======================================================================
        if strncmp(tt,'<data>',6) ==1
+
%=====runs the kc stuff=================================================
            ctr = ctr - 1;
+
%=====================================
            break
 
        end
 
           
 
        %end
 
    %end
 
end
 
  
zeromin_line = ones(1,ctr)*-9.9E35;
+
vars = CPSbopkc(s(L).channel,s(L).depthwidth(L),infile);
%zeromin_line = ones(1,ctr-2)*-9.9E35; %for prr_bincheat
+
vars = vars';% changed 12-4-12
fclose(infi);
+
valac = [valac,vars];
clear i;
+
%=======================================================================
for i = 1:length(pull)
+
%=======================================================================  
    oneval = char(valac(i));
 
    [a,b,c] = strread(oneval,'%s%s%s','delimiter',' ');
 
    val = char(c(2));
 
    zerominus = str2num(val);
 
  
    zeromin_line(pull(i)) = zerominus;
 
end
 
  
 
+
%===========print filters to
%------------------------- 
 
 
 
 
while ~feof(infp)
 
while ~feof(infp)
 
     linep = fgets(infp);
 
     linep = fgets(infp);
     fprintf(nf,linep);
+
    if strncmp(linep,'<data>',6) == 1
 +
        fprintf(nf,'%s\n',['kcr-',s(L).channel]);
 +
        fprintf(nf,'%s\n','<data>');
 +
        break
 +
    end
 +
     fprintf(nf,linep); %moved to after channel print 12-4-12
 
      
 
      
    if strncmp(linep,'<data>',6) == 1
+
end
        %fprintf(nf,linep)
 
  
        %fprintf(nf,'%s',zeromin_line)
+
%==========================================================================
       
+
%-----open temp data file for reading and add new data columns to it.
        dlmwrite(newfile,zeromin_line,'-append','delimiter',' ','precision','%.5d');
+
%==========================================================================
        fseek(nf,0,'eof');
+
  mname = strcat('temp',infile); %this is the same temp data file generated by bopkc
      % dlmwrite(newfile,' ','-append')
+
  tn = load(mname);
  
         %fprintf(nf,'%s\n','')
+
  if L ==1
       
+
    tempm = [tn,valac]; %added 12-4-12 ' making first line of data to write
 +
  else
 +
      tempm = [tempm,vars];
 +
  end
 +
  %disp('keyboard in kcloop')
 +
  %keyboard %#===++
 +
    dlmwrite(mname,tempm,'delimiter',' ','precision',6); %overwrites data file with new columns
 +
    matfile = fopen(mname);
 +
    while ~feof(matfile)
 +
        nln = fgets(matfile);
 +
         fprintf(nf,'%s',nln); %writes matfile to new lcd
 
     end
 
     end
 
      
 
      
 
      
 
      
 +
%------add filters to end of file
 +
while ~feof(infp)
 +
    tl = fgets(infp);
 +
 +
    if strncmp(tl,'<filters_used>',14) == 1
 +
        fprintf(nf,tl);
 +
        while ~feof(infp)
 +
            npf = fgets(infp);
 +
            fprintf(nf,'%s',npf);
 +
        end
 +
    end
 
end
 
end
%===end generate new file====
+
 
 +
 
 
%===add stats line==
 
%===add stats line==
 +
%for L = 1:size(depth_width,2) commented 12-4-12
 +
fprintf(nf,'%s\n',['bopkc', s(L).channel,' ', num2str(s(L).depthwidth(L)),' ', infile]);
 +
%fprintf(nf,'%s\n',char(valac(L)))
 +
%fprintf(nf,'%s/n')
 +
%end commented 12-4-12
  
for L = 1:size(scale,2)
+
fclose(nf);
fprintf(nf,'%s\n',['bscalc ', s(L).channel,' ', num2str(s(L).scale(L)),' ', num2str(s(L).interval(L)),' ', infile]);
+
fclose(infp);
 
+
if donebefore ==1 && L > 1
if ~ischar(valac) %added by ES 9-18-2012
+
%movefile(tempname,newfile)
     ln = valac(L);
+
     movefile(temp,infile);
fprintf(nf,'%s\n',char(ln));
 
 
end
 
end
%fprintf(nf,'%s/n')
+
infile = newfile; %needs to update filename otherwise infile will always be the same.
 
end
 
end
 +
 +
fclose all
  
  

Latest revision as of 15:13, 13 February 2014

function COPSkcloop(infile)

%channels
%={'0Ed412','0Ed443','0Ed490','0Ed510','0Ed555','0Ed665','1Lu412','1Lu443',
%'1Lu490','1Lu510','1Lu555','1Lu665'}; %prr channels
rqfid = fopen('/home/oceancolor/Plumes_and_Blooms/workspace/eriks/C-OPS/Copsrqclist.txt')
chin = 1;
while ~feof(rqfid)
    chline = fgets(rqfid);
    channels2(chin,:) = {chline(1:6)};
    chin = chin + 1;
    if chin > 36
        break
    end
end
channels2 = channels2';
depth_width = [10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10];
%interval = [12,12,12,12,12,10,12,12,12,12,12,10];
% -r 1ed412 1 12
% -r 1ed443 1 12
% -r 1ed490 1 12
% -r 1ed510 1 12
% -r 1ed555 1 12
% -r 1ed665 1 10
% -r 1lu412 1 12
% -r 1lu443 1 12
% -r 1lu490 1 12
% -r 1lu510 1 12
% -r 1lu555 1 12
% -r 1lu665 1 10
%infile = 'bsakrmP101216B.lcd.1';
s = struct('channel',channels2,'depthwidth',depth_width);
valac = [];
donebefore =0;


%=============main loop============
for L = 1:size(depth_width,2)

%vars
%=%bscalcE(s(L).channel,s(L).scale(L),s(L).interval(L),'bananKrqcmmP101216B.l%cd.1')
%-------------end changed 12-4-12
%valac = valac; %changed 12-4-12 from ' to not

%===generate new file and checking what input files to use=======
%========

newfile = strcat('kc',infile);
infp = fopen(newfile,'r+');
if infp ~= -1
    infile = newfile;
end
 if infp ==-1 && donebefore == 0 %if first time through using "mbs" file
     nf = fopen(newfile,'w+');  %open a new file for writing as usual
     infp = fopen(infile,'r+'); %open original as usual
 else
     if infp == -1 && donebefore == 1 
         newfile = infile;
     end
     temp = strcat('tempkclcd',newfile); %write stuff to this and then rename... to "kc"
     nf = fopen(temp,'w+');%open a temp file that will be renaimed 'kc..'
     if donebefore ==1 && L < 2 ;
         infile = newfile;%just need to assign this once otherwise infile will keep having an extra kc on it.(kckckc..)   
     end
     infp = fopen(infile,'r+');
 end 
if donebefore ==1
    %disp('done before')
end
donebefore =1;
vars = [];


%=======================================================================
%=====runs the kc stuff=================================================
%=====================================

vars = CPSbopkc(s(L).channel,s(L).depthwidth(L),infile);
vars = vars';% changed 12-4-12
valac = [valac,vars];
%=======================================================================
%======================================================================= 


%===========print filters to 
while ~feof(infp)
    linep = fgets(infp);
    if strncmp(linep,'<data>',6) == 1
        fprintf(nf,'%s\n',['kcr-',s(L).channel]);
        fprintf(nf,'%s\n','<data>');
        break
    end
    fprintf(nf,linep); %moved to after channel print 12-4-12
    
end

%==========================================================================
%-----open temp data file for reading and add new data columns to it.
%==========================================================================
   mname = strcat('temp',infile); %this is the same temp data file generated by bopkc
   tn = load(mname);

   if L ==1
    tempm = [tn,valac]; %added 12-4-12 ' making first line of data to write
   else
       tempm = [tempm,vars];
   end
   %disp('keyboard in kcloop')
   %keyboard %#===++
    dlmwrite(mname,tempm,'delimiter',' ','precision',6); %overwrites data file with new columns
    matfile = fopen(mname);
    while ~feof(matfile)
        nln = fgets(matfile);
        fprintf(nf,'%s',nln); %writes matfile to new lcd
    end
    
    
%------add filters to end of file
while ~feof(infp)
    tl = fgets(infp);

    if strncmp(tl,'<filters_used>',14) == 1
        fprintf(nf,tl);
        while ~feof(infp)
            npf = fgets(infp);
            fprintf(nf,'%s',npf);
        end
    end
end


%===add stats line==
%for L = 1:size(depth_width,2) commented 12-4-12
fprintf(nf,'%s\n',['bopkc', s(L).channel,' ', num2str(s(L).depthwidth(L)),' ', infile]);
%fprintf(nf,'%s\n',char(valac(L)))
%fprintf(nf,'%s/n')
%end commented 12-4-12

fclose(nf);
fclose(infp);
if donebefore ==1 && L > 1
%movefile(tempname,newfile)
    movefile(temp,infile);
end
infile = newfile; %needs to update filename otherwise infile will always be the same.
end

fclose all


back to C-OPS/CERBERUS Mfiles