I need some help to solve non-linear equation with three unknowns and three knowns with having 170 different values for one known.
1 vue (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Prabhath Manuranga
le 21 Fév 2024
Commenté : Walter Roberson
le 12 Mar 2024
Xw, Yw, Zw (170 * 1 matrices) are known with 170 different values.
Xe, Ye, Ze are the unknowns.
Tx, Ty, Tz, Rx, Ry, Rz, and neta are some of other knowns.
I want to find the values for Xe, Ye, and Ze.
0 commentaires
Réponse acceptée
Torsten
le 21 Fév 2024
Modifié(e) : Torsten
le 21 Fév 2024
M = [eta+1,Rz,-Ry;-Rz,eta+1,Rx;Ry,-Rx,eta+1];
M = repmat(M,170,1);
b = [];
for i = 1:170
b = [b;Xw(i)-Tx;Yw(i)-Ty;Zw(i)-Tz];
end
sol = M\b;
Xe = sol(1)
Ye = sol(2)
Ze = sol(3)
6 commentaires
Torsten
le 23 Fév 2024
:-)
M = [eta+1,Rz,-Ry;-Rz,eta+1,Rx;Ry,-Rx,eta+1];
dM = decomposition(M);
Xe = zeros(170,1);
Ye = zeros(170,1);
Ze = zeros(170,1);
for i = 1:170
b = [Xw(i)-Tx;Yw(i)-Ty;Zw(i)-Tz];
sol = dM\b;
Xe(i) = sol(1);
Ye(i) = sol(2);
Ze(i) = sol(3);
end
Plus de réponses (2)
Prabhath Manuranga
le 28 Fév 2024
Modifié(e) : Prabhath Manuranga
le 28 Fév 2024
1 commentaire
Torsten
le 28 Fév 2024
W_lvd = H_i.*(g_i+0.0424*H_i)+W_i
if you want W_lvd as a 170x1 matrix
W_lvd = 1/170*sum(H_i.*(g_i+0.0424*H_i)+W_i)
if you want W_lvd as the best approximate value for the vector values H_i.*(g_i+0.0424*H_i)+W_i
Prabhath Manuranga
le 12 Mar 2024
Modifié(e) : Walter Roberson
le 12 Mar 2024
1 commentaire
Walter Roberson
le 12 Mar 2024
X_ISMD = 995152.969208341;
Y_ISMD = 996113.117131325;
D1 = zeros(length(data1),1);
for i = 1:length(data1)
D1(i) = sqrt((X_ISMD - X_WGS84(i)).^2 + (Y_ISMD - Y_WGS84(i)).^2);
end
D1
Voir également
Catégories
En savoir plus sur Get Started with Curve Fitting Toolbox dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!