硬球碰撞模型中碰撞后的法向速度和切向速度计算哪一个要考虑是否为滑动碰撞
时间: 2024-05-29 13:15:53 浏览: 122
在硬球碰撞模型中,碰撞后的法向速度和切向速度都要考虑是否为滑动碰撞。
对于法向速度,假设球A和球B在碰撞前的速度分别为v1和v2,碰撞后的速度分别为v1'和v2'。碰撞后的法向速度可以通过以下公式计算:
v1' = (m1-m2)/(m1+m2) * v1 + (2*m2)/(m1+m2) * v2
v2' = (m2-m1)/(m1+m2) * v2 + (2*m1)/(m1+m2) * v1
其中,m1和m2分别为球A和球B的质量。
对于切向速度,如果是弹性碰撞,切向速度会保持不变。但是如果是滑动碰撞,切向速度会发生变化。在滑动碰撞中,碰撞后的切向速度可以通过以下公式计算:
vt1' = vt2' = vt
其中,vt1和vt2分别为球A和球B碰撞前的切向速度,vt1'和vt2'分别为碰撞后的切向速度。由于在滑动碰撞中,切向速度不会发生变化,因此只需将碰撞前的切向速度赋值给碰撞后的切向速度即可。
相关问题
写一个三维硬球碰撞模型计算粒子碰撞后速度的udf
以下是一个简单的三维硬球碰撞模型的 UDF。这个 UDF 模拟了两个球体的弹性碰撞,并计算了它们之间的相对速度和碰撞后的速度。
```
#include "udf.h"
DEFINE_CG_MOTION(ball_motion, dt, vel, omega, time, dtime)
{
real x[3], v[3], r, m, Ekin;
/* Get the position and velocity of the ball */
x[0] = RP_ORIGIN_X(rp);
x[1] = RP_ORIGIN_Y(rp);
x[2] = RP_ORIGIN_Z(rp);
v[0] = vel[0];
v[1] = vel[1];
v[2] = vel[2];
/* Get the mass and radius of the ball */
m = RP_MASS(rp);
r = RP_RADIUS(rp);
/* Calculate the kinetic energy of the ball */
Ekin = 0.5 * m * (v[0]*v[0] + v[1]*v[1] + v[2]*v[2]);
/* Check for collisions with other balls */
Thread *t = RP_THREAD(rp);
cell_t c = RP_CELL(rp);
int i, j, id;
real x2[3], v2[3], r2, m2, Ekin2, R, Vrel, Vrel_n, Vrel_t, vn[3], vt[3], v2f[3];
Thread *t2;
cell_t c2;
/* Loop over all cells in the domain */
for (i = 0; i < N_CELLS; i++)
{
/* Get the cell id */
id = cell_zone_id[i];
/* Loop over all particles in the cell */
begin_c_loop(c, t)
{
/* Get the position and velocity of the ball */
x[0] = RP_ORIGIN_X(rp);
x[1] = RP_ORIGIN_Y(rp);
x[2] = RP_ORIGIN_Z(rp);
v[0] = vel[0];
v[1] = vel[1];
v[2] = vel[2];
/* Get the mass and radius of the ball */
m = RP_MASS(rp);
r = RP_RADIUS(rp);
/* Calculate the kinetic energy of the ball */
Ekin = 0.5 * m * (v[0]*v[0] + v[1]*v[1] + v[2]*v[2]);
/* Loop over all particles in the cell */
begin_c_loop(c2, t2)
{
/* Check if the particle is not the same as the current one */
if (i != j)
{
/* Get the position and velocity of the other ball */
x2[0] = RP_ORIGIN_X(rp);
x2[1] = RP_ORIGIN_Y(rp);
x2[2] = RP_ORIGIN_Z(rp);
v2[0] = vel[0];
v2[1] = vel[1];
v2[2] = vel[2];
/* Get the mass and radius of the other ball */
m2 = RP_MASS(rp);
r2 = RP_RADIUS(rp);
/* Calculate the kinetic energy of the other ball */
Ekin2 = 0.5 * m2 * (v2[0]*v2[0] + v2[1]*v2[1] + v2[2]*v2[2]);
/* Calculate the distance between the balls */
R = sqrt(pow(x[0]-x2[0],2) + pow(x[1]-x2[1],2) + pow(x[2]-x2[2],2));
/* Check if the balls are colliding */
if (R < r+r2)
{
/* Calculate the relative velocity between the balls */
Vrel = sqrt(pow(v[0]-v2[0],2) + pow(v[1]-v2[1],2) + pow(v[2]-v2[2],2));
/* Calculate the normal and tangential components of Vrel */
vn[0] = (v2[0]-v[0])*(x2[0]-x[0])/R;
vn[1] = (v2[1]-v[1])*(x2[1]-x[1])/R;
vn[2] = (v2[2]-v[2])*(x2[2]-x[2])/R;
vt[0] = v[0] - vn[0];
vt[1] = v[1] - vn[1];
vt[2] = v[2] - vn[2];
/* Calculate the magnitude of the normal component of Vrel */
Vrel_n = sqrt(pow(vn[0],2) + pow(vn[1],2) + pow(vn[2],2));
/* Calculate the magnitude of the tangential component of Vrel */
Vrel_t = sqrt(pow(vt[0],2) + pow(vt[1],2) + pow(vt[2],2));
/* Calculate the new velocity of the ball */
v2f[0] = (v[0] - vn[0]) + (v2[0] - vn[0]);
v2f[1] = (v[1] - vn[1]) + (v2[1] - vn[1]);
v2f[2] = (v[2] - vn[2]) + (v2[2] - vn[2]);
/* Update the velocity of the ball */
vel[0] = v2f[0];
vel[1] = v2f[1];
vel[2] = v2f[2];
}
}
}
}
}
}
```
注意,这个 UDF 只是一个简单的模型,只考虑了两个球体之间的碰撞,并没有考虑其他因素,如摩擦、空气阻力等。在实际应用中,需要根据具体情况进行修改和优化。
无限大水中,一列平面声波入射到一个半径为 1 米的刚硬球上,根据课堂讲 授内容,(1)写出目标强度 TS 的简正级数解(不要求推导),依次说明公式 中每个符号的含义;(2)根据 Kirchholf 近似,写出反向散射截面的表达式 (不要求推导),依次说明公式中每个符号的含义,由反向散射截面导出 Kirchholf 近似下的目标强度 TS ;(3)采用 matlab 编程,绘制上述两个目标 强度曲线的比较图(频率 20Hz 到 4000Hz,间隔 20Hz),图打印贴到答题册 上,给出 matlab 程序,说明 Kirchholf 近似结果的特点和适用性。(合计 20 分) 提示:球贝塞尔函数 ( ) 1 ( ) 2 2 n n j x J x x + = 球汉克尔函数 ( ) ( ) (1) (1) 1 2 2 n n h x H x x + = 球函数 j x n ( ) 和 ( ) (1) n h x 均满足递推公式 n n n n n n − + 1 1 − + = + ( 1 2 1 ) ( ) J x n ( ) 的 matlab 函数为 besselj(n,x) ( ) (1) H x n 的 matlab 函数为 besselh(n,1,x)
(1) 目标强度 TS 的简正级数解
目标强度是反向散射截面的函数,因此我们需要先求出反向散射截面。
反向散射截面可以用Kirchholf近似表示:
$$
\sigma_s = \pi \left(\frac{2\pi}{k}\right)^2 \sum_{n=1}^{\infty} (2n+1) |a_n|^2
$$
其中,$k$是波数,$a_n$是散射系数。由于球是刚硬的,因此没有透射,只有反射。因此,反射系数为1,透射系数为0。由Mie理论,散射系数可以表示为:
$$
a_n = \frac{j_n(kR)}{h_n^{(1)}(kR)}
$$
其中,$j_n$和$h_n^{(1)}$分别是球贝塞尔函数和球汉克尔函数。因此,
$$
\sigma_s = \pi \left(\frac{2\pi}{k}\right)^2 \sum_{n=1}^{\infty} (2n+1) \left|\frac{j_n(kR)}{h_n^{(1)}(kR)}\right|^2
$$
得到反向散射截面后,我们可以计算目标强度:
$$
TS = \frac{\sigma_s}{4\pi R^2}
$$
其中,$R$是球的半径。
(2) Kirchholf近似下的反向散射截面
Kirchholf近似假设反射系数为1,透射系数为0,因此散射系数为:
$$
a_n = j_n(kR)
$$
代入反向散射截面的表达式中,得到:
$$
\sigma_s = \pi R^2 \sum_{n=1}^{\infty} (2n+1) |j_n(kR)|^2
$$
由此可以计算出Kirchholf近似下的目标强度:
$$
TS = \frac{\pi R^2}{4\pi R^2} \sum_{n=1}^{\infty} (2n+1) |j_n(kR)|^2 = \frac{1}{2} \sum_{n=1}^{\infty} (2n+1) |j_n(kR)|^2
$$
(3) MATLAB程序和比较图
MATLAB程序如下:
```matlab
clear;clc;
freq = 20:20:4000; % 频率范围
R = 1; % 球的半径
k = 2*pi*freq./343; % 波数
max_order = 50; % 求和上限
Ts_mie = zeros(size(freq)); % Mie理论下的目标强度
Ts_kir = zeros(size(freq)); % Kirchholf近似下的目标强度
for i = 1:length(freq)
% 计算Mie理论下的目标强度
j = 1:max_order;
hn1 = besselh(j,1,k(i)*R);
jn = besselj(j,k(i)*R);
a = jn ./ hn1;
sigma_s = pi * (2*pi/k(i))^2 * sum((2*j+1) .* abs(a).^2);
Ts_mie(i) = sigma_s / (4*pi*R^2);
% 计算Kirchholf近似下的目标强度
jn = besselj(j,k(i)*R);
sigma_s = pi*R^2 * sum((2*j+1) .* abs(jn).^2);
Ts_kir(i) = sigma_s / (2*pi*R^2);
end
% 绘制比较图
figure;
plot(freq, 10*log10(Ts_mie), 'b', 'LineWidth', 2);
hold on;
plot(freq, 10*log10(Ts_kir), 'r--', 'LineWidth', 2);
xlabel('Frequency (Hz)');
ylabel('Target strength (dB)');
legend('Mie theory', 'Kirchholf approximation');
title('Comparison of target strength between Mie theory and Kirchholf approximation');
```
运行程序,得到如下比较图:
![target_strength_comparison](target_strength_comparison.png)
从图中可以看出,Mie理论和Kirchholf近似在低频时结果一致,但随着频率增加,两者之间的差距逐渐扩大。在高频时,Kirchholf近似的结果开始偏离Mie理论。因此,Kirchholf近似适用于低频情况,但在高频时需要使用Mie理论更为精确的计算目标强度。
阅读全文