Multi-task joint computing unloading and resource allocation method based on D2D communication

Information

  • Patent Grant
  • 11838930
  • Patent Number
    11,838,930
  • Date Filed
    Monday, January 16, 2023
    a year ago
  • Date Issued
    Tuesday, December 5, 2023
    a year ago
Abstract
The present disclosure discloses a multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication. For solving the problems that computing resources of a local terminal cannot complete all computing tasks on time when there are multiple computing tasks with delay requirements on a local terminal, the method introduces a computing unloading mechanism to reduce the delay and the overhead of the local terminal itself. The method is based on a D2D communication technology. In the scenario where mobile terminals are densely distributed, the local terminal can unload the computing tasks at the same time to several surrounding idle terminals for processing. According to the method, a total overhead objective function is established in consideration of the task delay, energy consumption, and unloading fee.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

The application claims priority to Chinese patent application No. 202210101461.2, filed on Jan. 27, 2022, the entire contents of which are incorporated herein by reference.


TECHNICAL FIELD

The present disclosure relates to the technical field of communication, and in particular to a multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication.


BACKGROUND

The rapid development of mobile networks and smart devices provides a large number of service applications for people's daily life, but at the same time, these applications also produce a large number of computing-intensive tasks. Especially with the emergence of virtual reality, face recognition, and environmental interactive applications, the limited computing power of mobile terminal equipment is difficult to meet complex tasks with a large amount of computation and delay sensitivity. Mobile edge computing (MEC) is considered as an effective technology to address this challenge. MEC provides cloud computing capability in the radio access network (RAN) and connects users directly to the nearest edge computing server, which allows the needs of users to be met at any time and at any place. By unloading tasks to the edge computing server connected to the base station, users can get a better application experience. MEC servers have relatively high computing power, can complete tasks in a short time, and return the results to users.


In practice, mobile terminals are densely distributed, and each equipment has certain computing power. Users with relatively low computing power can unload their tasks to surrounding idle devices through device-to-device (D2D) communication. Compared with a MEC unloading scheme, the D2D technology can further enhance the user experience, make full use of the collaboration between mobile users, and effectively relieves the pressure on cellular networks in crowded scenes. In the scenario where user terminals have multi-task computing requirements, a reasonable task unloading decision and resource allocation scheme can effectively reduce the user's expenses.


SUMMARY

The present disclosure is aimed at providing a multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication. The local terminal unloads several computing tasks generated by itself to several surrounding idle terminals at the same time, and the method is applied to reduce the overhead of the task delay, the energy consumption of the local terminal, and other aspects.


To realize the above function, the multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication disclosed by the present disclosure executes the following steps according to a preset period to unload the computing tasks on the local terminal to all idle terminals with idle computing resources around the local terminal and realize the allocation of the computing tasks of the local terminal with the minimum total overhead.


S1. The idle terminals in a preset range are detected by taking the local terminal as the center, and the computing power fn, energy consumption pricing φn, maximum allowable energy consumption Emaxn, and channel state gn of the idle terminals are obtained, where n∈{1,2, . . . , N}, and N represents the total number of idle terminals.


S2. Based on the execution mode of the computing tasks on the local terminal, decision samples are constructed.


S3. Respectively for the decision samples, based on the processing delay function tm of the computing tasks, where m∈{1,2, . . . , M}, M represents the total number of computing tasks, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks, the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples, where n∈{1,2, . . . , N}, N represents the total number of idle terminals, and the fee charging function for the idle terminals respectively receiving the computing tasks of the local terminal, the total overhead objective function and constrain conditions of the local terminal corresponding to the decision samples is determined.


S4. Respectively for the decision samples, the upper limit of the transmission delay between the local terminal corresponding to the decision samples and the idle terminals and the lower limit of the delay between the local terminal and the idle terminals are calculated, and the optimal transmission delay function corresponding to the decision samples is determined under constraint conditions:


respectively for the decision samples, the total overhead of the local terminal corresponding to the decision samples is calculated based on the total overhead objective function and constraint conditions of the local terminal corresponding to the decision samples and the optimal transmission delay function corresponding to the decision samples under the constraint conditions.


S5. The decision samples that minimize the total overhead of the local terminal are selected with the goal of minimizing the total overhead of the local terminal through a preset number of iterations, and the allocation of the computing tasks on the local terminal is completed based on the decision samples.


A preferred technical scheme of the invention is as follows: the specific steps of constructing decision samples in step S2 are as follows:

    • S21, computing tasks on a local terminal are represented by a set Γ={T1, T2, . . . TM}, wherein the total number of the computing tasks is represented by M; the attributes of the computing tasks are represented by a set {Cm, Dm, Lm}, wherein Cm represents the total number of CPU cycles required to process the computing tasks, Dm represents the data volume of the computing tasks, Lm represents the maximum delay allowed by the computing tasks, wherein m∈{1,2, . . . , M}, and M represents the total number of computing tasks;
    • S22, idle terminals are sorted and numbered in descending order according to channel gains thereof, the channel gains of the idle terminals satisfy the requirement of g1≥ . . . ≥gn≥ . . . ≥gN, wherein gn represents the channel gain of one of the idle terminals, n∈{1,2, . . . , N}, N represents the total number of idle terminals, and the idle terminals are presented by a set Λ={1,2, . . . , N};
    • S23, respectively for one computing task Tm among the computing tasks on the local terminal, wherein m∈{1,2, . . . , M}, and M represents the total number of computing tasks, the execution mode of the computing task Tm is constructed as follows:
    • {xm,0, xm,1, . . . , xm,n, . . . , xm,N}
    • where xm,n represents the execution mode of the computing task Tm, wherein n∈{1,2, . . . , N}, N represents the total number of idle terminals, xm,0=1 represents that the computing task Tm is processed at the local terminal, xm,0=0 represents that the computing task Tm is not processed at the local terminal, xm,n=1 represents that computing task Tm is unloaded to the idle terminal n for processing, xm,n=0 represents that the computing task Tm is not processed on the idle terminal n, and the execution mode of each computing task in computing task sets on the local terminal satisfies Σn=0Nxm,n=1; and
    • S24, respectively for the computing tasks on the local terminal, the decision samples are constructed based on the execution mode of the computing tasks on the local terminal, each of the decision samples is represented by a matrix A with M rows and N+1 columns, and the matrix A is as follows:






A
=

(




x

1
,
0





x

1
,
1





x

1
,
2








x

1
,
N







x

2
,
0





x

2
,
1





x

2
,
2








x

2
,
N
























x

M
,
0





x

M
,
1





x

M
,
2








x

M
,
N





)







    • wherein the first column in the matrix A represents the execution condition of the computing tasks on the local terminal, and the second column to the (N+1)-th column represent the execution condition of the computing tasks unloaded to the idle terminals.





A preferred technical scheme of the invention is as follows: the specific steps of determining the total overhead objective function and constraint conditions of the local terminal in step 3 are as follows:

    • S31, respectively for each decision sample, the number of computing tasks on the local terminal and the idle terminals is represented by a set {K0, K1, . . . , KN}, and the computing tasks on the local terminal are arranged in descending order according to the maximum allowable delay Lm, and are represented by a set S0={S0,1, S0,2, . . . , S0,K0}; the computing tasks on the idle terminal n are arranged in descending order according to the maximum allowable delay Lm, and are represented by a set Sn={Sn,1, Sn,2, . . . , Sn,Kn};
    • S32, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks is calculated, and the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples are as follows:

      Elocm=1Mxm,0μCm
      Entran=ttran·Ptot
    • where μ represents the energy consumed in each CPU cycle, ttran represents the transmission time for the local terminal to unload the computing tasks to the idle terminals, and Ptot represents the minimum total transmission power of the local terminal;
    • wherein the decision x is executed based on the computing tasks corresponding to the decision samples, and the relationship between the transmission time ttran for the local terminal to unload the computing tasks to the idle terminals and the minimum total transmission power Ptot of the local terminal is as follows:








P
tot

(

x
,

t
tran


)

=



Wn
0






n
=
1

N




(


1

g
n


-

1

g

n
-
1




)



2


1


t
tran


W







k
=
n

N






m
=
1

M




x

m
,
k




D
m









-


Wn
0


g
N









    • where gn represents the n-th idle terminal, gn-1 represents the (n−1)-th idle terminal, gN represents the N-th idle terminal, and gn-1≥gn≥gN, W represents the bandwidth of a transmission channel, n0 represents the power spectral density of white noise, and k represents the serial number of the idle terminal;

    • S33, one computing task Tm among the computing tasks on the local terminal is unloaded to the idle terminal n, and the expression of the processing delay tm of the computing task Tm is as follows:










t
m

=

{







i
=

S

0
,
1





S
0

(
m
)





C
i


f
loc








x

m
,
n


=
1

,

n
=
0








t
tran

+




i
=

S

n
,
1





S
n

(
m
)





C
i


f
n









x

m
,
n


=
1

,

n

A












    • where floc represents the computing power of the local terminal, fn represents the computing power of the idle terminals, Sn(m) represents the position of the computing task Tm in the set Sn, S0(m) represents the position of the computing task Tm in the set S0 and i represents the serial number of the computing tasks in the set S0 or the Sn;

    • S34, a fee-charging function Monn for the idle terminals respectively receiving the computing tasks of the local terminal is calculated as follows:

      Monnn log2(1+Σi=Sn,1Sn,KnμCi)

    • where φn represents the pricing of unit energy consumption of the idle terminal n;

    • S34, based on the processing delay tm of the computing task Tm, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks, the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples, and the fee-charging function Monn for the idle terminals respectively receiving the computing tasks of the local terminal, the total overhead objective function of the local terminal corresponding to the decision samples is determined as follows:











minimize

x
,

t
tran





α

max


t
m


+

β

(


E
loc

+

E
n
tran


)

+

γ





n
=
1

N



Mon
n









    • constraint conditions are as follows:

    • (1) tm≤Lm ∀m∈{1, 2, . . . , M}

    • (2) Σm=Sn,1Sn,Kn μCm≤Emaxn ∀n∈Λ

    • (3) Ptot≤Pmax

    • (4) α+β+γ=1

    • (5) α, β, γ∈(0, 1), ttran>0, xm,n∈{0,1}

    • where Pmax represents the maximum transmission power of the local terminal, Emaxn represents the maximum allowable energy consumption of the idle terminal n, and α, β, and γ respectively represent the weight coefficients of the local terminal for the processing delay, the energy consumption, and the fee charging corresponding to the idle terminals respectively receiving the computing tasks of the local terminal.





A preferred technical scheme of the invention is as follows: the specific steps of determining the optimal transmission delay function corresponding to the decision samples in step S4 are as follows:

    • S41. respectively for each decision sample, the upper limit ttranup of transmission delay between the local terminal and the idle terminals is calculated as follows:







t
tran
up

=


min

n

Λ



{

Δ
n

}








    • where Δn represents the upper limit of the transmission delay between the local terminal and the idle terminal n and is specifically shown in the following formula:










Δ
n

=


min

m


S
n




{


L
m

-

t
m



}








    • where t′m represents the delay of the computing task Tm on the local terminal or the idle terminals, and is specifically shown in the following formula:










t
m


=

{







i
=

S

0
,
1





S
0

(
m
)





C
i


f
loc







x

m
,
0


=
1









i
=

S

n
,
1





S
n

(
m
)





C
i


f
n








x

m
,
n


=
1

,

n

Λ












    • S42, based on the maximum transmission power Pmax of the local terminal, the lower limit ttranlow of transmission delay between the local terminal and the idle terminals is calculated according to the following formula:











P
max

-


Wn
0






n
=
1

N




(


1

g
n


-

1

g

n
-
1




)



2


1


t
tran
low


W







k
=
n

N






m
=
1

M




x

m
,
k




D
m









-


Wn
0


g
N



=
0






    • S43, based on the maximum transmission power Pmax of the local terminal, the transmission delay t′tran which minimizes the total overhead of the local terminal corresponding to the decision samples is calculated according to the following formula:










α
-

β




Wn


0


g
N



+

β


n
0






n
=
1

N



(


1

g
n


-

1

g

n
-
1




)



2


1


t
tran



W







k
=
n

N






m
=
1

M




x

m
,
k




D
m








(

W
-

ln


2
·

1

t
tran









k
=
n

N






m
=
1

M




x

m
,
k




D
m






)





=
0






    • S44, based on the upper limit ttranup of the transmission delay and the lower limit ttranlow of the transmission delay between the local terminal and the idle terminals, the optimal transmission delay function t*tran is determined:
















if



t
tran
up





t
tran
low



and



t
tran
low




t
tran



,



t
tran
*

=

min


{


t
tran


,

t
up
tran


}



;






(
1
)










if



t
tran
up





t
tran
low



and



t
tran
low


>

t
tran



,



t
tran
*

=

t
tran
low


;






(
2
)










if



t
tran
up


<


t
tran
low



and


max

m

Γ



{


L
m

-

t
m



}


<

t
tran
low


,


t
tran
*

=

max


{


t
tran
low

,

t
tran



}








(
3
)










if



t
tran
up


<


t
tran
low



and


max

m

Γ



{


L
m

-

t
m



}




t
tran
low


,





(
4
)








according to the step S41, the transmission delay upper limit between the local terminal and the idle terminals is recalculated and is recorded as ttranup*;

    • (1) if ttranup*<t′tran, t*tran=ttranup*;
    • (2) if ttranup*≥t′tran, t*tran=max{ttranlow, t′tran};
    • S45, the processing delay t*m of the computing task Tm based on the optimal transmission delay function t*tran is obtained by bringing the optimal transmission delay function t*tran into the processing delay t*m expression of the computing task Tm, and based on the total overhead objective function of the local terminal corresponding to the decision samples, the total overhead of the local terminal corresponding to the decision samples is obtained as follows:







α

max


t
m
*


+

β


E
loc


+

γ





n
=
1

N



Mon
n



+

σ

max

m


{

1
,
2
,

,
M

}




{


max


{



t
m
*

-

L
m


,
0

}





"\[LeftBracketingBar]"



t
m
*

-

L
m




"\[RightBracketingBar]"



}








    • where σ represents a preset penalty value.





A preferred technical scheme of the invention is as follows: the specific steps of selecting the decision samples that minimize the total overhead of the local terminal with the goal of minimizing the total overhead of the local terminal through a preset number of iterations and completing the allocation of the computing tasks on the local terminal in step S5 are as follows:

    • S51, different decision samples are used to participate in the iterations, the computing tasks on the local terminal are allocated according to the decision samples, the maximum number of iterations is preset, whether the preset maximum number of iterations is reached is determined, and if the preset maximum number of iterations is reached, the decision samples in each iteration that minimize the total overhead of the local terminal in each iteration are selected to allocate the computing tasks on the local terminal are allocated;
    • if the preset maximum number of iterations is not reached, step S52 is performed;
    • S52, cross-operation is performed in the decision samples: two decision samples are randomly selected from the decision samples, and are marked as A1 and A2, the decision samples reflect the execution decision of each task, N+1 columns of vectors in the decision samples are regarded as chromosomes, each chromosome contains M elements which correspondingly represent the execution condition of M tasks on the local terminal or the idle terminals, the decision samples A1 and A2 are respectively marked as a parent individual 1 and a parent individual 2, the positions of the chromosome and the position of a crossing node on the chromosome are randomly selected, and the expression is as follows:
    • 1, θ2)
    • where θ1 represents the position of the chromosome in the parent individual to which the chromosome belongs, and θ2 represents the position of the crossing node in the chromosome; based on this position, a cross interchange is performed, first θ2 elements on first θ1−1 columns and a θ1-th column of the parent individual 1 and last M−θ2 elements on last N+1−θ1 columns and a θ1-th column of the parent individual 2 are combined to generate a new individual 1, last M−θ2 elements on last N+1−01 columns and a θ1-th column of the parent individual 1 and first θ2 elements on first θ1−1 columns and a θ1-th column of the parent individual 2 are combined to generate a new individual 2, and the two new individuals are generated and are respectively marked as an offspring individual 1 and an offspring individual 2:
    • after each cross-operation is completed, whether each offspring individual satisfies Σn=0Nxm,n=1 is checked, if Σn=0Nxm,n=0, it means that the computing tasks are missing, for the missing computing tasks, the idle terminals or the local terminal which can execute the missing computing tasks are randomly selected, if Σn=0Nxm,n>1, it means that the computing tasks are repeated, the idle terminals or the local terminal which can execute the repeated computing tasks are randomly selected;
    • S53, the mutation claim operation is implemented in the decision samples: based on the decision samples in the completed iterations, the decision samples that minimize the total overhead of the local terminal do not participate in the mutation operation, for other decision samples, the mutation operation is performed with a preset probability {circumflex over (m)}, for the matrix corresponding to the decision sample, the position of the chromosome and the position of a mutation element on the chromosome are randomly selected, and the expression is as follows:
    • 3, θ4)
    • where θ3 represents the position of the chromosome in the individual to which the chromosome belongs, and θ4 represents the position of the mutant element on the chromosome;
    • x3, θ4) represent the value of the element on the chromosome, if x3, θ4)=1, the value of the element is modified to 0, and the idle terminal or local terminal that executes the computing task to which the element corresponds is randomly selected, if x3, θ4)=0, the value of the element is modified to 1, the computing task to which the element corresponds is removed from the idle terminal or the local terminal that originally executed the computing task; and
    • S54, for the decision samples, and other decision samples obtained through cross-operation and mutation operation, the total overhead of the local terminal corresponding to the decision samples is calculated, and the optimal original population number of samples are selected to build a sample group to participate in iterations until the preset maximum number of iterations is reached.


Compared with the prior art, the present disclosure has the following beneficial effects and advantages:

    • 1. The present disclosure is aimed at maximizing the number of completed computing tasks; and the delay of the computing tasks is minimized by decentralizing and unloading the computing tasks to the different idle terminals, which ensures to the greatest extent that each computing task can be completed within the maximum delay allowed by the computing task.
    • 2. According to the present disclosure, the overhead of the local terminal in the aspects of computing task delay, energy consumption, unloading fee, and the like are jointly considered, and the aspects are jointly optimized, so that users can adjust the definition of their overhead according to the emphasis on different resources.
    • 3. Different from the traditional method of unloading computing tasks, the method makes full use of the computing resources of surrounding idle terminals, can unload multiple computing tasks to one terminal equipment at the same time, and may also unload multiple computing tasks to multiple terminal equipment at the same time with relatively high flexibility.





BRIEF DESCRIPTION OF DRAWINGS


FIG. 1 is a schematic flow diagram provided by an embodiment of the present disclosure.



FIG. 2 is a schematic diagram of a system model by an embodiment of the present disclosure.





DETAILED DESCRIPTION OF THE EMBODIMENTS

The present disclosure will be further described with reference to the accompanying drawings. The following embodiments are only used to illustrate the technical scheme of the present disclosure more clearly, and cannot be used to limit the scope of protection of the present disclosure.


Referring to FIG. 1 and FIG. 2, the multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication disclosed by the embodiment of the present disclosure executes the following steps according to a preset period to unload computing tasks on a local terminal to idle terminals with idle computing resources around the local terminal and realize the allocation of the computing tasks of the local terminal with the minimum total overhead of the local terminal. The D2D communication of the local terminal has the longest distance of 50 m.


S1. Idle terminals in a preset range are detected by taking the local terminal as the center, and the computing power fn, energy consumption pricing φn, maximum allowable energy consumption Emaxn, and channel state gn of the idle terminals are obtained, where n∈{1,2, . . . , N}, and N represents the total number of idle terminals.


S2. Based on the execution mode of the computing tasks on the local terminal, decision samples are constructed.


S3. Respectively for the decision samples, based on the processing delay function tm of the computing tasks, where m∈{1,2, . . . , M}, M represents the total number of computing tasks, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks, the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples, where n∈{1,2, . . . , N}, N represents the total number of idle terminals, and the fee charging function for the idle terminals respectively receiving the computing tasks of the local terminal, the total overhead objective function and constraint conditions of the local terminal corresponding to the decision samples are determined.


S4. Respectively for the decision samples, the upper limit of the transmission delay between the local terminal corresponding to the decision samples and the idle terminals and the lower limit of the delay between the local terminal and the idle terminals are calculated, and the optimal transmission delay function corresponding to the decision samples is determined under constraint conditions; and


respectively for the decision samples, the total overhead of the local terminal corresponding to the decision samples is calculated based on the total overhead objective function and constraint conditions of the local terminal corresponding to the decision samples and the optimal transmission delay function corresponding to the decision samples under the constraint conditions.


S5. The decision samples that minimize the total overhead of the local terminal are selected with the goal of minimizing the total overhead of the local terminal through a preset number of iterations, and the allocation of the computing tasks on the local terminal is completed based on the decision samples.


According to the multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication disclosed by the embodiment of the present disclosure, the specific steps of constructing decision samples in step S2 are as follows:

    • S21, computing tasks on a local terminal are represented by a set Γ={T1, T2, . . . TM}, wherein the total number of the computing tasks is represented by M, the attributes of the computing tasks are represented by a set {Cm, Dm, Lm}, wherein Cm represents the total number of CPU cycles required to process the computing tasks, Dm represents the data volume of the computing tasks, Lm represents the maximum delay allowed by the computing tasks, wherein m∈{1,2, . . . , M}, and M represents the total number of computing tasks;
    • S22, idle terminals are sorted and numbered in descending order according to channel gains thereof, the channel gains of the idle terminals satisfy the requirement of g1≥ . . . ≥gn≥ . . . ≥gN, wherein gn represents the channel gain of one of the idle terminals, n∈{1,2, . . . , N}, N represents the total number of idle terminals, and the idle terminals are presented by a set Λ={1,2, . . . , N};
    • S23, respectively for one computing task Tm among the computing tasks on the local terminal, wherein m∈{1,2, . . . , M}, and M represents the total number of computing tasks, the execution mode of the computing task Tm is constructed as follows:
    • {xm,0, xm,1, . . . xm,n, . . . xm,N},
    • where xm,n represents the execution mode of the computing task Tm, wherein n∈{1,2, . . . , N}, N represents the total number of idle terminals, xm,0=1 represents that the computing task Tm is processed at the local terminal, xm,0=0 represents that the computing task Tm is not processed at the local terminal, xm,n=1 represents that computing task Tm is unloaded to the idle terminal n for processing, xm,n=0 represents that the computing task Tm is not processed on the idle terminal n, and the execution mode of each computing task in computing task sets on the local terminal satisfies Σn=0Nxm,n=1, that is, each computing task can only be processed on an idle terminal or the local terminal; and
    • S24, respectively for the computing tasks on the local terminal, the decision samples are constructed based on the execution mode of the computing tasks on the local terminal, each of the decision samples is represented by a matrix A with M rows and N+1 columns, and the matrix A is as follows:






A
=

(




x

1
,
0





x

1
,
1





x

1
,
2








x

1
,
N







x

2
,
0





x

2
,
1





x

2
,
2








x

2
,
N
























x

M
,
0





x

M
,
1





x

M
,
2








x

M
,
N





)







    • wherein the first column in the matrix A represents the execution condition of the computing tasks on the local terminal, and the second column to the (N+1)-th column represent the execution condition of the computing tasks unloaded to the idle terminals, and when the decision sample of one computing task is constructed, whether the idle terminals satisfy energy consumption limit is determined.





According to the multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication disclosed by the embodiment of the present disclosure, the specific steps of determining the total overhead objective function and constraint conditions of the local terminal in step 3 are as follows:

    • S31, respectively for each decision sample, the number of computing tasks on the local terminal and the idle terminals is represented by a set {K0, K1, . . . , KN}, the computing tasks are processed on the idle terminals or the local terminal in a serial mode, and the computing tasks on the local terminal are arranged in descending order according to the maximum allowable delay Lm, and are represented by a set S0={S0,1, S0,2, . . . , S0,K0}; the computing tasks on the idle terminal n are arranged in descending order according to the maximum allowable delay Lm, and are represented by a set Sn={Sn,1, Sn,2, . . . , Sn,Kn};
    • S32, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks is calculated, and the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples are as follows:

      Elocm=1Mxm,0μCm,
      Entran=ttran·Ptot,
    • where μ represents the energy consumed in each CPU cycle, ttran represents the transmission time for the local terminal to unload the computing tasks to the idle terminals, and Ptot represents the minimum total transmission power of the local terminal;


wherein the decision x is executed based on the computing tasks corresponding to the decision samples, and the relationship between the transmission time ttran for the local terminal to unload the computing tasks to the idle terminals and the minimum total transmission power Ptot of the local terminal is as follows:








P
tot

(

x
,

t
trean


)

=



Wn
0






n
=
1

N




(


1

g
n


-

1

g

n
-
1




)



2


1


t
tran


W







k
=
n

N






m
=
1

M




x

m
,
k




D
m









-


Wn
0


g
N









    • where gn represents the n-th idle terminal, gn-1 represents the (n−1)-th idle terminal, gN represents the N-th idle terminal, and gn-1≥gn≥gN, W represents the bandwidth of a transmission channel, n0 represents the power spectral density of white noise, and k represents the serial number of the idle terminal;

    • S33, one computing task Tm among the computing tasks on the local terminal is unloaded to the idle terminal n, and the expression of the processing delay tm of the computing task Tm is as follows:










t
m


=

{








i
=

S

0
,
1





S
0

(
m
)





C
i


f
loc







x

m
,
0


=
1







t
tran

+




i
=

S

n
,
1





S
n

(
m
)





C
i


f
n









x

m
,
n


=
1

,

n

Λ





,








    • where floc represents the computing power of the local terminal, fn represents the computing power of the idle terminals, that is, the number of CPU cycles per second that the local terminal or the idle terminals can handle, Sn(m) represents the position of the computing task Tm in the set Sn, S0(m) represents the position of the computing task Tm in the set S0 and i represents the serial number of the computing task in the set S0 or the Sn;

    • S34, while the local terminal unloads the computing tasks to the idle terminals, the local terminal needs to pay a fee to the idle terminals as a commission, a fee-charging function Monn for the idle terminals respectively receiving the computing tasks of the local terminal is calculated as follows:

      Monnn log2(1+Σi=Sn,1Sn,KnμCi),

    • where φn represents the pricing of unit energy consumption of the idle terminal n, and is related to the maximum allowable energy consumption Emaxn of the idle terminal n, the computing power fn of the idle terminal n, and the value emphasizing factor ηn of the idle terminal n for energy, and the specific relationship is as follows:











φ
n

=



f
n


E
max
n




η
n



;






    • S34, based on the processing delay tm of the computing task Tm, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks, the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples, and the fee-charging function Monn for the idle terminals respectively receiving the computing tasks of the local terminal, the total overhead objective function of the local terminal corresponding to the decision samples is determined as follows:












minimize

x
,

t
tran





α

max


t
m


+

β

(


E
loc

+

E
n
tran


)

+

γ





n
=
1

N



Mon
n




,






    • constraint conditions are as follows:

    • (1) tm≤Lm ∀m∈{1, 2, . . . , M}

    • (2) Σm=Sn,1Sn,Kn μCm≤Emaxn ∀n∈Λ

    • (3) Ptot≤Pmax

    • (4) α+β+γ=1

    • (5) α, β, γ∈(0, 1), ttran>0, xm,n∈{0,1}

    • where Pmax represents the maximum transmission power of the local terminal, Emaxn represents the maximum allowable energy consumption of the idle terminal n, α, β and γ respectively represent the weight coefficients of the local terminal for the processing delay, the energy consumption, and the fee charging corresponding to the idle terminals respectively receiving the computing tasks of the local terminal, the three aspects respectively reflect the local terminal's emphasis on the processing delay, the energy consumption and unloading fee, the formula (1) guarantees that all computing tasks must be completed within the maximum time limit of the computing tasks, the formula (2) limits the maximum energy of the idle terminals, which can be used for computing, the formula (3) is the limit for the transmission power of the local terminal, the formula (4) specifies the relationship among the processing delay coefficient, the energy consumption coefficient, and the unloading fee coefficient, and the formula (5) limits the range of values of α, β, γ.





According to the multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication disclosed by the embodiment of the present disclosure, the specific steps of determining the optimal transmission delay function corresponding to the decision samples in step S4 are as follows:

    • S41. respectively for each decision sample, the upper limit ttranup of transmission delay between the local terminal and the idle terminals is calculated as follows:








t
tran
up

=


min

n

Λ



{

Δ
n

}



,






    • where Δn represents the upper limit of the transmission delay between the local terminal and the idle terminal n and is specifically shown in the following formula:











Δ
n

=


min

m


S
n




{


L
m

-

t
m



}



,






    • where t′m represents the delay of the computing task Tm on the local terminal or the idle terminals, and is specifically shown in the following formula:










t
m


=

{








i
=

S

0
,
1





S
0

(
m
)





C
i


f
loc







x

m
,
0


=
1









i
=

S

n
,
1





S
n

(
m
)





C
i


f
n








x

m
,
n


=
1

,

n

Λ





,








    • S42, based on the maximum transmission power Pmax of the local terminal, the lower limit ttranlow of transmission delay between the local terminal and the idle terminals is calculated according to the following formula:












P
max

-


Wn
0






n
=
1

N




(


1

g
n


-

1

g

n
-
1




)



2


1


t
tran
low


W







k
=
n

N






m
=
1

M




x

m
,
k




D
m









-


Wn
0


g
N



=
0

,






    • S43, based on the maximum transmission power Pmax of the local terminal, the transmission delay t′tran which minimizes the total overhead of the local terminal corresponding to the decision samples is calculated according to the following formula:










α
-

β



Wn
0


g
N



+

β


n
0








n
=
1

N



(


1

g
n


-

1

g

n
-
1




)



2


1


t
tran



W









k
=
n

N








m
=
1

M



x

m
,
k




D
m





(

W
-

ln


2
·

1

t
tran











k
=
n

N








m
=
1

M



x

m
,
k




D
m



)



=
0






    • S44, based on the upper limit ttranup of the transmission delay and the lower limit ttranlow of the transmission delay between the local terminal and the idle terminals, the optimal transmission delay function t*tran is determined:

    • if ttranup≥ttranlow, it means that there is ttran which can make loaded computing tasks be completed within the constraint time, then it will be discussed as follows:

    • (1) if ttranup≥ttranlow and ttranlow≤t′tran, t*tran=min{t′tran, t*tran};

    • (2) if ttranup≥ttranlow and ttranlow>t′tran, t*tran=ttranlow;

    • if ttranup<ttranlow, it means that at present, there are some of loaded computing tasks which cannot be completed on time, then it will be discussed as follows:














if



t
tran
up


<


t
tran
low



and


max

m

Γ



{


L
m

-

t
m



}


<

t
tran
low


,




(
3
)








it means that all the unloaded computing tasks cannot be completed within the delay limit, then t′tran=max{ttranlow, t′tran};











if



t
tran
up


<


t
tran
low



and


max

m

Γ



{


L
m

-

t
m



}




t
tran
low


,




(
4
)








it means that part of the computing tasks can be completed within the delay constraint, and for the computing tasks that can be completed on time, according to the step S41, the upper limit of the transmission delay between the local terminal and the idle terminals is recalculated and is recorded as ttranup*;

    • (1) if ttranup*<t′tran, t*tran=ttranup*;
    • (2) if ttranup*≥t′tran, t*tran=max{ttranlow, t′tran};
    • S45, the processing delay t*m of the computing task Tm based on the optimal transmission delay function t*tran is obtained by bringing the optimal transmission delay function t*tran into the processing delay t*m expression of the computing task Tm, and based on the total overhead objective function of the local terminal corresponding to the decision samples, the total overhead of the local terminal corresponding to the decision samples is obtained as follows:








α


maxt
m
*


+

β


E
loc


+

γ







n
=
1

N



Mon
n


+

σ

max

m


{

1
,
2
,




M


}




{


max


{



t
m
*

-

L
m


,
0

}





"\[LeftBracketingBar]"



t
m
*

-

L
m




"\[RightBracketingBar]"



}



,






    • where σ represents a preset penalty value, if there are computing tasks that cannot be completed on time, the preset penalty value σ is added based on the total overhead objective function of the local terminal corresponding to the decision samples.





According to the multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication disclosed by the embodiment of the present disclosure, the specific steps of selecting the decision samples that minimize the total overhead of the local terminal with the goal of minimizing the total overhead of the local terminal through a preset number of iterations and completing the allocation of the computing tasks on the local terminal in step S5 are as follows:

    • S51, different decision samples are used to participate in the iterations, the computing tasks on the local terminal are allocated according to the decision samples, the maximum number of iterations is preset, whether the preset maximum number of iterations is reached is determined, and if the preset maximum number of iterations is reached, the decision samples in each iteration that minimize the total overhead of the local terminal are selected to allocate the computing tasks on the local terminal are allocated;
    • if the preset maximum number of iterations is not reached, step S52 is performed;
    • S52, cross-operation is performed in the decision samples: two decision samples are randomly selected from the decision samples and are marked as A1 and A2, the decision samples reflect the execution decision of each task, N+1 columns of vectors in the decision samples are regarded as chromosomes, each chromosome contains M elements which correspondingly represent the execution condition of M tasks on the local terminal or the idle terminals, the decision samples A1 and A2 are respectively marked as a parent individual 1 and a parent individual 2, the positions of the chromosome and the position of a crossing node on the chromosome are randomly selected, and the expression is as follows:
    • 1, θ2)
    • where θ1 represents the position of the chromosome in the parent individual to which the chromosome belongs, and θ2 represents the position of the crossing node in the chromosome; based on this position, a cross interchange is performed, first θ2 elements on first θ1−1 columns and a θ1−th column of the parent individual 1 and last M−θ2 elements on last N+1−81 columns and a θ1−th column of the parent individual 2 are combined to generate a new individual 1, last M−θ2 elements on last N+1−θ1 columns and a θ1−th column of the parent individual 1 and first θ2 elements on first θ1− 1 columns and a θ1−th column of the parent individual 2 are combined to generate a new individual 2, and the two new individuals are generated and are respectively marked as an offspring individual 1 and an offspring individual 2;
    • after each cross-operation is completed, whether each offspring individual satisfies Σn=0Nxm,n=1 is checked, if Σn=0Nxm,n=0, it means that the computing tasks are missing, for the missing computing tasks, the idle terminals or the local terminal which can execute the missing computing tasks are randomly selected, if Σn=0Nxm,n>1, it means that the computing tasks are repeated, the idle terminals or the local terminal which can execute the repeated computing tasks are randomly selected;
    • S53, the mutation operation is implemented in the decision samples: based on the decision samples in the completed iterations, the decision samples that minimize the total overhead of the local terminal do not participate in the mutation operation, for other decision samples, the mutation operation is performed with a preset probability {circumflex over (m)}, for the matrix corresponding to the decision sample, the position of the chromosome and the position of a mutation element on the chromosome are randomly selected, and the expression is as follows:
    • 3, θ4)
    • where θ3 represents the position of the chromosome in the individual to which the chromosome belongs, and θ4 represents the position of the mutant element on the chromosome;
    • x3, θ4) represent the value of the element on the chromosome, if x3, θ4)=1, the value of the element is modified to 0, and the idle terminal or local terminal that executes the computing task to which the element corresponds is randomly selected, if x3, θ4)=0, the value of the element is modified to 1, the computing task to which the element corresponds is removed from the idle terminal or the local terminal that originally executed the computing task; and
    • S54, for the decision samples, and other decision samples obtained through cross-operation and mutation operation, the total overhead of the local terminal corresponding to the decision samples is calculated, and the optimal original population number of samples are selected to build a sample group to participate in iterations until the preset maximum number of iterations is reached.


The embodiments of the present disclosure are described above in detail with reference to the accompanying drawings, but the present disclosure is not limited to the above embodiments, and various changes can be made without departing from the purposes of the present disclosure and within the scope of knowledge of those ordinary skill in the art.

Claims
  • 1. A multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication, wherein the specific steps of constructing decision samples are as follows: S1. detecting idle terminals in a preset range by taking a local terminal as a center, and computing power fn energy consumption pricing φn, maximum allowable energy consumption Emaxn, and channel state gn of the idle terminals are obtained, wherein n∈{1,2, . . . , N}, and N represents the total number of the idle terminals; S2. constructing decision samples based on an execution mode of computing tasks on the local terminal;S3. respectively for the decision samples, determining a total overhead objective function and constrain conditions of the local terminal corresponding to the decision samples, based on a processing delay function tm of the computing tasks, wherein m∈{1,2, . . . , M}, M represents the total number of the computing tasks, a total computing energy consumption function Eloc for local terminal processing the computing tasks assigned by the decision tasks, a transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples, wherein n∈{1,2, . . . , N}, N represents the total number of the idle terminals, and a fee charging function for the idle terminals respectively receiving the computing tasks of the local terminal;S4. respectively for the decision samples, calculating an upper limit of a transmission delay between the local terminal corresponding to the decision samples and the idle terminals, calculating a lower limit of a delay between the local terminal and the idle terminals, and determining an optimal transmission delay function corresponding to the decision samples under constraint conditions;respectively for the decision samples, calculating a total overhead of the local terminal corresponding to the decision samples based on the total overhead objective function, the constraint conditions of the local terminal corresponding to the decision samples, and the optimal transmission delay function corresponding to the decision samples under the constraint conditions; andS5. selecting the decision samples that minimize the total overhead of the local terminal with the goal of minimizing the total overhead of the local terminal through a preset number of iterations, and completing an allocation of the computing tasks on the local terminal based on the decision samples;wherein the specific steps of constructing decision samples in step S2 are as follows:S21, computing tasks on the local terminal are represented by a set Γ={T1, T2, . . . TM}, wherein the total number of the computing tasks is represented by M; the attributes of the computing tasks are represented by a set {Cm, Dm, Lm}, wherein Cm represents the total number of CPU (central processing unit) cycles required to process the computing tasks, Dm represents the data volume of the computing tasks, Lm represents the maximum delay allowed by the computing tasks, wherein m∈{1,2, . . . , M}, and M represents the total number of computing tasks;S22, the idle terminals are sorted and numbered in descending order according to channel gains thereof, the channel gains of the idle terminals satisfy the requirement of g1≥ . . . ≥gn≥ . . . ≥gN, wherein gn represents the channel gain of one of the idle terminals, n∈{1,2, . . . , N}, N represents the total number of the idle terminals, and the idle terminals are presented by a set Λ={1,2, . . . , N};S23, respectively for one computing task Tm among the computing tasks on the local terminal, wherein m∈{1,2, . . . , M}, and M represents the total number of the computing tasks, the execution mode of the computing task Tm is constructed as follows: {xm,0, xm,1, . . . , xm,n, . . . , xm,N}wherein xm,n represents the execution mode of the computing task Tm, wherein n∈{1,2, . . . , N}, N represents the total number of idle terminals, xm,0=1 represents that the computing task Tm is processed at the local terminal, xm,0=0 represents that the computing task Tm is not processed at the local terminal, xm,n=1 represents that computing task Tm is unloaded to the idle terminal n for processing, xm,n=0 represents that the computing task Tm is not processed on the idle terminal n, and the execution mode of each computing task in computing task sets on the local terminal satisfies Σn=0Nxm,n=1; andS24, respectively for the computing tasks on the local terminal, constructing the decision samples based on the execution mode of the computing tasks on the local terminal, each of the decision samples is represented by a matrix A with M rows and N+1 columns, and the matrix A is as follows:
  • 2. The multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication according to claim 1, wherein the specific steps of determining the total overhead objective function and constraint conditions of the local terminal in step 3 are as follows: S31. respectively for each decision sample, the number of computing tasks on the local terminal and the idle terminals is represented by a set {K0, K1, . . . , KN}, and the computing tasks on the local terminal are arranged in descending order according to the maximum allowable delay Lm, and are represented by a set S0={S0,1, S0,2, . . . , S0,K0}; the computing tasks on the idle terminal n are arranged in descending order according to the maximum allowable delay Lm, and are represented by a set Sn={Sn,1, Sn,2, . . . , Sn,Kn};S32, the total computing energy consumption function Eloc for the local terminal processing the computing tasks assigned by the decision tasks is calculated, and the transmission energy consumption function Entran for the idle terminals involved in the decision samples respectively receiving the computing tasks assigned by the decision samples are as follows:
  • 3. The multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication according to claim 2, wherein the specific steps of determining the optimal transmission delay function corresponding to the decision samples in step S4 are as follows: S41, respectively for each decision sample, the upper limit ttranup of transmission delay between the local terminal and the idle terminals is calculated as follows:
  • 4. The multi-task joint computing unloading and resource allocation method based on D2D (Device-to-Device) communication according to claim 3, wherein the specific steps of selecting the decision samples that minimize the total overhead of the local terminal with the goal of minimizing the total overhead of the local terminal through a preset number of iterations and completing the allocation of the computing tasks on the local terminal in step S5 are as follows: S51, different decision samples are used to participate in the iterations, the computing tasks on the local terminal are allocated according to the decision samples, the maximum number of iterations is preset, whether the preset maximum number of iterations is reached is determined, and if the preset maximum number of iterations is reached, the decision samples in each iteration that minimize the total overhead of the local terminal in each iteration are selected to allocate the computing tasks on the local terminal are allocated;if the preset maximum number of iterations is not reached, step S52 is performed;S52, cross-operation is performed in the decision samples: two decision samples are randomly selected from the decision samples and are marked as A1 and A2, the decision samples reflect the execution decision of each task, N+1 columns of vectors in the decision samples are regarded as chromosomes, each chromosome contains M elements which correspondingly represent the execution condition of M tasks on the local terminal or the idle terminals, the decision samples A1 and A2 are respectively marked as a parent individual 1 and a parent individual 2, the positions of the chromosome and the position of a crossing node on the chromosome are randomly selected, and the expression is as follows: (θ1, θ2)where θ1 represents the position of the chromosome in the parent individual to which the chromosome belongs, and θ2 represents the position of the crossing node in the chromosome; based on this position, a cross interchange is performed, first θ2 elements on first θ1−1 columns and a θ1−th column of the parent individual 1 and last M−θ2 elements on last N+1−81 columns and a θ1−th column of the parent individual 2 are combined to generate a new individual 1, last M−θ2 elements on last N+1−θ1 columns and a θ1−th column of the parent individual 1 and first θ2 elements on first θ1− 1 columns and a θ1−th column of the parent individual 2 are combined to generate a new individual 2, and the two new individuals are generated and are respectively marked as an offspring individual 1 and an offspring individual 2;after each cross-operation is completed, whether each offspring individual satisfies Σn=0Nxm,n=1 is checked, if Σn=0Nxm,n=0, it means that the computing tasks are missing, for the missing computing tasks, the idle terminals or the local terminal which can execute the missing computing tasks are randomly selected, if Σn=0Nxm,n>1, it means that the computing tasks are repeated, the idle terminals or the local terminal which can execute the repeated computing tasks are randomly selected;S53, the mutation operation is implemented in the decision samples: based on the decision samples in the completed iterations, the decision samples that minimize the total overhead of the local terminal do not participate in the mutation operation, for other decision samples, the mutation operation is performed with a preset probability {circumflex over (m)}, for the matrix corresponding to the decision sample, the position of the chromosome and the position of a mutation element on the chromosome are randomly selected, and the expression is as follows: (θ3, θ4)where θ3 represents the position of the chromosome in the individual to which the chromosome belongs, and θ4 represents the position of the mutant element on the chromosome;x(θ3, θ4) represent the value of the element on the chromosome, if x(θ3, θ4)=1, the value of the element is modified to 0, and the idle terminal or local terminal that executes the computing task to which the element corresponds is randomly selected, if x(θ3, θ4)=0, the value of the element is modified to 1, the computing task to which the element corresponds is removed from the idle terminal or the local terminal that originally executed the computing task; andS54, for the decision samples, and other decision samples obtained through cross-operation and mutation operation, the total overhead of the local terminal corresponding to the decision samples is calculated, and the optimal original population number of samples are selected to build a sample group to participate in iterations until the preset maximum number of iterations is reached.
Priority Claims (1)
Number Date Country Kind
202210101461.2 Jan 2022 CN national
US Referenced Citations (8)
Number Name Date Kind
20170013495 Chae Jan 2017 A1
20180183855 Sabella Jun 2018 A1
20190138934 Prakash May 2019 A1
20190158300 Sabella May 2019 A1
20190364492 Azizi Nov 2019 A1
20210266834 Hu Aug 2021 A1
20220007310 Najla Jan 2022 A1
20220386094 Vemuri Dec 2022 A1
Foreign Referenced Citations (2)
Number Date Country
111586696 Aug 2020 CN
114449490 May 2022 CN
Non-Patent Literature Citations (2)
Entry
EEE Communications Surveys & Tutorials, vol. 19, No. 3, Third Quarter 2017 Mobile Edge Computing: A Survey on Architecture and Computation Offloading Pavel Mach, Member, IEEE, and Zdenek Becvar, Member, IEEE (Year: 2017).
EEE Transactions on Wireless Communications, vol. 17, No. 3, Mar. 2018 Joint Offloading and Computing Optimization in Wireless Powered Mobile-Edge Computing Systems Feng Wang , Member, IEEE, Jie Xu , Member, IEEE, Xin Wang, Senior Member, IEEE, (Year: 2018).
Related Publications (1)
Number Date Country
20230239903 A1 Jul 2023 US
Continuations (1)
Number Date Country
Parent PCT/CN2022/107287 Jul 2022 US
Child 18154933 US