How to transform a nonlinear velocity field to a new frame of reference?
1 回表示 (過去 30 日間)
古いコメントを表示
Example:
Velocity Field:
v =
- x*sin(C*t) - y*(w/2 - cos(C*t))
y*sin(C*t) + x*(w/2 + cos(C*t))
0
The linear velocity field can be written as:
X = [x,y,z];
A = [-sin(C*t), cos(C*t) - w/2,0; cos(C*t) + w/2 , sin(C*t),0;0,0,0;];
v = A*transpose(X);
Transformation (Observer change):
where data:image/s3,"s3://crabby-images/43eab/43eab6d61bdd0ac755ecebf783b0bb9ea0a06e08" alt=""
data:image/s3,"s3://crabby-images/29dd7/29dd79c9e55df809a722ddc161d30884e5ee8ee6" alt=""
data:image/s3,"s3://crabby-images/43eab/43eab6d61bdd0ac755ecebf783b0bb9ea0a06e08" alt=""
Q = [cos(C/2*t),sin(C/2*t),0;-sin(C/2*t),cos(C/2*t),0;0,0,1];
Based on continuum mechanics, velocity field transforms as
. Applying this formula as:
data:image/s3,"s3://crabby-images/29b3b/29b3bf46c9cd14f7f2af9745a337fb00b6eb46b9" alt=""
vy = diff(Q,t,1)*transpose(X) + Q*v;
I do not get the correct answer. I believe that is because v
and
are still in the old frame. If I change them to the new frame it works. The procedure I used is as follows:
data:image/s3,"s3://crabby-images/6877f/6877fd13338d0b7b519df7b9754aea3bcac0abda" alt=""
data:image/s3,"s3://crabby-images/3c5a6/3c5a639bed22fded0bcc185084a9b9c969cc23e5" alt=""
If
is also linear, then it can be written as:
data:image/s3,"s3://crabby-images/09ee4/09ee4e6d11629d0793ede95da67a28d21e1929aa" alt=""
data:image/s3,"s3://crabby-images/d00a9/d00a960c62e776446bdec0a7f4a6d84ff6866d0d" alt=""
Then B is computed as:
Qtr = transpose(Q); assume(Qtr,'real')';
Q*(A*Qtr - diff(Qtr,t,1))
and it works. However, now the problem is that, I can not define A and B for nonlinear velocity fields, for numerical velocity fields not possible at all, so what do I do? How do I transform a velocity field with a given observer change?
0 件のコメント
回答 (0 件)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!