-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathenginepolar_workin.m
91 lines (78 loc) · 2.5 KB
/
enginepolar_workin.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
% This is a simple 2-stroke engine design tool. It produces a polar plot of the crank torque per angle.
close all
clear all
debug = 1;
% defining variables
%calc
res = 1000; %points per revolution
rad = [0:2*pi/res:2*pi]; %circular coordinate
scale = 30 ; % display scale for rodforce
%forces
F_max = 1000; %N maximal force (at TDC)
F_min = 100;
%geometry
rod = .040; %m
stroke = .060; %m
V_a = 120; %deg V_angle
PAs = [V_a/2 -V_a/2 V_a/2 -V_a/2 V_a/2 -V_a/2] /180*pi; %deg Piston Angles
%firing
FAs_i = [ 0 60 120 180 240 300]; %deg Firing Angles
%FAs_i = [ 0 0 0 0 0 0]; %deg Firing Angles
%CAs_i = [ 0 180 0 180 0 180]; %deg Crank Angles
CAs_i = [ 90 150 210 270 330 30]; %deg Crank Angles
%CAs_i = [ 0 0 0 0 0 0]; %deg Crank Angles
%CAs_i = [ 90 90 90 90 90 90]; %deg Crank Angles
FAs = FAs_i / 180*pi;
CAs = CAs_i / 180*pi;
% basic cos
cosforce = @(angle) (F_max-F_min)/2.*cos(rad.+angle).+(F_max-F_min)/2+F_min;
% piston force
pistonforce = zeros(length(FAs), length(rad));
for i = 1:length(FAs)
pistonforce(i,:) = cosforce(FAs(i));
end
%crank angle
crankangle = zeros(length(FAs), length(rad));
for i = 1:length(FAs)
crankangle(i,:) = rad + CAs(i) - PAs(i);
crankangle(i,:) = mod(crankangle(i,:), 2*pi);
end
%rod angle
rodangle = zeros(length(FAs), length(rad));
for i = 1:length(FAs)
rodangle(i,:) = asin(stroke/2/rod * sin(crankangle(i,:)));
end
%rod force
rodforce = pistonforce .* cos(rodangle);
%crank rod angle
crankrodangle = zeros(length(FAs), length(rad));
for i = 1:length(FAs)
crankrodangle(i,:) = pi - crankangle(i,:) - rodangle(i,:);
end
% crank torque
cranktorque = rodforce .* stroke/2 .* sin(crankrodangle);
% offset
mincranktorque = min( sum( cranktorque ) );
%cranktorque = cranktorque - mincranktorque;
i = 2;
if debug
plot ( rad*180/pi, pistonforce(i,:)/ 2);
hold on;
plot ( rad*180/pi, crankangle(i,:)* 180/pi, 'r' );
plot ( rad*180/pi, rodangle(i,:)* 180/pi, 'g' );
plot ( rad*180/pi, rodforce(i,:) / 2, 'm' );
plot ( rad*180/pi, crankrodangle(i,:)* 180/pi, 'k' );
hold off;
legend('pistonforce', 'crankangle', 'rodangle', 'rodforce', 'crankrodangle');
end
% display
figure;
polar(rad, sum(cranktorque))
hold on;
%polar(rad, 1/scale*sum(rodforce), 'r')
%polar(rad, 1/scale*rodforce)
axis equal;
legend('Crank Torque (Nm)'); %, strcat(int2str(scale), '\1 * Rod Forces (N)'));
title(strcat('Polar Plot == with FAs: ', mat2str(FAs_i), ', CAs: ', mat2str(CAs_i), ', Vangle: ', mat2str(V_a), ', offset crank torque: ', mat2str(mincranktorque)));
hold off;
#CH_save_plot();