How to inner join two matrices?
    8 visualizzazioni (ultimi 30 giorni)
  
       Mostra commenti meno recenti
    
I have following two matrices of data that contain three columns each, first two columns are GPS data (latitude, longitude) and the third value is elevation angle. I would like to inner join both tables based on their GPS values to calculate the difference in elevation angle between the two matrices. Here is an example;
tbl1 = [
   28.057      -80.621        25.3 
    ......];
tbl2 = [
     28.057      -80.624        20.6
     28.057      -80.621       20.62
     .....];
tbl3 should look like the following:
tbl3 = [
28.057      -80.621        25.3      20.6   4.7];
Any idea on how to join these tables? Cheers!
0 Commenti
Risposta accettata
  Guillaume
      
      
 il 20 Ott 2016
        
      Modificato: Guillaume
      
      
 il 21 Ott 2016
  
      [~, row1, row2] = intersect(tbl1(:, [1 2]), tbl2(:, [1 2]), 'rows');
tbl3 = [tbl1(row1), tbl2(row2, 3)];
tbl3(:, 5) = diff(tbl3(:, [4 3]), [], 2);
This assumes that the GPS values are exactly identical in both matrices or that they're rounded to the same number of decimals in both.
Più risposte (0)
Vedere anche
Categorie
				Scopri di più su Cell Arrays in Help Center e File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!