質問編集履歴
3
コード記載
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
コード記載
test
CHANGED
File without changes
|
test
CHANGED
@@ -2,9 +2,9 @@
|
|
2
2
|
|
3
3
|
|
4
4
|
|
5
|
-
|
5
|
+
s = [s1, s2, s3]
|
6
|
-
|
6
|
+
|
7
|
-
|
7
|
+
t = [t1, t2, t3]
|
8
8
|
|
9
9
|
|
10
10
|
|
@@ -14,12 +14,16 @@
|
|
14
14
|
|
15
15
|
(条件)
|
16
16
|
|
17
|
-
・ pk = max{
|
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
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
|