You are now following this question
- You will see updates in your followed content feed.
- You may receive emails, depending on your communication preferences.
How to select columns from data matrix using "for" loop?
    5 views (last 30 days)
  
       Show older comments
    
Hi,
I would like to select columns from a data matrix and use them to interpolate data from another file. For example, first column is selected and interpolated from another file, and printed, then the second column, and so on. I know the interpolation code, but I need the selection of column and printing the interpolated data codes.
I would be grateful if someone can help me in this.
Thank you. Regards, Ismail
Accepted Answer
  Birdman
      
      
 on 14 Feb 2018
        One approach:
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step
    interp(b,..);%you can use it in your function 
end
42 Comments
  Birdman
      
      
 on 14 Feb 2018
				Either erase the semicolon:
for i=1:size(A,2)%number of columns
    b=A(:,i)
    interp(b,..);
end
or use disp:
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step
    interp(b,..);%you can use it in your function 
    disp(b)
end
  Ismail Qeshta
 on 14 Feb 2018
				Thanks Birdman. Would you please be able to suggest to me how to print the outcome out at every step?
  Birdman
      
      
 on 14 Feb 2018
				Outcome, means outcome of interp? Then:
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step
    res=interp(b,..);%you can use it in your function 
    disp(res)
end
  Birdman
      
      
 on 14 Feb 2018
				I mean to print the interpolation results in a .txt file.
Answer:
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step
    res=interp(b,..);%you can use it in your function 
    disp(res)
    fid=fopen(['result_' num2str(i) '.txt'],'w');
    fprintf(fid,'%f\n',res); 
    fclose(fid)
end
  Ismail Qeshta
 on 14 Feb 2018
				Thank you very much Birdman for the code. That is really helpful. Also, I am actually extracting the data matrix from a file. I am not sure how to modify the code to suit that. Thank you again Birdman for your great help.
  Walter Roberson
      
      
 on 14 Feb 2018
				Unless you have a different data matrix file for each column, you would read the data once before the loop, and then (if necessary) extract the appropriate portion of it inside the loop.
  Birdman
      
      
 on 14 Feb 2018
				You will use fscanf instead of fprintf. Imagine you want to read the file you wrote. Simply do this:
    fid=fopen('result_1.txt,'r');
    fscanf(fid,'%f') 
    fclose(fid)
The line with fscanf will display the result of the txt file.
  Ismail Qeshta
 on 14 Feb 2018
				Many thanks Birdman. I tried to incorporate it in my code. I only get the interpolation in the first file. Would you please be able to check it for me?
clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
A=importdata('allPiers.txt');
for i=1:size(A,37)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step   
[y2] = [b];
x2 (k,:) = interp1(y3, x3, y2, 'linear')
 fid=fopen(['result_' num2str(i) '.txt'],'w');
 fprintf(fid,'%f\n',x2); 
 fclose(fid)
end
end
  Ismail Qeshta
 on 14 Feb 2018
				Great. Thank you so much Birdman. The only thing is that some of the data in the .txt files are written as "NaN". Is there anyway to replace them automatically with 0.07?
  Birdman
      
      
 on 14 Feb 2018
				Replace them before writing in your for loop. So
temp=x2(k,:);
temp(isnan(temp))=0.07;
x2(k,:)=temp;
and then write to the txt file.
  Ismail Qeshta
 on 14 Feb 2018
				Thank you Birdman. Which one exactly? I put it before the second for loop but it does not work.
  Ismail Qeshta
 on 14 Feb 2018
				
      Edited: Ismail Qeshta
 on 14 Feb 2018
  
			I actually mean the output "result_n.txt" files.
  Birdman
      
      
 on 14 Feb 2018
				
      Edited: Birdman
      
      
 on 14 Feb 2018
  
			Use the following code:
clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
A=importdata('allPiers.txt');
for i=1:size(A,37)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step   
[y2] = [b];
x2 (k,:) = interp1(y3, x3, y2, 'linear')
temp=x2(k,:);
temp(isnan(temp))=0.07;
x2(k,:)=temp;
 fid=fopen(['result_' num2str(i) '.txt'],'w');
 fprintf(fid,'%f\n',x2); 
 fclose(fid)
end
end
  Ismail Qeshta
 on 14 Feb 2018
				Many thanks Birdman. Shall the for i=1:size(A,37) be changed to i=1:size(A,2)?
  Ismail Qeshta
 on 14 Feb 2018
				I cannot thank you enough Birdman. You have been awesome. Thank you very much.
  Ismail Qeshta
 on 14 Feb 2018
				Hi Birdman. Actually, after doing some further checking of the code, I found that it does not give the same results as when I use it for individual columns using the original code below. Would you please be able to help me find the error?
clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
[y2] = [8479186.526  5814080.3  7648088.256  7116870.805  9233172.585];
x2 (k,:) = interp1(y3, x3, y2, 'linear')
end
  Ismail Qeshta
 on 14 Feb 2018
				
      Edited: Ismail Qeshta
 on 14 Feb 2018
  
			Thanks Birdman. It showed me the following error message: Subscripted assignment dimension mismatch.
Subscripted assignment dimension mismatch.
Error in Interpolate11 (line 18)
x2 (:,k) = interp1(y3, x3, y2, 'linear')
  Ismail Qeshta
 on 14 Feb 2018
				
      Edited: Ismail Qeshta
 on 14 Feb 2018
  
			Thanks Birdman. I got the same error message as above. Now the code is:
clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
A=importdata('AllPiers2.txt');
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step   
[y2] = [b];
x2 (:,k) = interp1(y3, x3, y2, 'linear').'
temp=x2(:,k);
temp(isnan(temp))=0.07;
x2(:,k)=temp;
 fid=fopen(['result_' num2str(i) '.txt'],'w');
 fprintf(fid,'%f\n',x2); 
 fclose(fid)
end
end
  Ismail Qeshta
 on 14 Feb 2018
				This interpolation is for getting the y values that correspond to x values from the data matrix column. It refers to the linear interpolation.
  Birdman
      
      
 on 14 Feb 2018
				clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
A=importdata('AllPiers2.txt');
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step   
[y2] = [b];
res = interp1(y3, x3, y2, 'linear').'
x2=res(:,k);
temp=x2;
temp(isnan(temp))=0.07;
x2=temp;
 fid=fopen(['result_' num2str(i) '.txt'],'w');
 fprintf(fid,'%f\n',x2); 
 fclose(fid)
end
end
  Ismail Qeshta
 on 14 Feb 2018
				Many thanks Birdman. I got the following error message:
Index exceeds matrix dimensions.
Error in Interpolate11 (line 19)
x2=res(:,k);
  Birdman
      
      
 on 14 Feb 2018
				Ups, I missed this. Adapt this code:
clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
[y2] = [8479186.526  5814080.3  7648088.256  7116870.805  9233172.585].';
x2 (k,:) = interp1(y3, x3, y2, 'linear')
end
  Ismail Qeshta
 on 14 Feb 2018
				
      Edited: Ismail Qeshta
 on 14 Feb 2018
  
			Many thanks Birdman. In which part of the code should it be placed? This code is for individual data not the one we discussed above I think.
  Birdman
      
      
 on 14 Feb 2018
				clear; clc;
Folder = cd;
N=100;
x2     = zeros(N, 10);
for k = 1:N;
  Driftt  = sprintf('Drift%d.out', k);
  Reactt  = sprintf('React%d.out', k);
  matDrift     = importdata(fullfile(Folder, Driftt));
  matReact = importdata(fullfile(Folder, Reactt));
  x1= matDrift(:,2);
  y1= -sum(matReact(:,2:11),2);
[x3, ix] = unique(x1);
y3       = y1(ix);
A=importdata('AllPiers2.txt');
for i=1:size(A,2)%number of columns
    b=A(:,i);%ith column is assigned to b variable at every step   
[y2] = [8479186.526  5814080.3  7648088.256  7116870.805  9233172.585].';
x2 (:,k) = interp1(y3, x3, y2, 'linear').'
temp=x2(:,k);
temp(isnan(temp))=0.07;
x2(:,k)=temp;
 fid=fopen(['result_' num2str(i) '.txt'],'w');
 fprintf(fid,'%f\n',x2); 
 fclose(fid)
end
end
  Ismail Qeshta
 on 14 Feb 2018
				Thanks Birdman. [y2] should take [b] values not the one inserted. Isn't it?
  Ismail Qeshta
 on 14 Feb 2018
				I still got the same error message:
Subscripted assignment dimension mismatch.
Error in Interpolate11 (line 18)
x2 (:,k) = interp1(y3, x3, y2, 'linear').'
  Birdman
      
      
 on 14 Feb 2018
				Make sure that this y2 vector you defined manually has the same length with
   b=A(:,i);
   y2=b;
because that was working as I recall. Notice the lengths should be equal.
  Ismail Qeshta
 on 14 Feb 2018
				The matrix dimension problem came up only when we started changing the x2(:,k) with x2(k,:)
  Ismail Qeshta
 on 14 Feb 2018
				Thanks Birdman. Yes, that is right, but how to fix the difference in results?
  Ismail Qeshta
 on 14 Feb 2018
				Yes. I was thinking about that. Thank you very much again Birdman. I really appreciate your time and effort.
More Answers (0)
See Also
Categories
				Find more on Loops and Conditional Statements in Help Center and File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!An Error Occurred
Unable to complete the action because of changes made to the page. Reload the page to see its updated state.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom(English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)


