METHOD FOR OPTIMIZING WEIGHT OF DISC SPRING

Information

  • Patent Application
  • 20230401359
  • Publication Number
    20230401359
  • Date Filed
    June 08, 2023
    a year ago
  • Date Published
    December 14, 2023
    a year ago
Abstract
A method for optimizing a weight of a disc spring includes: determining an objective function for weight optimization of the disc spring and key parameters to be solved; optimizing an original Harris Hawks optimization structure, specifically including: first, eliminating steps of centralized calculation of objective function values of the original Harris Hawks optimization except a step of population initialization, and recording a result when a better solution is obtained; second, introducing a random unit permutation mechanism before an end of each iterative optimization of the original Harris Hawks optimization; third, deleting a step of searching for an energy factor E with an absolute value greater than or equal to 1; and solving the key parameters by means of the optimized Harris Hawks optimization referred to as the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring.
Description
CROSS-REFERENCE TO RELATED APPLICATION

This application claims the priority benefit of China application serial no. 202210643552.9, filed on Jun. 9, 2022. The entirety of the above-mentioned patent application is hereby incorporated by reference herein and made a part of this specification.


BACKGROUND
Technical Field

The invention relates to an optimization method, in particular to a method for optimizing a weight of a disc spring.


Description of Related Art

Disc springs, which are similar to discs in shape and have a good shock-absorption capacity, are widely applied to the elastic suspensions of vehicles, or are used in scenarios requiring shock insulation. The load and deformation of the disc springs are in a nonlinear relation, and the load-deformation curve of the disc springs varies accordingly with the ratio of the height of an inner frustum to the thickness of a steel spring plate. In actual application, the weight of the disc springs needs to be optimized. Weight optimization of the disc springs is regarded as an optimization problem with complex constraints due to its complex mathematical properties and constraints.


Traditionally, this problem is solved through a mathematical method, which excessively relies on the mathematical properties of an optimization model, so when the complexity of the optimization model increases, the solving precision and speed will be reduced, and even the problem cannot be solved. Harris Hawks optimization, as a novel meta-heuristic algorithm proposed in recent years, can effectively overcome the drawbacks of the traditional mathematical method. Harris Hawks optimization is not concerned about the specific mathematical properties of the optimization model and has the advantages of using less parameters, high universality, and the like, thus being widely applied to the optimization field. However, since Harris Hawks optimization is not proposed for weight optimization of disc springs, it has some defects when used for weight optimization of disc springs. First, when Harris Hawks optimization runs, an objective function will be called repeatedly to adjust the search direction of the algorithm, so the objective function at the same position has to be called multiple times, leading to the waste of computation resources; second, the randomness of Harris Hawks optimization during global search is excessively high, leading to a low convergence rate; and finally, due to the insufficient convergence of Harris Hawks optimization during local search, the solving precision of this algorithm is excessively low.


SUMMARY

The technical issue to be settled by the invention is to provide a method for optimizing a weight of a disc spring, which is high in convergence rate and solving precision. According to the method for optimizing the weight of the disc spring, a random unit permutation mechanism is introduced to original Harris Hawks optimization to optimize the Harris Hawks optimization structure to obtain a random unit permutation-based Harris Hawks optimization, which is used to extract key parameters for weight optimization of the disc spring, such that the solving speed and the optimization precision are further improved, optimal parameters are finally solved under the precondition of meeting constraints, and the structural weight of the disc spring is optimized.


The technical solution adopted by the invention to settle the above technical issue is as follows: a method for optimizing the weight of the disc spring comprises the following steps:

    • S1: determining an objective function for weight optimization of the disc spring and key parameters to be solved; and
    • S2: optimizing an original Harris Hawks optimization structure, specifically: first, eliminating steps of centralized calculation of objective function values in the original Harris Hawks optimization except a step of population initialization, and recording a result when a better solution is obtained, to save the calculation time; second, introducing a random unit permutation mechanism before the end of each iterative optimization of the original Harris Hawks optimization to enhance the global search performance; third, deleting a step of searching for an energy factor E with an absolute value greater than or equal to 1 of the original Harris Hawks optimization to reduce the influence of the random unit permutation mechanism on the optimization effect; referring to the optimized Harris Hawks optimization as random unit permutation-based Harris Hawks optimization, and solving the key parameters by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring;
    • Wherein determining the objective function for weight optimization of the disc spring and the key parameters to be solved in S1 specifically comprises:
    • S1.1: determining the objective function for weight optimization of the disc spring, wherein the objective function is shown by formula (1):










F

(
x
)

=


ρ


V

B

S



=


ρ
·

π
4

·

(


D
ot
t

-

D

i

n

n

2


)




t
s







(
1
)









    • Where F(x) is the objective function and represents a weight of the disc spring, which is measured by pound (lb); ρ represents a density of the disc spring, which is measured by pound/cubic inch (lb/in3); VBS is a size of the disc spring, which is measured by cubic inch (in3); π is a circular constant; Dot is an outer diameter of the disc spring, which is measured by inch (in); Dinn is an inner diameter of the disc spring, which is measured by inch (in); ts is a thickness of the disc spring, which is measured by inch (in);

    • S1.2: determining constraints for weight optimization of the disc spring, wherein the constraints are shown by formula (2) to formula (8):














g
1

(
x
)

=


S
-



4

E


δ
max




(

1
-

μ
2


)


α


D
ot
2



[


β

(

h
-


δ
max

2


)

+

γ


t
s



]



0





(
2
)














g
2

(
x
)

=





4

E


δ
max




(

1
-

μ
2


)


α


D
ot
2



[



(

h
-


δ
max

2


)



(

h
-

δ
max


)



t
s


+

t
s
3


]

-

P
max



0





(
3
)














g
3

(
x
)

=



δ
l

-

δ
max



0





(
4
)














g
4

(
x
)

=


H
-
h
-

t
s



0





(
5
)














g
5

(
x
)

=



D
max

-

D
ot



0





(
6
)














g
6

(
x
)

=



D
ot

-

D

i

n

n




0





(
7
)














g
7

(
x
)

=



0
.
3

-

h


D

o

t


-

D

i

n

n






0





(
8
)









    • Where g1(x) is a stress constraint induced by radial compression of the disc spring, g2(x) is a rigidity constraint of the disc spring, g3(x) is a limited deflection constraint of the disc spring, g4(x) is a thickness-height relation constraint of the disc spring, g5(x) is an outer diameter constraint of the disc spring, g6(x) is an outer diameter-inner diameter relation constraint of the disc spring, and g7(x) is a geometric size constraint of the disc spring, h represents the height of the disc spring, which is measured by inch (in); S represents allowable strength of the disc spring, which is measured by kilopound/square inch (kpsi); E represents an elastic modulus of the disc spring, which is measured by pound/square inch (psi); δmax represents the maximum deflection of the disc spring, which is measured by inch (in); μ is a Poisson's ratio of the disc spring; Pmax represents a maximum load of the disc spring, which is measured by pound (lb); H is a maximum limit of the height of the disc spring, which is measured by inch (in); Dmax is a maximum outer diameter of the disc spring, which is measured by inch (in); δl is limited deflection, δl=f(a)h;









a
=

h

t
s






represents a ratio of the height of the disc spring to the thickness of the disc spring; f(a) represents load deformation of the disc spring, which is measured by inch (in); K=Dot/Dinn, and α, β and γ are temporary variables and are calculated by formula (9) to formula (11):









α
=


6

π

lnK




(


K
-
1

K

)






(
9
)












β
=


6

π

lnK




(



K
-
1

lnK

-
1

)






(
10
)












γ
=


6

π

lnK




(


K
-
1

2

)






(
11
)









    • S1.3: determining parameter values in the constraints shown by formula (2) to formula (8), where ρ=0.283 lb/in3, S=200 kpsi, E=30×106 psi, δmax=0.2 in, μ=0.3, Pmax=5400 lb, H=2 in, Dmax=12.01 in, and the relation between a and f(a) is as follows: when a<1.45, f(a)=1; when 1.45≤a<1.55, f(a)=0.85; when 1.55≤a<1.65, f(a)=0.77; when 1.65≤a<1.75, f(a)=0.71; when 1.75≤a<1.85, f(a)=0.66; when 1.85≤a<1.95, f(a)=0.63; when 1.95≤a<2.05, f(a)=0.6; when 2.05≤a<2.15, f(a)=0.58; when 2.15≤a<2.25, f(a)=0.56; when 2.25≤a<2.35, f(a)=0.55; when 2.35≤a<2.45, f(a)=0.53; when 2.45≤a<2.55, f(a)=0.52; when 2.55≤a<2.65, f(a)=0.51; when 2.65≤a<2.75, f(a)=0.51; when a≥2.75, f(a)=0.50; the remaining four parameters, namely the outer diameter Dot of the disc spring, the inner diameter Dinn of the disc spring, the thickness ts of the disc spring, and the height h of the disc spring, are the key parameters to be solved, and meet: 5 in≤Dot≤15 in, 5 in≤Dinn≤15 in, 0.01 in≤ts≤6 in, and 0.05 in≤h≤0.5 in; the key parameters to be solved are represented by a vector X, where a lower bound of X is represented by a vector LB, an upper bound of X is represented by a vector UB, and X, LB and UB are expressed by formula (12) to formula (14):









X=[D
ot
,D
inn
,t
s
,h]  (12)





LB=[5,5,0.01,0.05]  (13)





UB=[15,15,6,0.5]  (14)

    • Where first-dimensional data of LB represents a lower bound of Dot, second-dimensional data of LB represents a lower bound of Dinn, third-dimensional data of LB represents a lower bound of ts, fourth-dimensional data of LB represents a lower bound of h, first-dimensional data of UB represents an upper bound of Dot, second-dimensional data of UB represents an upper bound of third-dimensional data of UB represents an upper bound of ts, and fourth-dimensional data of UB represents an upper bound of h; and
    • S1.4: transforming the objective function shown by formula (1) with the vector X to obtain a final objective function which is expressed by formula (15):






F(X)=0.07075π((X1)2−(X2)2)X3  (15)

    • Where X1 represents first-dimensional data of the vector X, X2 represents second-dimensional data of the vector X, X3 represents third-dimensional data of the vector X, and (·) 2 represents a square operation of data, that is, (X1)2 represents a square operation of X1, and (X2)2 represents a square operation of X2;
    • Solving the key parameters by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring in S2 specifically comprises:
    • S2.1: performing population initialization to obtain an initial population: making the vector X correspond to individuals of a population, wherein the individuals have four dimensions, first-dimensional data of the individuals corresponds to Dot, second-dimensional data of the individuals corresponds to Dinn, third-dimensional data of the individuals corresponds to ts, and fourth-dimensional data of the individuals corresponds to h; setting a population capacity N corresponding to the random unit permutation-based Harris Hawks optimization to 30, randomly initializing 30 individuals according to formula (16) to obtain the initial population:












Pop
=






[




LB
1
1







LB
1
0

















LB
N
1







LB
N
D




]

+







[




rand
1
1







rand
1
D

















rand
N
1







rand
N
D




]



[





UB
1

-

LB
1













UB
N

-

LB
N





]











=



[




X
1
1







X
1
D

















X
N
1







X
N
D




]

=

[




X
1











X
N




]









(
16
)









    • Where LBiij represents a lower bound of jth-dimensional data of the (ii)th individual; randiij represents the jth-dimensional data of the (ii)th individual generated by a random function, which is within [0,1]; ° represents a Hadmard product operator of a matrix, that is, elements at the same position of the matrix are multiplied; UBii=UB, LBii=LB, and Xii represents the (ii)th individual of the initial population; Xii=[Xii1, Xii2, Xii3, Xii4], Xiij represents the jth-dimensional data of the (ii)th individual, ii=1, 2, . . . , 30, and j=1, 2, 3, 4;

    • S2.2: evaluating the initial population: calculating an objective function value of each individual in the initial population according to the objective function shown by formula (15), and determining each individual in the initial population according to the constraints in formula (2) to formula (8); if the current individual fails to meet all the constraints, updating this individual by randomly reassigning each of the dimensional data, within a range of the upper bound and the lower bound corresponding to each of the dimensional data, of the individual, and after the current individual is updated, directly setting the objective function value of this individual to 1010 rather than calculating the objective function value of this individual by formula (15); if the current individual meets all the constraints, keeping this individual unchanged, such that a 0-generation population is obtained; denoting the individual having a minimum objective function value among all individuals meeting all the constraints in the 0-generation population as gBest, denoting the objective function value of the individual gBest as F(gBest), setting a global optimal individual of the (ii)th individual, and denoting the global optimal individual of the (ii)th individual as pBestii; initializing the value of pBestii with Xii in the 0-generation population, and denoting an objective function value of pBestii as F(pBestii);

    • S2.3: setting an iteration variable t, a maximum iteration T, initializing the iteration variable t to 1, and setting the maximum iteration T to 1000;

    • S2.4: performing a tth iteration on the population to obtain a t-generation population, which specifically comprises:

    • S2.4.1: setting an individual number i, and initializing the individual number i to 1;

    • S2.4.2: updating an ith individual to obtain the ith individual Xi(t) of the t-generation population, which specifically comprises:

    • S2.4.2.1: setting an energy factor for the tth iteration of the ith individual, and calculating the energy factor for the tth iteration of the ith individual, which is used for switching a search mode of the algorithm:













E
f

t
i


=

2



E
0

t
i


·

(

1
-

t
T


)







(
17
)









    • Where E0ti represents a random number for the tth iteration of the ith individual and is generated by a random function, −1≤E0ti≤1;

    • S2.4.2.2: if |Efti|<1, performing S2.4.2.3; if |Efti|≥1, setting the value of Xi(t) to Xi(t−1), then performing S2.4.2.4, where Xi(t−1) is an ith individual of a (t−1)-generation population, and | | is an absolute value sign;

    • S2.4.2.3: generating a random number qti by the random function, wherein 0≤qti≤1; if qti≥0.5 and |Efti|≥0.5, updating the ith individual according to formula (18) to obtain Xi(t); if qti<0.5 and |Efti|≥0.5, updating the ith individual according to formula (23) to obtain Xi(t); if qti≥0.5 and |Efti|<0.5, updating the ith individual according to formula (24) to obtain Xi(t); if qti<0.5 and |Efti|<0.5, updating the ith individual according to formula (28) to obtain Xi(t); after Xi(t) is obtained according to formula (18), (23), (24) or (28), calculating an objective function value of Xi(t) according to formula (15); if the objective function value of Xi(t) is less than an objective function value of Xi(t−1), remaining Xi(t) unchanged; if the objective function value of Xi(t) is greater than the objective function value of Xi(t−1), updating Xi(t) to Xi(t−1), substituting data of Xi(t) into formula (2) to formula (8), and determining whether Xi(t) meets the constraints in formula (2) to formula (8); if so, remaining Xi(t) unchanged; otherwise, updating Xi(t) again, reassigning each of the dimensional data, within a range of the upper bound and the lower bound corresponding to each of the dimensional data, of Xi(t), and after Xi(t) is updated, directly setting the objective function value F(Xi(t)) of Xi(t) to 1010 rather than calculating the objective function value F(Xi(t)) according to formula (15);














X
i

(
t
)

=

gBest
-


X
i

(

t
-
1

)

-


E
f

t
i






"\[LeftBracketingBar]"


(



J

t
i


·
gBest

-


X
i

(

t
-
1

)


)



"\[RightBracketingBar]"








(
18
)













J

t
i


=

2


(

1
-

r
1

t
i



)






(
19
)













A

t
i


=

gBest
-


E
f

t
i






"\[LeftBracketingBar]"




J

t
i


·
gBest

-


X
i

(

t
-
1

)




"\[RightBracketingBar]"








(
20
)













B

t
i


=


A

t
i


+


R


t
i





L


F

(
D
)







(
21
)














LF

(
D
)

=



r
2

r
i


×
σ





"\[LeftBracketingBar]"


r
3

t
i




"\[RightBracketingBar]"


θ



,

σ
=


(



Γ

(

1
+
θ

)

×

sin

(


π

θ

2

)




Γ

(


1
+
θ

2

)

×
θ
×
2


(


θ
-
1

2

)



)


1
θ







(
22
)














X
i

(
t
)

=

{




A

t
i






if



F

(

A

t
i


)


<

F

(

B

t
i


)







B

t
i






if



F

(

A

t
i


)




F

(

B

t
i


)










(
23
)














X
i

(
t
)

=

gBest
-


E
f

t
i






"\[LeftBracketingBar]"


gBest
-


X
i

(

t
-
1

)




"\[RightBracketingBar]"








(
24
)













Y

t
i


=

gBest
-


E
f

t
i






"\[LeftBracketingBar]"




J

t
i


·
gBest

-

Mean

t
i





"\[RightBracketingBar]"








(
25
)













Mean

t
i


=


1
N









n

u

m

=
1

N




X

n

u

m


(

t
-
1

)






(
26
)













Z

t
i


=


Y

t
i


+


R


t
i





L


F

(
D
)







(
27
)














X
i

(
t
)

=

{




Y

t
i






if



F

(

Y

t
i


)


<

F

(

Z

t
i


)







Z

t
i






if



F

(

Y

t
i


)




F

(

Z

t
i


)










(
28
)









    • Where Xi(t) represents the ith individual of the t-generation population, Ati, Bti, Yti, Zti represent four intermediate individuals generated for the ith individual during the tth iteration, | | represents an absolute value sign, the value of 0 is 1.5, r1ti represents a first one-row D-dimensional random number vector generated for the ith individual by the tth iteration, each of the dimensional data of the first one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1, r2ti represents a second one-row D-dimensional random number vector generated for the ith individual by the tth iteration, each of the dimensional data of the second one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1, represents a third one-row D-dimensional random number vector generated for the ith individual by the tth iteration, each of the dimensional data of the third one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1, Jti represents a random number generated for the ith individual by the tth iteration and is used for disturbing a current optimal individual to improve the diversity of the population, LF is a levy flight function, Meanti represents a mean value of Xi(t−1), X2(t−1), . . . , XN(t−1) when the ith individual is solved by the tth iteration, and is expressed by formula (26), Γ is a gamma function, Rti represents the one-column D-dimensional random number vector generated for ith individual by the tth iteration, and each of the dimensional data of the one-column D-dimensional random number vector has a lower bound 0 and an upper bound 1; if the objective function value F(Xi(t)) of Xi(t) is set to 1010, the objective function value F(Xi(t)) of Xi(t) is obtained directly; if the objective function value F(Xi(t)) of Xi(t) is not set to 1010, the objective function value F(Xi(t)) of Xi(t) is calculated according to formula (15); then, if F(Xi(t))<F(gBest), a variable value of gBest is updated to Xi(t); otherwise, the variable value of gBest is not updated; if F(Xi(t))<F(pBesti), a variable value of pBesti is updated to Xi(t); otherwise, the variable value of pBesti is not updated; up to now, Xi(t) is updated, and S2.4.2.4 is performed;

    • S2.4.2.4: setting four intermediate individuals M1ti, M2ti, SM1ti and SM2ti, and calculating M1ti and M2ti according to formula (29) and formula (30);













M


1

t
i



=



k
1

t
i


·

(



k
2

t
i


·


X

a
1

t
i



(

t
-
1

)


+


(

~

k
2

t
i



)

·


X

a
2

t
i



(

t
-
1

)



)


+


(

~

k
1

t
i



)

·
gBest






(
29
)













M


2

t
i



=



k
1

t
i


·

(



k
2

t
i


·


X

a
3

t
i



(

t
-
1

)


+


(

~

k
2

t
i



)

·


X

a
4

t
i



(

t
-
1

)



)


+


(

~

k
1

t
i



)

·
gBest






(
30
)









    • Where k1ti is a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; k2ti is a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; ˜ is a bitwise negation operator; the values of a1ti, a2ti, a3ti, a4ti are four different integers within [1, N] except i;

    • Substituting M1ti and M2ti into formula (31) and formula (32) respectively to obtain SM1ti and SM2ti:













SM


1

t
i



=


M


1

t
i



+

2
·

r
4

t
i


·


e


F

(

g

Best

)

-


F

(


X
i

(
t
)

)





(

gBest
-


X
i

(

t
-
1

)


)


+


r
5


t
i




(

gBest
-

pBes


t
i



)






(
31
)













SM


2

t
i



=


M


2

t
i



+

2
·

r
6

t
i


·


e


g

Best

-



X
i

(
t
)





(

gBest
-


X
i

(
t
)


)


+


r
7

t
i


·

(

gBest
-


X
i

(

t
-
1

)


)







(
32
)









    • Where r4ti a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; r5ti is a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; r6ti is a random number generated by the random function, and −1≤r6ti≤1; r7ti is a random function generated by the random function, and −1≤r7ti≤1; r7ti is a Napierian constant, the value of e is 2.718281828459045;

    • Substituting data of SM1ti and data of SM2ti into formula (2) and formula (8) respectively; determining whether SM1ti and SM2ti meet the constraints in formula (2) to formula (8); if either SM1ti or SM2ti fails to meet all the constraints, updating the intermediate individual (SM1ti or SM2ti) not meeting all the constraints, and reassigning each of the dimensional data, between a range of the upper bound and the lower bound corresponding to each of the dimensional data, of the individual, and directly setting an objective function value of this individual to 1010, which is then substituted into formula (33) to obtain an intermediate individual Qti; if SM1ti and SM2ti both meet all the constraints, directly substituting SM1ti and SM2ti into formula (33) to obtain the intermediate individual Qti.













Q

t
i


=

{





S

M


1

t
i



,





if



F

(

S

M


1

t
i



)


<

F

(

S

M


2

t
i



)








S

M


2

t
i



,



else








(
33
)









    • S2.4.2.5: updating Xi(t) to Qti; calculating the objective function value of Xi(t) according to formula (15); if the objective function value of Xi(t) is less than the objective function value of gBest, updating the objective function value of gBest to Xi(t); otherwise, not updating the objective function value of gBest; if the objective function of Xi(t) is less than the objective function value of pBesti, updating pBesti to Xi(t); otherwise, not updating pBesti;

    • S2.4.3: determining whether a current value of i is equal to N; if the current value of i is not equal to N, updating the current value of i to the sum of the current value of i and 1, and then returning to S2.4.2 to update the next individual; if the current value of i is equal to N, completing the tth iteration to obtain N individuals X1(t) to XN(t) of the t-generation population, and performing the next step;

    • S2.4.4: determining whether a current value of t is equal to T; if the current value of t is not equal to T, updating the current value of t to the sum of the current value of t and 1, and then returning to S2.4 to perform the next iteration; if the current value of t is equal to T, performing the next step; and

    • S2.5: outputting the current gBest, and using the current gBest as the key parameters for weight optimization of the disc spring.





Compared with the prior art, the invention has the following beneficial effects: after an objective function for weight optimization of a disc spring and key parameters to be solved are determined, an original Harris Hawks optimization structure is optimized specifically as follows: first, steps of centralized calculation of objective function values of the original Harris Hawks optimization except a step of population initialization are eliminated, and a result is recorded when a better solution is obtained, to save the calculation time; second, a random unit permutation mechanism is introduced before the end of each iterative optimization of the original Harris Hawks optimization to enhance the global search performance; third, a step of searching for an energy factor E with an absolute value greater than or equal to 1 of the original Harris Hawks optimization is deleted to reduce the influence of the random unit permutation mechanism on the optimization effect; the optimized Harris Hawks optimization is referred to as a random unit permutation-based Harris Hawks optimization, and key parameters are solved by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring; in the invention, the random unit permutation-based Harris Hawks optimization is not concerned about the specific mathematical properties of an optimization model, and thus effectively avoids being trapped in local extrema; running of the random unit permutation-based Harris Hawks optimization is limited by the number of iterations, and the resolving time is controllable, so excessively long computation time is prevented; the random unit permutation-based Harris Hawks optimization adopts the random unit permutation mechanism to improve the diversity of populations, so the solving speed and precision are further improved; and the original Harris Hawks optimization structure is optimized to ensure the introduced mechanism to fulfill the optimal effect, so the method has high convergence rate and solving precision, can further optimize the weight of disc springs, and has high application value.





BRIEF DESCRIPTION OF THE DRAWINGS

FIGURE illustrates the simulation results of a method for optimizing a weight of a disc spring according to the invention.





DESCRIPTION OF THE EMBODIMENTS

The invention will be described in further detail below in conjunction with the accompanying drawing and embodiments.


Embodiment: a method for optimizing a weight of a disc spring comprises the following steps:

    • S1: determining an objective function for weight optimization of the disc spring and key parameters to be solved; and
    • S2: optimizing an original Harris Hawks optimization structure, specifically: first, eliminating steps of centralized calculation of objective function values in the original Harris Hawks optimization except a step of population initialization, and recording a result when a better solution is obtained, to save the calculation time; second, introducing a random unit permutation mechanism before the end of each iterative optimization of the original Harris Hawks optimization to enhance the global search performance; third, deleting a step of searching for an energy factor E with an absolute value greater than or equal to 1 of the original Harris Hawks optimization to reduce the influence of the random unit permutation mechanism on the optimization effect; referring to the optimized Harris Hawks optimization as random unit permutation-based Harris Hawks optimization, and solving the key parameters by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring.


In this embodiment, determining the objective function for weight optimization of the disc spring and the key parameters to be solved in S1 specifically comprises:

    • S1.1: determining the objective function for weight optimization of the disc spring, wherein the objective function is shown by formula (1):










F


(
x
)


=


ρ


V

B

S



=


ρ
·

π
4

·

(


D
ot
t

-

D

i

n

n

2


)




t
s







(
1
)









    • Where, F(x) is the objective function and represents a weight of the disc spring, which is measured by pound (lb); ρ represents a density of the disc spring, which is measured by pound/cubic inch (lb/in3); VBS is a size of the disc spring, which is measured by cubic inch (in3); π is a circular constant; Dot is an outer diameter of the disc spring, which is measured by inch (in); Dinn is an inner diameter of the disc spring, which is measured by inch (in); ts is a thickness of the disc spring, which is measured by inch (in);

    • S1.2: determining constraints for weight optimization of the disc spring, wherein the constraints are shown by formula (2) to formula (8):














g
1

(
x
)

=


S
-



4

E


δ
max




(

1
-

μ
2


)


α


D
ot
2



[


β

(

h
-


δ
max

2


)

+

γ


t
s



]



0





(
2
)














g
2

(
x
)

=





4

E


δ
max




(

1
-

μ
2


)


α


D
ot
2



[



(

h
-


δ
max

2


)



(

h
-

δ
max


)



t
s


+

t
s
3


]

-

P
max



0





(
3
)














g
3

(
x
)

=



δ
l

-

δ
max



0





(
4
)














g
4

(
x
)

=


H
-
h
-

t
s



0





(
5
)














g
5

(
x
)

=



D
max

-

D
ot



0





(
6
)














g
6

(
x
)

=



D
ot

-

D

i

n

n




0





(
7
)














g
7

(
x
)

=



0
.
3

-

h


D

o

t


-

D

i

n

n






0





(
8
)







g1(x) is a stress constraint induced by radial compression of the disc spring, g2(x) is a rigidity constraint of the disc spring, g3(x) is a limited deflection constraint of the disc spring, g4(x) is a thickness-height relation constraint of the disc spring, g5(x) is an outer diameter constraint of the disc spring, g6(x) is an outer diameter-inner diameter relation constraint of the disc spring, and g7(x) is a geometric size constraint of the disc spring, h represents the height of the disc spring, which is measured by inch (in); S represents allowable strength of the disc spring, which is measured by kilopound/square inch (kpsi); E represents an elastic modulus of the disc spring, which is measured by pound/square inch (psi); δmax represents the maximum deflection of the disc spring, which is measured by inch (in); μ is a Poisson's ratio of the disc spring; Pmax represents a maximum load of the disc spring, which is measured by pound (lb); H is a maximum limit of the height of the disc spring, which is measured by inch (in); Dmax is a maximum outer diameter of the disc spring, which is measured by inch (in); δl is limited deflection, δl=f(a)h;






a
=

h

t
s






represents a ratio of the height of the disc spring to the thickness of the disc spring; f(a) represents load deformation of the disc spring, which is measured by inch (in); K=Dot/Dinn, and α, β and γ are temporary variables and are calculated by formula (9) to formula (11):









α
=


6

π

lnK




(


K
-
1

K

)






(
9
)












β
=


6

π

lnK




(



K
-
1

lnK

-
1

)






(
10
)












γ
=


6

π

lnK




(


K
-
1

2

)






(
11
)







S1.3: determining parameter values in the constraints shown by formula (2) to formula (8), where ρ=0.283 lb/in3, S=200 kpsi, E=30×106 psi, δmax=0.2 in, μ=0.3, Pmax=5400 lb, H=2 in, Dmax=12.01 in, and the relation between a and f(a) is as follows: when a<1.45, f(a)=1; when 1.45≤a<1.55, f(a)=0.85; when 1.55≤a<1.65, f(a)=0.77; when 1.65≤a<1.75, f(a)=0.71; when 1.75≤a<1.85, f(a)=0.66; when 1.85≤a<1.95, f(a)=0.63; when 1.95≤a<2.05, f(a)=0.6; when 2.05≤a<2.15, f(a)=0.58; when 2.15≤a<2.25, f(a)=0.56; when 2.25≤a<2.35, f(a)=0.55; when 2.35≤a<2.45, f(a)=0.53; when 2.45≤a<2.55, f(a)=0.52; when 2.55≤a<2.65, f(a)=0.51; when 2.65≤a<2.75, f(a)=0.51; when a≥2.75, f(a)=0.50; the remaining four parameters, namely the outer diameter Dot of the disc spring, the inner diameter Dinn of the disc spring, the thickness ts of the disc spring, and the height h of the disc spring, are the key parameters to be solved, and meet: 5 in≤Dot≤15 in, 5 in≤Dinn≤15 in, 0.01 in≤ts≤6 in, and 0.05 in≤h≤0.5 in; the key parameters to be solved is represented by a vector X, where a lower bound of X is represented by a vector LB, an upper bound of X is represented by a vector UB, and X, LB and UB are expressed by formula (12) to formula (14):






X=[D
ot
,D
inn
,t
s
,h]  (12)





LB=[5,5,0.01,0.05]  (13)





UB=[15,15,6,0.5]  (14)

    • Where first-dimensional data of LB represents a lower bound of Dot, second-dimensional data of LB represents a lower bound of Dinn, third-dimensional data of LB represents a lower bound of ts, fourth-dimensional data of LB represents a lower bound of h, first-dimensional data of UB represents an upper bound of Dot, second-dimensional data of UB represents an upper bound of Dinn, third-dimensional data of UB represents an upper bound of ts, and fourth-dimensional data of UB represents an upper bound of h; and
    • S1.4: transforming the objective function shown by formula (1) with the vector X to obtain a final objective function which is expressed by formula (15):






F(X)=0.07075π((X1)2−(X2)2)X3  (15)

    • Where X1 represents first-dimensional data of the vector X, X2 represents second-dimensional data of the vector X, X3 represents third-dimensional data of the vector X, and (·)2 represents a square operation of data, that is, (X1)2 represents a square operation of X1, and (X2)2 represents a square operation of X2.


Solving the key parameters by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring in S2 specifically comprises:

    • S2.1: performing population initialization to obtain an initial population: making the vector X correspond to individuals of a population, wherein the individuals have four dimensions, first-dimensional data of the individuals corresponds to Dot, second-dimensional data of the individuals corresponds to Dinn, third-dimensional data of the individuals corresponds to ts, and fourth-dimensional data of the individuals corresponds to h; setting a population capacity N corresponding to the random unit permutation-based Harris Hawks optimization to 30, randomly initializing 30 individuals according to formula (16) to obtain the initial population:












Pop
=






[




LB
1
1







LB
1
0

















LB
N
1







LB
N
D




]

+







[




rand
1
1







rand
1
D

















rand
N
1







rand
N
D




]



[





UB
1

-

LB
1













UB
N

-

LB
N





]











=



[




X
1
1







X
1
D

















X
N
1







X
N
D




]

=

[




X
1











X
N




]









(
16
)









    • Where, LBiij represents a lower bound of jth-dimensional data of the (ii)th individual; randiij represents the jth-dimensional data of the (ii)th individual generated by a random function, which is within [0,1]; ° represents a Hadmard product operator of a matrix, that is, elements at the same position of the matrix are multiplied; UBii=UB, LBii=LB, and Xii represents the (ii)th individual of the initial population; Xii=[Xii1, Xii2, Xii3, Xii4], Xiij represents the jth-dimensional data of the (ii)th individual, ii=1, 2, . . . , 30, and j=1, 2, 3, 4;

    • S2.2: evaluating the initial population: calculating an objective function value of each individual in the initial population according to the objective function shown by formula (15), and determining each individual in the initial population according to the constraints in formula (2) to formula (8); if the current individual fails to meet all the constraints, updating this individual by randomly reassigning each of the dimensional data, within a range of the upper bound and the lower bound corresponding to each of the dimensional data, of the individual, and after the current individual is updated, directly setting the objective function value of this individual to 1010 rather than calculating the objective function value of this individual by formula (15); if the current individual meets all the constraints, keeping this individual unchanged, such that a 0-generation population is obtained; denoting the individual having a minimum objective function value among all individuals meeting all the constraints in the 0-generation population as gBest, denoting the objective function value of the individual gBest as F(gBest), setting a global optimal individual of the (ii)th individual, and denoting the global optimal individual of the (ii)th individual as pBestii; initializing the value of pBestii with Xii in the 0-generation population, and denoting an objective function value of pBestii as F(pBestii);

    • S2.3: setting an iteration variable t, a maximum iteration T, initializing the iteration variable t to 1, and setting the maximum iteration T to 1000;

    • S2.4: performing a tth iteration on the population to obtain a t-generation population, which specifically comprises:

    • S2.4.1: setting an individual number i, and initializing the individual number i to 1;

    • S2.4.2: updating an ith individual to obtain the ith individual Xi(t) of the t-generation population, which specifically comprises:

    • S2.4.2.1: setting an energy factor for the tth iteration of the ith individual, and calculating the energy factor for the tth iteration of the individual, which is used for switching a search mode of the algorithm:













E
f

t
i


=

2



E
0

t
i


·

(

1
-

t
T


)







(
17
)









    • Where, E0ti represents a random number for the tth iteration of the ith individual and is generated by a random function, −1≤E0ti≤1;

    • S2.4.2.2: if |Efti|<1, performing S2.4.2.3; if |Efti|≥1, setting the value of Xi(t) to Xi(t−1), then performing S2.4.2.4, where Xi(t−1) is an ith individual of a (t−1)-generation population, and | | is an absolute value sign;

    • S2.4.2.3: generating a random number qti by the random function, wherein 0≤qti≤1; if qti≥0.5 and |Efti|≥0.5, updating the ith individual according to formula (18) to obtain Xi(t); if qti≤0.5 and |Efti|≥0.5, updating the ith individual according to formula (23) to obtain Xi(t); if qti≥0.5 and |Efti|<0.5, updating the ith individual according to formula (24) to obtain Xi(t); if qti<0.5 and |Efti|<0.5, updating the ith individual according to formula (28) to obtain Xi(t); after Xi(t) is obtained according to formula (18), (23), (24) or (28), calculating an objective function value of Xi(t) according to formula (15); if the objective function value of Xi(t) is less than an objective function value of Xi(t−1), remaining Xi(t) unchanged; if the objective function value of Xi(t) is greater than the objective function value of Xi(t−1), updating Xi(t) to Xi(t−1), substituting data of Xi(t) into formula (2) to formula (8), and determining whether Xi(t) meets the constraints in formula (2) to formula (8); if so, remaining Xi(t) unchanged; otherwise, updating Xi(t) again, reassigning each of the dimensional data, within a range of the upper bound and the lower bound corresponding to each of the dimensional data, of Xi(t), and after Xi(t) is updated, directly setting the objective function value F(Xi(t)) of Xi(t) to 1010 rather than calculating the objective function value F(Xi(t)) according to formula (15);














X
i

(
t
)

=


g

Best

-


X
i

(

t
-
1

)

-


E
f

t
i






"\[LeftBracketingBar]"


(



J

t
i


·

g

Best


-


X
i

(

t
-
1

)


)



"\[RightBracketingBar]"








(
18
)













J

t
i


=

2


(

1
-

r
1

t
i



)






(
19
)













A

t
i


=


g

Best

-


E
f

t
i






"\[LeftBracketingBar]"




J

t
i


·

g

Best


-


X
i

(

t
-
1

)




"\[RightBracketingBar]"








(
20
)













B

t
i


=


A

t
i


+


R

t
i



°


LF

(
D
)







(
21
)














LF

(
D
)

=



r
2

t
i


×
σ





"\[LeftBracketingBar]"


r
3

t
i




"\[RightBracketingBar]"


θ



,

σ
=


(



Γ

(

1
+
θ

)

×

sin

(

πθ
2

)




Γ

(


1
+
θ

2

)

×
θ
×

2

(


θ
-
1

2

)




)


1
θ







(
22
)














X
i

(
t
)

=

{




A

t
i






if



F

(

A

t
i


)


<

F

(

B

t
i


)







B

t
i






if



F

(

A

t
i


)




F

(

B

t
i


)










(
23
)














X
i

(
t
)

=


g

Best

-


E
f

t
i






"\[LeftBracketingBar]"



g

Best

-


X
i

(

t
-
1

)




"\[RightBracketingBar]"








(
24
)













Y

t
i


=


g

Best

-


E
f

t
i






"\[LeftBracketingBar]"




J

t
i


·

g

Best


-

Mean

t
i





"\[RightBracketingBar]"








(
25
)













Mean

t
i


=


1
N








num
=
1

N




X
num

(

t
-
1

)






(
26
)













Z

t
i


=


Y

t
i


+


R

t
i



°


LF

(
D
)







(
27
)














X
i

(
t
)

=

{




Y

t
i






if



F

(

Y

t
i


)


<

F

(

Z

t
i


)







Z

t
i






if



F

(

Y

t
i


)




F

(

Z

t
i


)










(
28
)









    • Where, Xi(t) represents the ith individual of the t-generation population, Ati, Bti, Yti, Zti represent four intermediate individuals generated for the ith individual during the tth iteration, | | represents an absolute value sign, the value of θ is 1.5, r1ti represents a first one-row D-dimensional random number vector generated for the ith individual by the tth iteration, each of the dimensional data of the first one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1, r2ti represents a second one-row D-dimensional random number vector generated for the ith individual by the tth iteration, each of the dimensional data of the second one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1, r3ti represents a third one-row D-dimensional random number vector generated for the ith individual by the ith iteration, each of the dimensional data of the third one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1, Jti represents a random number generated for the ith individual by the tth iteration and is used for disturbing a current optimal individual to improve the diversity of the population, LF is a levy flight function, Meanti represents a mean value of X1(t−1), X2(t−1), . . . , XN(t−1) when the ith individual is solved by the tth iteration, and is expressed by formula (26), Γ is a gamma function, Rti represents the one-column D-dimensional random number vector generated for ith individual by the tth iteration, and each of the dimensional data of the one-column D-dimensional random number vector has a lower bound 0 and an upper bound 1; if the objective function value F(Xi(t)) of Xi(t) is set to 1010, the objective function value F(Xi(t)) of Xi(t) is obtained directly; if the objective function value F(Xi(t)) of Xi(t) is not set to 1010, the objective function value F(Xi(t)) of Xi(t) is calculated according to formula (15); then, if F(Xi(t))<F(gBest), a variable value of gBest is updated to Xi(t); otherwise, the variable value of gBest is not updated; if F(Xi(t))<F(pBesti), a variable value of pBesti is updated to Xi(t); otherwise, the variable value of pBesti is not updated; up to now, Xi(t) is updated, and S2.4.2.4 is performed;

    • S2.4.2.4: setting four intermediate individuals M1ti, M2ti, SM1ti and SM2ti, and calculating M1ti and M2ti according to formula (29) and formula (30);













M


1

t
i



=



k
1

t
i


·

(



k
2

t
i


·


X

a
1

t
i



(

t
-
1

)


+


(



k
2

t
i



)

·


X

a
2

t
i



(

t
-
1

)



)


+


(



k
1

t
i



)

·

g

Best







(
29
)













M


2

t
i



=



k
1

t
i


·

(



k
2

t
i


·


X

a
3

t
i



(

t
-
1

)


+


(



k
2

t
i



)

·


X

a
4

t
i



(

t
-
1

)



)


+


(



k
1

t
i



)

·
gBest






(
30
)









    • Where k1ti is a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; is a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; ˜ is a bitwise negation operator; the values of a1ti, a2ti, a3ti, a4ti are four different integers within [1, N] except i;

    • Substituting M1ti and M2ti into formula (31) and formula (32) respectively to obtain SM1ti and SM2ti:













SM


1

t
i



=


M


1

t
i



+


2
·

r
4

t
i


·

e


F

(
gBest
)

-

F

(


X
i

(
t
)

)






°

(

gBest
-


X
i

(

t
-
1

)


)


+


r
5

t
i




°

(

gBest
-

pBest
i


)







(
31
)













SM


2

t
i



=


M


2

t
i



+


2
·

r
6

t
i


·

e

gBest
-


X
i

(
t
)






°

(

gBest
-


X
i

(
t
)


)


+


r
7

t
i




°

(

gBest
-


X
i

(

t
-
1

)


)







(
32
)









    • Where r4ti a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; r5ti is a one-row D-dimensional random number vector generated by the random function, and each of the dimensional data of the one-row D-dimensional random number vector has a lower bound 0 and an upper bound 1; r6ti is a random number generated by the random function, and −1≤r6ti≤1; r7ti is a random function generated by the random function, and −1≤r7ti≤1; e is a Napierian constant, the value of e is 2.718281828459045;

    • Substituting data of SM1ti and data of SM2ti into formula (2) and formula (8) respectively; determining whether SM1ti and SM2ti meet the constraints in formula (2) to formula (8); if either SM1ti or SM2ti fails to meet all the constraints, updating the intermediate individual (SM1ti or SM2ti) not meeting all the constraints, and reassigning each of the dimensional data of, between a range of the upper bound and the lower bound corresponding to each of the dimensional data, the individual, and directly setting an objective function value of this individual to 1010, which is then substituted into formula (33) to obtain an intermediate individual Qti; if SM1ti and SM2ti both meet all the constraints, directly substituting SM1ti and SM2ti into formula (33) to obtain the intermediate individual Qti:













Q

t
i


=

{





SM


1

t
i



,





if



F

(

SM


1

t
i



)


<

F

(

SM


2

t
i



)








SM


2

t
i



,



else








(
33
)









    • S2.4.2.5: updating Xi(t) to Qti; calculating the objective function value of Xi(t) according to formula (15); if the objective function value of Xi(t) is less than the objective function value of gBest, updating the objective function value of gBest to Xi(t); otherwise, not updating the objective function value of gBest; if the objective function of Xi(t) is less than the objective function value of pBesti, updating pBesti to Xi(t); otherwise, not updating pBesti;

    • S2.4.3: determining whether a current value of i is equal to N; if the current value of i is not equal to N, updating the current value of i to the sum of the current value of i and 1, and then returning to S2.4.2 to update the next individual; if the current value of i is equal to N, completing the tth iteration to obtain N individuals Xi(t) to XN(t) of the t-generation population, and performing the next step;

    • S2.4.4: determining whether a current value of t is equal to T; if the current value of t is not equal to T, updating the current value of t to the sum of the current value of t and 1, and then returning to S2.4 to perform the next iteration; if the current value of t is equal to T, performing the next step; and

    • S2.5: outputting the current gBest, and using the current gBest as the key parameters for weight optimization of the disc spring.





Simulation results of the method for optimizing the weight of the disc spring are shown in FIGURE. It can be known, based upon FIGURE, that the method for optimizing the weight of the disc spring has high in convergence rate and optimization precision, can solve key parameters for weight optimization of disc springs under the condition of meeting all constraints, so compared with traditional methods, the weight optimization effect of the disc spring is remarkably improved; and the random unit permutation mechanism adopted by the invention can enhance the diversity of populations, thus improving the probability of finding an optimal search space; and the method provided by the invention can reliably solve the problem of weight optimization of disc springs.

Claims
  • 1. A method for optimizing a weight of a disc spring comprising steps: S1: determining an objective function for weight optimization of the disc spring and key parameters to be solved; andS2: optimizing a structure of an original Harris Hawks optimization, wherein first, eliminating steps of centralized calculation of objective function values in the original Harris Hawks optimization except a step of population initialization, and recording a result when a better solution is obtained, to save calculation time; second, introducing a random unit permutation mechanism before an end of each iterative optimization of the original Harris Hawks optimization to enhance global search performance; third, deleting a step of searching for an energy factor E with an absolute value greater than or equal to 1 in the original Harris Hawks optimization to reduce an influence of the random unit permutation mechanism on an optimization effect; referring to an optimized Harris Hawks optimization as a random unit permutation-based Harris Hawks optimization, and solving the key parameters by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring.
  • 2. A method for optimizing the weight of the disc spring according to claim 1, wherein determining the objective function for weight optimization of the disc spring and the key parameters to be solved in S1 comprises steps: S1.1: determining the objective function for weight optimization of the disc spring, wherein the objective function is shown by formula (1):
  • 3. A method for optimizing the weight of the disc spring according to claim 2, wherein solving the key parameters by means of the random unit permutation-based Harris Hawks optimization to obtain the key parameters for weight optimization of the disc spring in S2 comprises: S2.1: performing population initialization to obtain an initial population: making the vector X correspond to individuals of a population, wherein the individuals have four dimensions, first-dimensional data of the individuals corresponds to Dot, second-dimensional data of the individuals corresponds to Dinn third-dimensional data of the individuals corresponds to ts, and fourth-dimensional data of the individuals corresponds to h; setting a population capacity N corresponding to the random unit permutation-based Harris Hawks optimization to 30, randomly initializing 30 individuals according to formula (16) to obtain the initial population:
Priority Claims (1)
Number Date Country Kind
202210643552.9 Jun 2022 CN national