Skip to content
Snippets Groups Projects
Commit 220707a5 authored by Lars Spannan's avatar Lars Spannan
Browse files

Upload Aufgabe12

parent f567ceb6
No related branches found
No related tags found
No related merge requests found
%% Cell type:markdown id: tags:
<img src="">
%% Cell type:markdown id: tags:
<center>Lehrstuhl Technische Dynamik, Juniorprofessur Fluid-Struktur Kopplung in Mehrkörpersystemen</center><br>
<center><font size=5>Maschinen- und Strukturdynamik</font></center>
%% Cell type:markdown id: tags:
# Übung 12 - Vektoriteration
Die Eigenfrequenzen und Eigenvektoren einer Getriebewelle mit zwei Zahnrädern sollen bestimmt werden.
Gegeben:
$a_1$ = 100mm, $a_2$ = 160 mm, $a_3$ = 100 mm, $d$ = 20 mm, $E$ = $2.1\cdot 10^{5}$ N/mm², $D_1$ = 200 mm, $B_1$ = 30 mm, $D_2$ = 120 mm, $B_2$ = 40 mm, $\rho$ = 7850 kg/m³, $c_{L1}$ = $10^7$ N/m, $c_{L2}$ = $2 \cdot 10^7$ N/m
%% Cell type:markdown id: tags:
Gesucht:
1. DGL mit FE-Balken (massebehaftete Welle + Zahnrad mit Masse und Drehträgheit) mit elastischen Lagern
2. Bestimmen Sie die ersten drei Eigenvektoren mittels der inversen Vektoriteration nach von Mises.
%% Cell type:markdown id: tags:
<img src="" alt="" />
%% Cell type:markdown id: tags:
## Bestimmung des homogenen DGL Systems
$$
\mathrm{M} \; \ddot{\vec{q}} \; + \; \mathrm{K} \; \vec{q} \; = \; \vec{0}
$$
Dämpfung und Gyroskopie können entsprechend berücksichtigt werden, wenn das resultierende nichtlineare EWP nach der bekannten Transformation in ein lineares EWP überführt wird (Matrizen $\mathrm{F}$ und $\mathrm{G}$).
Übertragen der Lösung aus Aufgabe 11 (FEM4):
%% Cell type:markdown id: tags:
### Parameter definieren
Alle Parameter in SI-Einheiten.
%% Cell type:code id: tags:
``` octave
% Strukturvariable p beinhaltet alle Größen
p.a_1 = 0.100; p.a_2 = 0.160; p.a_3 = 0.100; p.d = 0.020;
p.E = 2.1E11; p.rho = 7850;
p.D_1 = 0.200; p.B_1 = 0.030;
p.D_2 = 0.120; p.B_2 = 0.040;
p.c_L1 = 1E7; p.c_L2 = 2E7;
p.Fd = 100;
% abgeleitete Groessen:
p.Ixx = pi/64*p.d^4; % Flächenträgheitsmoment
p.L = p.a_1 + p.a_2; % Lagerabstand
p.m_1 = p.rho*p.B_1*pi/4*p.D_1^2; % Masse Zahnrad 1
p.Ja_1 = 0.25*p.m_1*((p.D_1/2)^2 + (p.B_1^2)/3); % Axiales MTM Zahnrad 1
p.m_2 = p.rho*p.B_2*pi/4*p.D_2^2; % Masse Zahnrad 2
p.Ja_2 = 0.25*p.m_2*((p.D_2/2)^2 + (p.B_1^2)/3); % Axiales MTM Zahnrad 2
```
%% Cell type:markdown id: tags:
### Element-Matrizen
%% Cell type:code id: tags:
``` octave
function [Ke, Me] = element_matrix_balken(E,d,L,rho)
% diese Zuordnung gilt, wenn die z Achse die Balkenlängsachse ist
% Flächenträgheitsmoment
I = pi/64*(d^4);
% Querschnittsfläche
A = pi/4*(d^2);
% Element-Steifigkeitsmatrix
Ke = E*I/L^3*...
[ 12 6*L -12 6*L;
6*L 4*L^2 -6*L 2*L^2;
-12 -6*L 12 -6*L;
6*L 2*L^2 -6*L 4*L^2];
% Element-Massenmatrix
Me = rho*A*L/420*...
[156 22*L 54 -13*L;
22*L 4*L^2 13*L 3*L^2;
54 13*L 156 -22*L;
-13*L 3*L^2 -22*L 4*L^2];
end
```
%% Cell type:markdown id: tags:
### Gesamtmatrizen
Für die massebehaftete Welle mit Zahnrädern (Masse + Drehträgheit) in elastischen Lagern. Gyroskopie wird vernachlässigt.
%% Cell type:code id: tags:
``` octave
function [K, M, rhs, z] = matrizen_FEM4(p)
dof_knoten = 2; % Anzahl Freiheitsgrade pro Knoten
% Knotenpositionen
z = [0 (p.a_1-p.B_1/2) (p.a_1+p.B_1/2) (p.a_1+p.a_2) ...
(p.a_1+p.a_2+p.a_3-p.B_2/2) (p.a_1+p.a_2+p.a_3) (p.a_1+p.a_2+p.a_3+p.B_2/2)];
% Extra Knoten in der Mitte von Zahnrad 2 zur Auswertung des Amplitudengangs
anz_knoten = numel(z);
anz_balken = anz_knoten -1;
DOF = anz_knoten*dof_knoten;
% Durchmesserverlauf
d = [p.d p.D_1 p.d p.d p.D_2 p.D_2];
% Speicher für Matrizen allokieren
K = zeros(DOF, DOF);
M = zeros(DOF, DOF);
rhs = zeros(DOF, 1);
% Balken-Matrizen aufbauen
for ElementNr = 1:anz_balken
% Elementlänge
L_e = z(ElementNr+1) - z(ElementNr);
%aktueller Balkendurchmesser
d_e = d(ElementNr);
% Elementmatrizen
[Ke,Me] = element_matrix_balken(p.E, d_e, L_e, p.rho); % Input Reihenfolge wie Definition oben
% Startindex in Gesamtmatrix
ia = (ElementNr - 1)*dof_knoten + 1;
% Endindex in Gesamtmatrix
ie = ia + 2*dof_knoten - 1;
K(ia:ie,ia:ie) = K(ia:ie,ia:ie) + Ke;
M(ia:ie,ia:ie) = M(ia:ie,ia:ie) + Me;
end
% Massen der Zahnräder nicht aufprägen, da in Wellenmasse enthalten
% Rechte Seite für Amplitudengang
KnotenNummer = 6;
idx = dof_knoten*(KnotenNummer -1)+1;
rhs(idx, 1) = p.Fd;
% Lagerung modellieren
% Steifigkeit bei Translation der Knoten 1 (DOF 1) und 4 (DOF 7) aufprägen
% Lager 1
KnotenNummer = 1;
idx = dof_knoten*(KnotenNummer -1)+1; % = 1
K(idx, idx) = K(idx, idx) + p.c_L1;
% Lager 2
KnotenNummer = 4;
idx = dof_knoten*(KnotenNummer -1)+1; % = 7
K(idx, idx) = K(idx, idx) + p.c_L2;
end
```
%% Cell type:markdown id: tags:
## Eigenwerte und Eigenvektoren
%% Cell type:markdown id: tags:
### Inverse Vektoriteration
Für dieses Verfahren sind drei Schritte/Kenntnisse notwendig:
1. Transformation des Eigenwertproblems (EWP)
2. Der Entwicklungssatz für die Zusammensetzung von Vektoren
3. Die Iterationsvorschrift
In Aufgabe 11 wurden die (ersten 2) Eigenwerte und Eigenvektoren mit dem `eigs` Befehl bestimmt.
```octave
[K, M, rhs, z_FEM4] = matrizen_FEM4(p);
% Diese Routine ───────┐ wollen wir selbst programmieren.
[EV_FEM4, EW_FEM4] = eigs(K, M, 2, 'sm');
```
%% Cell type:markdown id: tags:
#### Transformation des Eigenwertproblems (EWP)
Mit dem üblichen Ansatz $\vec{q} = \hat{\vec{q}} \sin(\omega_0 t)$ ergibt sich das EWP:
$$
\left( -\omega_0^2 \mathrm{M} + \mathrm{K} \right) \hat{\vec{q}} = \vec{0}
$$
%% Cell type:markdown id: tags:
Division durch $-\omega_0^2$ ergibt
$$
\left( \mathrm{M} -\frac{1}{\omega_0^2} \mathrm{K} \right) \hat{\vec{q}} = \vec{0}
$$
%% Cell type:markdown id: tags:
Die Substitution $\mu \equiv \frac{1}{\omega_0^2}$ liefert
$$
\left( \mathrm{M} -\mu \mathrm{K} \right) \hat{\vec{q}} = \vec{0}
$$
%% Cell type:markdown id: tags:
Multiplikation mit der Inversen von $\mathrm{K}$ von links liefert
$$
\left( \mathrm{K}^{-1}\mathrm{M} -\mu \mathrm{I} \right) \hat{\vec{q}} = \vec{0}
$$
%% Cell type:markdown id: tags:
Umsortieren liefert
$$
\mathrm{K}^{-1}\mathrm{M} \; \hat{\vec{q}} = \mu \hat{\vec{q}}
$$
%% Cell type:markdown id: tags:
Und Einführen der Abkürzung $\mathrm{M}^\prime_u \equiv \mathrm{K}^{-1}\mathrm{M}$ liefert schließlich
$$
\mathrm{M}^\prime_u \; \hat{\vec{q}} = \mu \hat{\vec{q}}
$$
%% Cell type:markdown id: tags:
Diese Umformung ist exakt. Hier hat noch keine Näherung stattgefunden. Diese Gleichung gilt für jede betrachtete Eigenkreisfrequenz $\omega_{0,i}$ und den zugehörigen Eigenvektor $\hat{\vec{q}}_i$.
$$
\mathrm{M}^\prime_u \; \hat{\vec{q}}_i = \mu_i \hat{\vec{q}}_i
$$
%% Cell type:markdown id: tags:
#### Entwicklungssatz
%% Cell type:markdown id: tags:
Jede beliebige Verformung $\hat{\vec{s}}$ des Systems setzt sich durch die Überlagerung der Eigenformen zusammen:
$$
\hat{\vec{s}} = \sum_{i=1}^f a_i \hat{\vec{q}}_i
$$
$f$ ist die Gesamtanzahl der Freiheitsgrade (= Anzahl der Eigenformen). Die skalaren Vorfaktoren $a_i$ sind zunächst unbekannt. Auch Null ist als Vorfaktor möglich, wenn eine Eigenform nicht an der betrachtenten Verformung beteiligt ist.
%% Cell type:markdown id: tags:
#### Iteration
Wird $\mathrm{M}^\prime_u $ mit einem beliebigen Vektor $\hat{\vec{s}}$ multipliziert, ergibt sich
$$
\mathrm{M}^\prime_u \; \hat{\vec{s}} = \sum_{i=1}^f \mathrm{M}^\prime_u a_i \hat{\vec{q}}_i
= \sum_{i=1}^f a_i \mathrm{M}^\prime_u \hat{\vec{q}}_i
= \sum_{i=1}^f a_i \mu_i \hat{\vec{q}}_i
$$
%% Cell type:markdown id: tags:
$$
= a_1 \mu_1 \hat{\vec{q}}_1 + a_2 \mu_2 \hat{\vec{q}}_2 + a_3 \mu_3 \hat{\vec{q}}_3 + \ldots + a_f \mu_f \hat{\vec{q}}_f = \hat{\vec{s}}_1
$$
%% Cell type:markdown id: tags:
Mit $\quad \mu_1 > \mu_2 > \mu_3 > \ldots > \mu_f$, da $\quad \omega_{0,1} < \omega_{0,2} < \omega_{0,3} < \ldots < \omega_{0,f}$.
%% Cell type:markdown id: tags:
Erneutes Einsetzen in die Iterationsvorschrift ergibt dann
$$
\mathrm{M}^\prime_u \; \hat{\vec{s}}_1 = a_1 \mu_1^2 \hat{\vec{q}}_1 + a_2 \mu_2^2 \hat{\vec{q}}_2 + a_3 \mu_3^2 \hat{\vec{q}}_3 + \ldots + a_f \mu_f^2 \hat{\vec{q}}_f = \hat{\vec{s}}_2
$$
%% Cell type:markdown id: tags:
Nach ,,ausreichend'' vielen Iterationsschritten $N$ besteht der Vektor $\hat{\vec{s}}_N$ maßgeblich aus dem Vielfachen des ersten Eigenvektors $\hat{\vec{q}}_1$ und ist somit selbst ein Eigenvektor der ersten Eigenkreisfrequenz.
%% Cell type:markdown id: tags:
#### Iterationsfunktion
%% Cell type:markdown id: tags:
Mit Angabe der Iterationsschritte:
%% Cell type:code id: tags:
``` octave
function sj = InvVekIteration_Schritte(K,M,s0,N)
% K - Steifigkeitsmatrix
% M - Massenmatrix
% s0 - Startvektor
% N - Anzahl an Iterationsschritten
M_u_prime = inv(K)*M;
sj = s0;
for j = 1:N
sj = M_u_prime*sj;
sj = sj/norm(sj); % Division durch die Länge (euklidische Norm)
end
end
```
%% Cell type:markdown id: tags:
Mit Angabe eines Konvergenzkriteriums
%% Cell type:code id: tags:
``` octave
function sk = InvVekIteration_Kriterium(K,M,s0,Grenze)
% K - Steifigkeitsmatrix
% M - Massenmatrix
% s0 - Startvektor
% Grenze - Konvergenzkriterium: Norm der Vektordifferenz der letzten beiden Iterationen
M_u_prime = inv(K)*M;
% Initialisierung
sj = zeros(size(s0));
sk = s0/norm(s0);
while norm(sk - sj) > Grenze
sj = sk; % letztes Iterationsergebnis speichern
sk = M_u_prime*sk; % Iteration (k = j+1) durchführen
sk = sk/norm(sk); % Normieren
end
end
```
%% Cell type:markdown id: tags:
Auch eine Kombination wäre denkbar mit einer definierten maximalen Anzahl an Iterationsschritten.
%% Cell type:markdown id: tags:
Berechnung des ersten Eigenvektors:
%% Cell type:code id: tags:
``` octave
[K, M, ~, ~] = matrizen_FEM4(p);
InvVekIteration_Kriterium(K,M,ones(size(K,1),1),1E-6)
```
%% Output
ans =
-0.0043813
-0.1638477
-0.0155952
-0.0682089
-0.0176414
-0.0682013
0.0029700
0.3658776
0.0399129
0.5233080
0.0503791
0.5233143
0.0608454
0.5233152
%% Cell type:markdown id: tags:
#### Aussieben
Ist nun der zweite Eigenvektor gesucht, muss ein Startvektor $\hat{\vec{s}}_{0,2}$ gefunden werden, für den $a_1 = 0$ gilt. Dies wird erzielt, indem der Anteil des ersten Eigenvektors $\hat{\vec{q}}_1$ von dem (zufälligen) Startvektor $\hat{\vec{s}}$ subtrahiert wird.
%% Cell type:markdown id: tags:
Isolation des Anteils des ersten EV ergibt
$$
\hat{\vec{s}} = \sum_{i=1}^f a_i \hat{\vec{q}}_i = a_1 \hat{\vec{q}}_1 + \sum_{i=2}^f a_i \hat{\vec{q}}_i
$$
%% Cell type:markdown id: tags:
Nach Multiplikation von links mit $\hat{\vec{q}}_1^T \mathrm{M}$ ergibt sich
$$
\hat{\vec{q}}_1^T \; \mathrm{M} \; \hat{\vec{s}} = a_1 \hat{\vec{q}}_1^T \; \mathrm{M} \; \hat{\vec{q}}_1 \; + \; \sum_{i=2}^f a_i \; \underbrace{\hat{\vec{q}}_1^T \; \mathrm{M} \; \hat{\vec{q}}_i}_{= 0}
$$
%% Cell type:markdown id: tags:
Und somit
$$
a_1 = \frac{\hat{\vec{q}}_1^T \; \mathrm{M} \; \hat{\vec{s}}}{\hat{\vec{q}}_1^T \; \mathrm{M} \; \hat{\vec{q}}_1}
$$
$$
\hat{\vec{s}}_{0,2} = \hat{\vec{s}} - a_1 \hat{\vec{q}}_1
$$
%% Cell type:code id: tags:
``` octave
function s_neu = aussieben(s_alt, M, q)
a = (q' * M * s_alt)/(q' * M * q);
s_neu = s_alt - a * q;
end
```
%% Cell type:markdown id: tags:
### Numerik
* Da die Länge des Vektors $\hat{\vec{s}}_j$ mit jeder Iteration $j$ zunimmt, ist $\hat{\vec{s}}_j$ nach jeder$^\text{*}$ Iteration zu normieren, um die numerischen Werte beschränkt zu halten.
* Der Startvektor muss den gesuchten ersten Eigenvektor beinhalten, d.h. $a_1 \neq 0$.
* Da das Absieben nicht exakt ist, muss auch während der Iteration gesiebt werden.
%% Cell type:markdown id: tags:
Iterationsfunktion mit dem Aussieben ungewünschter Ergebnisse in jedem Iterationsschritt
%% Cell type:code id: tags:
``` octave
function sk = InvVekIteration_Sieben(K,M,s0,Grenze,EV_bekannt)
% K - Steifigkeitsmatrix
% M - Massenmatrix
% s0 - Startvektor
% Grenze - Konvergenzkriterium: Norm der Vektordifferenz der letzten beiden Iterationen
% EV_bekannt - Matrix mit Eigenvektoren in den Spalten, die bei der Iteration ausgesiebt werden sollen
M_u_prime = inv(K)*M;
% Initialisierung
sj = zeros(size(s0));
sk = s0/norm(s0);
while norm(sk - sj) > Grenze
sj = sk; % letztes Iterationsergebnis speichern
sk = M_u_prime*sj; % Iteration (k = j+1) durchführen
sk = sk/norm(sk); % Normieren
for i = 1:size(EV_bekannt,2) % Alle bekannten Eigenvektoren raussieben
sk = aussieben(sk,M,EV_bekannt(:,i));
end
end
end
```
%% Cell type:markdown id: tags:
### Rayleigh-Quotient
Ist ein Eigenvektor (näherungsweise) bekannt, so kann der Eigenwert bzw. die Eigenkreisfrequenz (näherungsweise) mittels des Rayleigh-Quotienten berechnet werden. Dieser folgt aus der Umformung des Eigenwertproblems:
$$
\left( - \omega_0^2 \mathrm{M} + \mathrm{K} \right) \hat{\vec{q}} = \vec{0} \\
\mathrm{K} \hat{\vec{q}} = \omega_0^2 \mathrm{M} \hat{\vec{q}}
$$
%% Cell type:markdown id: tags:
Multiplikation von links mit $\hat{\vec{q}}^T$ ergibt
$$
\underbrace{\hat{\vec{q}}^T \mathrm{K} \hat{\vec{q}}}_{Skalar} = \omega_0^2 \underbrace{\hat{\vec{q}}^T \mathrm{M} \hat{\vec{q}}}_{Skalar}
$$
%% Cell type:markdown id: tags:
und somit
$$
\omega_0^2 = \frac{\hat{\vec{q}}^T \mathrm{K} \hat{\vec{q}}}{\hat{\vec{q}}^T \mathrm{M} \hat{\vec{q}}}
$$
%% Cell type:code id: tags:
``` octave
function omega = Omega_RQ(K,M,q)
omega = sqrt( (q' * K * q)/(q' * M * q) );
end
```
%% Cell type:markdown id: tags:
### myeigs(K,M,n)
Mit den obigen Funktionen kann nun eine rudimentäre Version der `eigs` Funktion zur Bestimmung der kleinsten $n$ Eigenwerte mit zugehörigen Eigenvektoren erstellt werden.
%% Cell type:code id: tags:
``` octave
function [omega, EV] = myeigs(K,M,n)
Grenze = 1E-10; % Iterationsgrenze
dof = size(K,1); % Anzahl der Freiheitsgrade in q
s0 = ones(dof,1); % Startvektor generieren (rand() oder ones())
omega = zeros(n,1); % Vektor zum Abspeichern der Eigenkreisfrequenzen
EV = zeros(dof,n); % Matrix zum Abspeichern der Eigenvektoren
% Schleife, bis die gewünschte Anzahl an Eigenvektoren gefunden ist
for i = 1:n
EV(:,i) = InvVekIteration_Sieben(K,M,s0,Grenze,EV(:,1:i-1));
omega(i) = Omega_RQ(K,M,EV(:,i));
end
end
```
%% Cell type:markdown id: tags:
### Ergebnisse
%% Cell type:code id: tags:
``` octave
[K, M, ~, ~] = matrizen_FEM4(p);
% Eigene Implementierung:
[omega, EV] = myeigs(K, M, 2);
display(['Eigene Implementierung: ω_{01} = ' num2str(omega(1)) ', ω_{02} = ' num2str(omega(2))])
% Eingebaute Funktion:
[EV, lambda] = eigs(K, M, 2, 'sm');
lambda = sort(lambda*ones(size(lambda,1),1));
display(['Eingebaute eigs Funktion: ω_{01} = ' num2str(sqrt(lambda(1))) ', ω_{02} = ' num2str(sqrt(lambda(2)))])
```
%% Output
Eigene Implementierung: ω_{01} = 541.0232, ω_{02} = 1021.7371
Eingebaute eigs Funktion: ω_{01} = 541.0232, ω_{02} = 1021.7371
%% Cell type:markdown id: tags:
## Hinweise
%% Cell type:markdown id: tags:
1. Mit der (nicht-inversen) Vektoriteration können entsprechend die höchsten Eigenkreisfrequenzen zuerst berechnet werden
%% Cell type:markdown id: tags:
2. Die inverse von-Mises Vektoriteration liefert die betragsmäßig kleinsten Eigenwerte. Mit Hilfe der Skalarverschiebung lässt sich auch die zu einem Zielwert am nächsten befindliche Lösung finden, denn
%% Cell type:markdown id: tags:
*Besitzt eine Matrix $A$ die Eigenwerte $\lambda_1, \lambda_2, \lambda_3, \ldots, \lambda_n$, sodass $(A - \lambda I) q = 0$,*
*dann besitzt die Matrix $B = A + pI$ die Eigenwerte $\lambda_1+p, \lambda_2+p, \lambda_3+p, \ldots, \lambda_n+p$.*
$$
\begin{align*}
B &= A + pI \\
&= M^{-1}K + pI \\
&= M^{-1} \underbrace{(K + pM)}_{K^\prime}
\end{align*}
$$
%% Cell type:markdown id: tags:
Wird also die Eigenkreisfrequenz in der Nähe von $\omega_{ziel}$ gesucht, kann die Steifigkeitsmatrix durch
$$
K^\prime = K - \omega_{ziel}^2 M
$$
modifiziert werden und die inverse Vektoriteration durchgeführt werden. Nach Identifikation des Eigenwertes ist die Verschiebung in der Lösung rückgängig zu machen, d.h. der Lösung ist $\omega_{ziel}$ zu addieren.
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment