-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
70 lines (49 loc) · 1.94 KB
/
main.py
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
# ============================================================================
# Reduce order model for particle pair sedimentation
# Author : Lucka Barbeau, Polytechnique Montréal, 2023
# MAIN PROGRAM
# ============================================================================
import matplotlib.pyplot as plt
import numpy as np
from particle_pair_rom import *
tf.random.set_seed(
42
)
# Initialize the model
rom_model=ROM_2_particles(final_time=0.6,time_step=0.00025)
#Setup the case
# units for length (centimeter), units for time (second), units for mass (Kilograms)
rom_model.gravity=np.array([0,0,-1000])
rom_model.fluid.rho=0.0001
rom_model.fluid.mu=0.000175
rom_model.particle1.position=np.array([0.0,0.0,0])
rom_model.particle2.position=np.array([0.0,0.5,2.0])
rom_model.particle1.rho=0.001
rom_model.particle2.rho=0.001
rom_model.particle1.diameter=1.0
rom_model.particle2.diameter=1.0
### uncomment to run with relative velocity force model
#rom_model.model_relative_velocity=1.0
#Update the particle state with the variables
rom_model.particle1.update()
rom_model.particle2.update()
# Run the case
output=rom_model.run()
# Graph results
fig1 = plt.figure()
ax1 = fig1.add_subplot()
ax1.plot(output.time_table,output.vectorize_components(output.p1_velocity,1),label=r"$P_0$ ROM", color='k')
ax1.plot(output.time_table,output.vectorize_components(output.p2_velocity,1),label=r"$P_1$ ROM", color='b')
ax1.set_xlabel(r"t (s)")
ax1.set_ylabel(r"$v_y$ $\frac{cm}{s}$")
ax1.legend()
fig1.tight_layout()
fig2 = plt.figure()
ax2 = fig2.add_subplot()
ax2.plot(output.time_table,output.vectorize_components(output.p1_velocity,2),label=r"$P_0$ ROM", color='k')
ax2.plot(output.time_table,output.vectorize_components(output.p2_velocity,2),label=r"$P_1$ ROM", color='b')
ax2.set_xlabel(r"t (s)")
ax2.set_ylabel(r"$v_z$ $\frac{cm}{s}$")
ax2.legend()
fig2.tight_layout()
plt.show()