forked from cvxpy/cvxpy
-
Notifications
You must be signed in to change notification settings - Fork 3
/
water_filling_BVex5.2.py
70 lines (61 loc) · 2.45 KB
/
water_filling_BVex5.2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
"""
Copyright 2013 Steven Diamond
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
#!/usr/bin/env python3
# @author: R. Gowers, S. Al-Izzi, T. Pollington, R. Hill & K. Briggs
# Boyd and Vandenberghe, Convex Optimization, example 5.2 page 145
import numpy as np
import cvxpy as cvx
'''
Input parameters
n: Number of communication channels or 'buckets'
a: Floor above the baseline for each channel at which power can be added
sum_x: Total power to be allocated to the n channels
'''
def water_filling(n,a,sum_x=1):
'''
Boyd and Vandenberghe, Convex Optimization, example 5.2 page 145
Water-filling.
This problem arises in information theory, in allocating power to a set of
n communication channels in order to maximise the total channel capacity.
The variable x_i represents the transmitter power allocated to the ith channel,
and log(α_i+x_i) gives the capacity or maximum communication rate of the channel.
The objective is to minimize -∑log(α_i+x_i) subject to the constraint ∑x_i = 1
'''
# Declare variables and parameters
x = cvx.Variable(n)
alpha = cvx.Parameter(n,nonneg=True)
alpha.value = a
#alpha.value = np.ones(n)
# Choose objective function. Interpret as maximising the total communication rate of all the channels
obj = cvx.Maximize(cvx.sum(cvx.log(alpha + x)))
# Declare constraints
constraints = [x >= 0, cvx.sum(x) - sum_x == 0]
# Solve
prob = cvx.Problem(obj, constraints)
prob.solve()
if(prob.status=='optimal'):
return prob.status,prob.value,x.value
else:
return prob.status,np.nan,np.nan
# as an example, solve the water filling problem for three buckets
if __name__ == '__main__':
print(water_filling.__doc__)
# print all arrays to 3 significant figures
np.set_printoptions(precision=3)
buckets=3
alpha = np.array([0.8,1.0,1.2])
print('Number of buckets = %s'%buckets)
stat,prob,x=water_filling(buckets,alpha)
print('Problem status: ',stat)
print('Optimal communication rate = %.4g '%prob)
print('Transmitter powers:\n', x)