error:An array for multiple LHS assignment cannot contain expressions.
Mostrar comentarios más antiguos
Error: File: Q7.m Line: 12 Column: 2
What does the error mean?
I'm using Matlab to solve Mechanism problems,and here is my code.
I'm pretty sure that it's not InverseRR's problem.I have used that function in other problems ,and it worked.
Hope that somebody who good at it could help me,please><
clc
clear
a1 = 15 ; a2 = 30 ; a3 = 20 ; a4 = 30 ; alpha = 30;
Xq = 50 ; Yq = 8 ; Xr = 70 ; Yr = 8;
dXa = 10 ; dYa = 0;
Xa = 20 ;Ya = a1 ;
I = 1;
BC = sqrt(a3^2 + a4^2 - 2 * a3 * a4 * cos(alpha)) ;
[(theta04),(theta02),dtheta4,dtheta2,ddtheta4,ddtheta2] = InverseRR(Xq,Yq,a3,a2,Xa,Ya,dXa,dYa,ddXa,ddYa,I);
theta2 = theta02 - 180;
theta4 = theta04 - alpha;
7 comentarios
madhan ravi
el 18 de Nov. de 2018
InverseRR is a function defined by you? if so upload it
Yi-Le Li
el 18 de Nov. de 2018
Editada: madhan ravi
el 18 de Nov. de 2018
madhan ravi
el 18 de Nov. de 2018
you didn't provide the value for ddXa,ddYa
Yi-Le Li
el 18 de Nov. de 2018
Stephen23
el 18 de Nov. de 2018
@Yi-Le Li: please show the complete error message. This means all of the red text.
madhan ravi
el 18 de Nov. de 2018
@Yi no you will still have error see my answer below
Yi-Le Li
el 18 de Nov. de 2018
Respuesta aceptada
Más respuestas (1)
madhan ravi
el 18 de Nov. de 2018
Editada: madhan ravi
el 18 de Nov. de 2018
The problem in your code was you put comma ( , ) instead of semicolon ( ; )
a1 = 15 ; a2 = 30 ; a3 = 20 ; a4 = 30 ; alpha = 30;
Xq = 50 ; Yq = 8 ; Xr = 70 ; Yr = 8;
dXa = 10 ; dYa = 0;
Xa = 20 ;Ya = a1 ;
I = 1;
ddXa=3; %fake data change it to your value
ddYa=5; %fake data change it to your value
BC = sqrt(a3^2 + a4^2 - 2 * a3 * a4 * cos(alpha)) ;
%|------||------|----error was here
[theta04,theta02,dtheta4,dtheta2,ddtheta4,ddtheta2] = InverseRR(Xq,Yq,a3,a2,Xa,Ya,dXa,dYa,ddXa,ddYa,I);
theta2 = theta02 - 180;
theta4 = theta04 - alpha;
function[PHI,PSI,dPHI,dPSI,ddPHI,ddPSI] = InverseRR(Xq,Yq,c,b,Xa,Ya,dXa,dYa,ddXa,ddYa,I)
X = Xa - Xq;
Y = Ya - Yq;
A = 2 * c* Y;
B = 2 * c * X;
C = X^2 + Y^2 + c^2 - b^2;
t1 = (A + sqrt(A^2+B^2-C^2))/(C+B);
t2 = (A - sqrt(A^2+B^2-C^2))/(C+B);
if (I == 1)
t = t1;
else
t = t2;
end
PHI = 2*atan(t);
U = (X- c*cos(PHI))/b;
V = (Y- c*sin(PHI))/b;
PSI = atan2(V,U);
Xb = c*cos(PHI);
Yb = c*sin(PHI);
%%% Inverse Velocity%%%
dX = dXa;
dY = dYa;
D = [ -c * sin(PHI) -b * sin(PSI); c * cos(PHI) b * cos(PSI) ];
% ^--------- error was here
E = [ dX;
dY ];
F = D \ E ;
dPHI = F(1,1);
dPSI = F(2,1);
%%% Inverse Acceleration %%%
ddX = ddXa;
ddY = ddYa;
G = [ -c * sin(PHI) -b * sin(PSI); %error was here
c * cos(PHI) b * cos(PSI) ];
H = [ ddX + c * cos(PHI) * dPHI ^2 - b * cos(PSI) * dPSI ^2 ; %error was here
ddY + c * cos(PHI) * dPHI ^2 - b * sin(PSI) * dPSI ^2 ] ;
I = G \ H;
ddPHI = I(1,1);
ddPSI = I(2,1);
PHI = PHI / pi * 180;
PSI = PSI / pi * 180;
end
1 comentario
Stephen23
el 18 de Nov. de 2018
"The problem in your code was you put comma ( , ) instead of semicolon ( ; )"
Where? And why is this a problem?
Categorías
Más información sobre Characters and Strings en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!