-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathlanchester.py
More file actions
executable file
·71 lines (57 loc) · 1.72 KB
/
lanchester.py
File metadata and controls
executable file
·71 lines (57 loc) · 1.72 KB
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
# (c) 2022 Marcin "szczyglis" Szczygliński
# GitHub page: https://github.com/szczyglis-dev/python-lanchester
# Email: szczyglis@protonmail.com
# Version: 1.0.0
# This package is licensed under the MIT License.
# License text available at https://opensource.org/licenses/MIT
import numpy as np
__version__ = "1.0.0"
def calc_square(R, B, r_s, b_s, t):
R.append(R[t] - b_s * B[t])
B.append(B[t] - r_s * R[t])
return R, B
def calc_linear(R, B, r_l, b_l, t):
R.append(R[t] - b_l * B[t] * R[t])
B.append(B[t] - r_l * B[t] * R[t])
return R, B
def calc_modernized(R, B, r_s, b_s, r_l, b_l, r_f, s_r, b_f, s_b, r_i, b_i, t):
rValue = (
R[t]
- (1 - r_f) * s_b * r_s * B[t] * b_i
- (1 - (1 - r_f) * s_b) * r_l * B[t] * R[t] * b_i
)
bValue = (
B[t]
- (1 - b_f) * s_r * b_s * R[t] * r_i
- (1 - (1 - b_f) * s_r) * b_l * B[t] * R[t] * r_i
)
R.append(rValue)
B.append(bValue)
return R, B
# square law
def square(R0, B0, r_s, b_s, T, dt):
R = [R0,]
B = [B0,]
for t in np.arange(0, T, dt):
calc_square(R, B, r_s, b_s, t)
if R[-1] < 1e-6 or B[-1] < 1e-6:
break
return R, B
# linear law
def linear(R0, B0, r_l, b_l, T, dt):
R = [R0,]
B = [B0,]
for t in np.arange(0, T, dt):
calc_linear(R, B, r_l, b_l, t)
if R[-1] < 1e-6 or B[-1] < 1e-6:
break
return R, B
# modernized model
def modernized(R0, B0, r_l, b_l, r_s, b_s, r_f, s_r, b_f, s_b, r_i, b_i, T, dt):
R = [R0,]
B = [B0,]
for t in np.arange(0, T, dt):
calc_modernized(R, B, r_s, b_s, r_l, b_l, r_f, s_r, b_f, s_b, r_i, b_i, t)
if R[-1] < 1e-6 or B[-1] < 1e-6:
break
return R, B