質問編集履歴

3

コード記載

2020/08/03 04:43

投稿

wandora
wandora

スコア0

test CHANGED
File without changes
test CHANGED
@@ -158,12 +158,12 @@
158
158
 
159
159
  SNR = 0
160
160
 
161
+ Ps = 1.0
162
+
161
163
  sigma = math.sqrt( Ps / (2 * math.pow(10.0, SNR/10)))
162
164
 
163
165
 
164
166
 
165
- Ps = 1.0
166
-
167
167
  Pn = 2*sigma*sigma
168
168
 
169
169
  r0 = Ps/Pn

2

コード記載

2020/08/03 04:43

投稿

wandora
wandora

スコア0

test CHANGED
File without changes
test CHANGED
@@ -2,9 +2,9 @@
2
2
 
3
3
 
4
4
 
5
- a = [a1, a2, a3]
5
+ s = [s1, s2, s3]
6
-
6
+
7
- b = [b1, b2, b3]
7
+ t = [t1, t2, t3]
8
8
 
9
9
 
10
10
 
@@ -14,12 +14,16 @@
14
14
 
15
15
  (条件)
16
16
 
17
- ・ pk = max{ bk(ak - h), 0 } k = 1,2,3
17
+ ・ pk = max{ tk(sk - h), 0 } k = 1,2,3
18
18
 
19
19
  ・ h は p1 + p2 + p3 = 1 を満たす為の定数
20
20
 
21
21
 
22
22
 
23
+ この条件下で出来るだけ p を 0 にしないようなコードを書きたいと考えております。
24
+
25
+ (0 を許可するコードなら既に書けております)
26
+
23
27
 
24
28
 
25
29
  どういったコードが考えられますでしょうか。
@@ -32,7 +36,17 @@
32
36
 
33
37
 
34
38
 
35
-
39
+ 返信が遅れまして大変申し訳ございません。
40
+
41
+ またご回答くださり誠に有難うございます。
42
+
43
+ 以下、コードです。
44
+
45
+
46
+
47
+
48
+
49
+ ```python
36
50
 
37
51
  def calculate_send_power(bits, A, r0, a, b):
38
52
 
@@ -91,3 +105,127 @@
91
105
 
92
106
 
93
107
  return p
108
+
109
+
110
+
111
+ if __name__ == '__main__':
112
+
113
+ for bits in bit_pattern:
114
+
115
+ num_stream = len(bits)
116
+
117
+ p = calculate_send_power(bits, A, r0, a, b)
118
+
119
+
120
+
121
+ if len(p) != num_stream:
122
+
123
+ for i in range(num_stream - len(p)):
124
+
125
+ p.append(0)
126
+
127
+ ```
128
+
129
+
130
+
131
+ かなり分かりにくいかと思いますが、 calculate_send_power() における over が s を表し、under が t を表し、 xi が h を表しているとお考えください。
132
+
133
+
134
+
135
+ 以下にそれぞれの変数を述べておきます。
136
+
137
+ ```ここに言語を入力
138
+
139
+
140
+
141
+ a = [0,0,1/2,0,3/8,0,7/24,0,15/64]
142
+
143
+ b = [0,0,2,0,10,0,42,0,170]
144
+
145
+
146
+
147
+ bit_pattern = [[8], [6, 2], [4, 4], [4, 2, 2], [2, 2, 2, 2]]
148
+
149
+
150
+
151
+ H = (4,4)の複素行列 実部、虚部ともに正規分布に従う乱数
152
+
153
+ gram_H = np.conjugate(H.T) @ H
154
+
155
+ U, A, Uh = svd(gram_H)
156
+
157
+
158
+
159
+ SNR = 0
160
+
161
+ sigma = math.sqrt( Ps / (2 * math.pow(10.0, SNR/10)))
162
+
163
+
164
+
165
+ Ps = 1.0
166
+
167
+ Pn = 2*sigma*sigma
168
+
169
+ r0 = Ps/Pn
170
+
171
+ ```
172
+
173
+
174
+
175
+ このコードは bit_pattern = [[8], [6, 2], [4, 4], [4, 2, 2], [2, 2, 2, 2]] のそれぞれに割り当てる電力(電力総和 = 1)を決定するもので以下のようになります。
176
+
177
+
178
+
179
+
180
+
181
+ |bits|p(ower)|sum|
182
+
183
+ |:--|:--:|--:|
184
+
185
+ |[8]|[1.000]|1.0|
186
+
187
+ |[6, 2]|[0.453, 0.546]|1.0|
188
+
189
+
190
+
191
+ 以下に実行結果を述べます。
192
+
193
+ ```ここに言語を入力
194
+
195
+ for bits in bit_pattern:
196
+
197
+ num_stream = len(bits)
198
+
199
+ tmp = 0
200
+
201
+ p = calculate_send_power(bits, A, r0, a, b)
202
+
203
+ if len(p) != num_stream:
204
+
205
+ for i in range(num_stream - len(p)):
206
+
207
+ p.append(0)
208
+
209
+
210
+
211
+ print("bits = {} , power = {}, sum = {}".format(bits, p, sum(p)))
212
+
213
+
214
+
215
+ >>>
216
+
217
+ bits = [8] , power = [1.00], sum = 1.0
218
+
219
+ bits = [6, 2] , power = [0.39036578941718647, 0.6096342105828132], sum = 1.0
220
+
221
+ bits = [4, 4] , power = [0.6905457297074978, 0.30945427029250216], sum = 1.0
222
+
223
+ bits = [4, 2, 2] , power = [0.4747411414947003, 0.35540013052184316, 0.1698587279834565], sum = 1.0
224
+
225
+ bits = [2, 2, 2, 2] , power = [0.3157712110211322, 0.40062777763337526, 0.2836010113454926, 0], sum = 1.0
226
+
227
+ ```
228
+
229
+
230
+
231
+ と出来ているのですが、 bits = [2, 2, 2, 2] の4項目に割り当てる電力が 0 になってしまいます。この条件下で出来るだけ p を 0 にしないようなコードを書きたいと考えており、考え方でもご教授頂けると幸いです。よろしくお願い申し上げます。

1

a

2020/08/03 04:30

投稿

wandora
wandora

スコア0

test CHANGED
File without changes
test CHANGED
@@ -27,3 +27,67 @@
27
27
  考え方でもご教授頂けると幸いです。
28
28
 
29
29
  よろしくお願い申し上げます。
30
+
31
+
32
+
33
+
34
+
35
+
36
+
37
+ def calculate_send_power(bits, A, r0, a, b):
38
+
39
+ num_stream = len(bits)
40
+
41
+ over = 0
42
+
43
+ under = 0
44
+
45
+ for k in range(num_stream):
46
+
47
+ rk = A[k] * r0
48
+
49
+ ak = a[bits[k]]
50
+
51
+ bk = b[bits[k]]
52
+
53
+ mk = bits[k]
54
+
55
+
56
+
57
+ over += bk/rk * math.log(ak * mk * rk / bk)
58
+
59
+ under += bk/rk
60
+
61
+
62
+
63
+ xi = (over - 1) / under
64
+
65
+ p = []
66
+
67
+
68
+
69
+ for k in range(num_stream):
70
+
71
+ rk = A[k] * r0
72
+
73
+ ak = a[bits[k]]
74
+
75
+ bk = b[bits[k]]
76
+
77
+ mk = bits[k]
78
+
79
+
80
+
81
+ if bk/rk * (math.log(ak * mk * rk / bk) - xi) > 0:
82
+
83
+ p.append(bk/rk * (math.log(ak * mk * rk / bk) - xi))
84
+
85
+
86
+
87
+ if len(p) != num_stream:
88
+
89
+ p = calculate_send_power(bits[:-1], A, r0, a, b)
90
+
91
+
92
+
93
+ return p