Clear Filters
Clear Filters

Angle between 2 lines

5 views (last 30 days)
Elie
Elie on 19 Feb 2014
Commented: Jos (10584) on 24 Feb 2014
How can i calculate the angle between such two lines.is the dotvector method useful in such case?
line([50 50],[1 10000],'Color','G');
line([newBoxPolygon(1, 1) newBoxPolygon(4, 1)],[newBoxPolygon(1, 2) newBoxPolygon(4, 2)],'Color','G');
i tried this method
u=[newBoxPolygon(1, 1) newBoxPolygon(4, 1),newBoxPolygon(1, 2) newBoxPolygon(4, 2)]
v=[[50 50],[1 10000]]
CosTheta = dot(u,v)/(norm(u)*norm(v));
ThetaInDegrees = acos(CosTheta)*180/pi
but i'm getting an error can you please help
  2 Comments
Jos (10584)
Jos (10584) on 19 Feb 2014
What is the exact error you're getting?
Elie
Elie on 19 Feb 2014
There is no logical or compiler error , the error is in the angel it self, because the angle between the 2 lines is less than that splitted by the function above

Sign in to comment.

Answers (1)

Jos (10584)
Jos (10584) on 19 Feb 2014
Edited: Jos (10584) on 19 Feb 2014
You want to enter the direction vectors U and V into the formula
dU = [diffUx diffUy]
dV = [diffVx diffVy]
cosTheta = dot(dU,dV) ./ (norm(dU) * norm(dV))
  4 Comments
Elie
Elie on 21 Feb 2014
Hey i tried your advice but im getting the following error "A and B must be same size" This is my code . what is the error
%Line1
x1=(newBoxPolygon(1, 1));y1=(newBoxPolygon(1, 2));
x2=[newBoxPolygon(1, 1) newBoxPolygon(4, 1)];y2=[newBoxPolygon(1, 2) newBoxPolygon(4, 2)];
%The theoritcal line
x1_1=1; x1_2=1000;
y1_1=900; y1_2=900;
dU = [(x2-x1) (y2-y1)];
dV = [(x1_2-x1_1) (y1_2-y1_1)];
cosTheta = dot(dU,dV) ./ (norm(dU) * norm(dV));
disp(cosTheta);
Jos (10584)
Jos (10584) on 24 Feb 2014
You are setting up the vectors the wrong way: the direction vectors dU and dV should be 2 element arrays. dU is, but dV is not.
If you remove the semi-colons you see what I mean.

Sign in to comment.

Categories

Find more on Resizing and Reshaping Matrices in Help Center and File Exchange

Tags

No tags entered yet.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!