IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ 国立大学法人京都大学の特許一覧 ▶ 株式会社国際電気通信基礎技術研究所の特許一覧

特許7236708制御装置、それを備えた基地局、コンピュータに実行させるためのプログラムおよびプログラムを記録したコンピュータ読み取り可能な記録媒体
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2023-03-02
(45)【発行日】2023-03-10
(54)【発明の名称】制御装置、それを備えた基地局、コンピュータに実行させるためのプログラムおよびプログラムを記録したコンピュータ読み取り可能な記録媒体
(51)【国際特許分類】
   H04W 72/50 20230101AFI20230303BHJP
   H04W 84/12 20090101ALI20230303BHJP
   H04W 72/0446 20230101ALI20230303BHJP
   H04W 72/52 20230101ALI20230303BHJP
   H04W 72/541 20230101ALI20230303BHJP
【FI】
H04W72/50 110
H04W84/12
H04W72/0446
H04W72/52
H04W72/541
【請求項の数】 18
(21)【出願番号】P 2020151896
(22)【出願日】2020-09-10
(65)【公開番号】P2022046051
(43)【公開日】2022-03-23
【審査請求日】2022-05-11
【国等の委託研究の成果に係る記載事項】(出願人による申告)「令和2年度 総務省「電波利活用強靭化に向けた周波数創造技術に関する研究開発及び人材育成プログラム」委託研究、産業技術力強化法第17条の適用を受ける特許出願
(73)【特許権者】
【識別番号】504132272
【氏名又は名称】国立大学法人京都大学
(73)【特許権者】
【識別番号】393031586
【氏名又は名称】株式会社国際電気通信基礎技術研究所
(74)【代理人】
【識別番号】100112715
【弁理士】
【氏名又は名称】松山 隆夫
(72)【発明者】
【氏名】山本 高至
(72)【発明者】
【氏名】香田 優介
(72)【発明者】
【氏名】紀平 悠人
(72)【発明者】
【氏名】矢野 一人
【審査官】桑原 聡一
(56)【参考文献】
【文献】特開2020-17938(JP,A)
【文献】特開2013-106202(JP,A)
【文献】米国特許出願公開第2019/0245882(US,A1)
(58)【調査した分野】(Int.Cl.,DB名)
H04B 7/24-7/26
H04W 4/00-99/00
(57)【特許請求の範囲】
【請求項1】
各々が基地局と端末装置とを含み、かつ、タイムスロットを用いてフレームを無線通信によって送受信する複数のサービスセットのうちの任意の1つのサービスセットである制御対象サービスセットを制御する制御装置であって、
前記制御対象サービスセットに含まれる基地局である制御対象基地局によるフレームの送信スケジュールである第1の送信スケジュールと、前記制御対象基地局によるフレームの送信区間である第1の送信区間と、前記制御対象基地局によるフレームの送信が成功したか失敗したかを示す成功/失敗情報と、前記制御対象基地局による無線通信を妨害する基地局である敵対基地局によるフレームの送信区間である第2の送信区間と、前記複数のサービスセットのうちの前記制御対象サービスセット以外の1個以上のサービスセットであり、かつ、前記制御対象サービスセットと協調して無線通信を行う協調サービスセットに含まれる基地局である協調基地局によるフレームの送信スケジュールである第2の送信スケジュールとを収集する収集手段と、
前記制御対象基地局による無線通信への前記敵対基地局による妨害行動を固定して、前記成功/失敗情報と前記第1および第2の送信区間とに基づいて、前記敵対基地局による妨害が存在する通信環境において前記制御対象基地局の無線通信性能を維持する性能維持行動を学習する第1の敵対的強化学習をN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して前記第1の敵対的強化学習の結果を出力する第1の学習器と、
前記制御対象基地局の前記性能維持行動を固定して、前記敵対基地局の前記妨害行動を学習する第2の敵対的強化学習を前記N個のタイムスロットと異なるN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して前記第2の敵対的強化学習の結果を出力する第2の学習器と、
前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の学習器から受けた前記第1の敵対的強化学習の結果と前記第2の送信スケジュールとに基づいて前記制御対象基地局の行動を制御する制御手段とを備え、
前記第1の学習器は、前記第2の学習器から前記妨害行動を受けると、その受けた妨害行動を固定して、前記N個のタイムスロットにおける前記第1の敵対的強化学習をNitcr(Nitcrは、(N+N)の自然数倍の整数)個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行して前記性能維持行動を更新し、前記N個のタイムスロットにおいて前記性能維持行動を最終的に更新するごとに前記最終的に更新した前記性能維持行動を前記第2の学習器へ出力するとともに、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の敵対的強化学習の結果を前記制御手段へ出力し、
前記第2の学習器は、前記第1の学習器から前記性能維持行動を受けると、その受けた性能維持行動を固定して、前記N個のタイムスロットにおける前記第2の敵対的強化学習を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行して前記妨害行動を更新し、前記N個のタイムスロットにおいて前記妨害行動を最終的に更新するごとに前記最終的に更新した前記妨害行動を前記第1の学習器へ出力し、
前記第1の学習器は、前記Nitcr個のタイムスロットにおいて、前記N個のタイムスロットにおける前記第1の敵対的強化学習を前記N個のタイムスロットにおける前記第2の学習器による前記第2の敵対的強化学習と交互に実行する、制御装置。
【請求項2】
前記第1の学習器は、前記第1の敵対的強化学習において、前記制御対象基地局が前記フレームを送信する予定であるタイムスロットにおいて取得し得る報酬を累積した期待累積報酬が最大になるように第1の行動価値関数をQ学習によって更新する第1の更新処理を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行し、前記Q学習におけるQ値が最大になるときの前記第1の行動価値関数の行動を前記性能維持行動として前記第2の学習器へ出力するとともに、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記フレームの送信タイミングになったときの前記Q学習におけるQテーブルを前記第1の敵対的強化学習の結果として前記制御手段へ出力し、
前記第2の学習器は、前記第2の敵対的強化学習において、前記期待累積報酬が最小になるように第2の行動価値関数をQ学習によって更新する第2の更新処理を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行し、前記Q学習におけるQ値が最小になるときの前記第2の行動価値関数の行動を前記妨害行動として前記第1の学習器へ出力し、
前記第1の行動価値関数は、前記制御対象基地局が自己の行動を選択することである方策に基づいて、前記協調基地局による前記フレームの送信有無の状態を示す第1の状態と、前記制御対象基地局および前記敵対基地局の過去の所定数のタイムスロットにおける前記フレームの送信有無の履歴の状態を示す第2の状態とから状態集合のうちの1つの状態において前記制御対象基地局が実行可能な行動集合のうちの1つの行動を実行するときの価値を表し、
前記第2の行動価値関数は、前記敵対基地局が自己の行動を選択することである方策に基づいて、前記状態集合のうちの1つの状態において前記敵対基地局が前記フレームの送信を行う行動と前記敵対基地局が前記フレームの送信を行わない行動とのうちの1つの行動を実行するときの価値を表す、請求項1に記載の制御装置。
【請求項3】
前記第1の学習器は、前記第1の更新処理において、所定の確率によって前記制御対象基地局の行動を選択し、その選択した前記制御対象基地局の行動に基づいて前記第1の行動価値関数を前記Q学習によって更新し、
前記第2の学習器は、前記第2の更新処理において、前記所定の確率によって前記敵対基地局の行動を選択し、その選択した前記敵対基地局の行動に基づいて前記第2の行動価値関数を前記Q学習によって更新する、請求項2に記載の制御装置。
【請求項4】
前記第1の行動価値関数に含まれる報酬は、
各タイムスロットにおいて前記制御対象基地局が前記フレームを送信したときに得られる第1の報酬と、
各タイムスロットにおいて前記制御対象基地局が前記フレームを送信しなかったときに得られる第2の報酬とを含む、請求項2または請求項3に記載の制御装置。
【請求項5】
前記第1の報酬は、前記制御対象基地局が前記敵対基地局による前記フレームの送信有無に関わらず前記フレームを送信するときの前記タイムスロット当たりの零以上のデータ量からなる、請求項4に記載の制御装置。
【請求項6】
前記第2の報酬は、前記制御対象基地局が前記敵対基地局による前記フレームの送信有無に関わらず前記フレームを送信しないときの正の一定値または負の一定値からなる、請求項4に記載の制御装置。
【請求項7】
前記第2の行動価値関数に含まれる報酬は、前記第1の行動価値関数に含まれる報酬の符号を反転した報酬である、請求項4から請求項6のいずれか1項に記載の制御装置。
【請求項8】
前記第1の学習器は、
前記敵対基地局によるフレームの送信確率がしきい値よりも大きいとき、前記第1の敵対的強化学習を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行して前記性能維持行動を更新し、前記N個のタイムスロットにおいて前記性能維持行動を最終的に更新するごとに前記最終的に更新した前記性能維持行動を前記第2の学習器へ出力するとともに、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の敵対的強化学習の結果を前記制御手段へ出力し、
前記フレームの送信確率が前記しきい値以下であるとき、更に、前記成功/失敗情報および前記第1の送信区間に基づいて、前記敵対基地局による妨害が存在しない通信環境において前記制御対象基地局による無線通信のスループットが最大になるスループット最大行動を学習する強化学習をN’itcr(N’itcrは、Nの自然数倍の整数)個のタイムスロットにおいて繰り返し実行して前記スループット最大行動を更新し、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の敵対的強化学習の結果に代えて前記強化学習の結果を前記制御手段へ出力し、
前記第2の学習器は、前記第1の学習器が前記強化学習を実行するとき、前記第2の敵対的強化学習を停止し、前記第1の学習器から前記性能維持行動を受けると、前記第2の敵対的強化学習を実行する、請求項1から請求項7のいずれか1項に記載の制御装置。
【請求項9】
請求項1から請求項8のいずれか1項に記載の制御装置を備える基地局。
【請求項10】
各々が基地局と端末装置とを含み、かつ、タイムスロットを用いてフレームを無線通信によって送受信する複数のサービスセットのうちの任意の1つのサービスセットである制御対象サービスセットの制御をコンピュータに実行させるためのプログラムであって、
収集手段が、前記制御対象サービスセットに含まれる基地局である制御対象基地局によるフレームの送信スケジュールである第1の送信スケジュールと、前記制御対象基地局によるフレームの送信区間である第1の送信区間と、前記制御対象基地局によるフレームの送信が成功したか失敗したかを示す成功/失敗情報と、前記制御対象基地局による無線通信を妨害する基地局である敵対基地局によるフレームの送信区間である第2の送信区間と、前記複数のサービスセットのうちの前記制御対象サービスセット以外の1個以上のサービスセットであり、かつ、前記制御対象サービスセットと協調して無線通信を行う協調サービスセットに含まれる基地局である協調基地局によるフレームの送信スケジュールである第2の送信スケジュールとを収集する第1のステップと、
第1の学習器が、前記制御対象基地局による無線通信への前記敵対基地局による妨害行動を固定して、前記成功/失敗情報と前記第1および第2の送信区間とに基づいて、前記敵対基地局による妨害が存在する通信環境において前記制御対象基地局の無線通信性能を維持する性能維持行動を学習する第1の敵対的強化学習をN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して前記第1の敵対的強化学習の結果を出力する第2のステップと、
第2の学習器が、前記制御対象基地局の前記性能維持行動を固定して、前記敵対基地局の前記妨害行動を学習する第2の敵対的強化学習を前記N個のタイムスロットと異なるN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して前記第2の敵対的強化学習の結果を出力する第3のステップと、
制御手段が、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の学習器から受けた前記第1の敵対的強化学習の結果と前記第2の送信スケジュールとに基づいて前記制御対象基地局の行動を制御する第4のステップとをコンピュータに実行させ、
前記第1の学習器は、前記第2のステップにおいて、前記第2の学習器から前記妨害行動を受けると、その受けた妨害行動を固定して、前記N個のタイムスロットにおける前記第1の敵対的強化学習をNitcr(Nitcrは、(N+N)の自然数倍の整数)個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行して前記性能維持行動を更新し、前記N個のタイムスロットにおいて前記性能維持行動を最終的に更新するごとに前記最終的に更新した前記性能維持行動を前記第2の学習器へ出力するとともに、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の敵対的強化学習の結果を前記制御手段へ出力し、
前記第2の学習器は、前記第3のステップにおいて、前記第1の学習器から前記性能維持行動を受けると、その受けた性能維持行動を固定して、前記N個のタイムスロットにおける前記第2の敵対的強化学習を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行して前記妨害行動を更新し、前記N個のタイムスロットにおいて前記妨害行動を最終的に更新するごとに前記最終的に更新した前記妨害行動を前記第1の学習器へ出力し、
前記第2のステップは、前記Nitcr個のタイムスロットにおいて、前記第3のステップと交互に実行される、コンピュータに実行させるためのプログラム。
【請求項11】
前記第1の学習器は、前記第2のステップの前記第1の敵対的強化学習において、前記制御対象基地局が前記フレームを送信する予定であるタイムスロットにおいて取得し得る報酬を累積した期待累積報酬が最大になるように第1の行動価値関数をQ学習によって更新する第1の更新処理を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行し、前記Q学習におけるQ値が最大になるときの前記第1の行動価値関数の行動を前記性能維持行動として前記第2の学習器へ出力するとともに、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記フレームの送信タイミングになったときの前記Q学習におけるQテーブルを前記第1の敵対的強化学習の結果として前記制御手段へ出力し、
前記第2の学習器は、前記第3のステップの前記第2の敵対的強化学習において、前記期待累積報酬が最小になるように第2の行動価値関数をQ学習によって更新する第2の更新処理を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行し、前記Q学習におけるQ値が最小になるときの前記第2の行動価値関数の行動を前記妨害行動として前記第1の学習器へ出力し、
前記第1の行動価値関数は、前記制御対象基地局が自己の行動を選択することである方策に基づいて前記協調基地局による前記フレームの送信有無の状態を示す第1の状態と、前記制御対象基地局および前記敵対基地局の過去の所定数のタイムスロットにおける前記フレームの送信有無の履歴の状態を示す第2の状態とから状態集合のうちの1つの状態において前記制御対象基地局が実行可能な行動集合のうちの1つの行動を実行するときの価値を表し、
前記第2の行動価値関数は、前記敵対基地局が自己の行動を選択することである方策に基づいて前記状態集合のうちの1つの状態において前記敵対基地局が前記フレームの送信を行う行動と前記敵対基地局が前記フレームの送信を行わない行動とのうちの1つの行動を実行するときの価値を表す、請求項10に記載のコンピュータに実行させるためのプログラム。
【請求項12】
前記第1の学習器は、前記第2のステップの前記第1の更新処理において、所定の確率によって前記制御対象基地局の行動を選択し、その選択した前記制御対象基地局の行動に基づいて前記第1の行動価値関数を前記Q学習によって更新し、
前記第2の学習器は、前記第3のステップの前記第2の更新処理において、前記所定の確率によって前記敵対基地局の行動を選択し、その選択した前記敵対基地局の行動に基づいて前記第2の行動価値関数を前記Q学習によって更新する、請求項11に記載のコンピュータに実行させるためのプログラム。
【請求項13】
前記第1の行動価値関数に含まれる報酬は、
各タイムスロットにおいて前記制御対象基地局が前記フレームを送信したときに得られる第1の報酬と、
各タイムスロットにおいて前記制御対象基地局が前記フレームを送信しなかったときに得られる第2の報酬とを含む、請求項11または請求項12に記載のコンピュータに実行させるためのプログラム。
【請求項14】
前記第1の報酬は、前記制御対象基地局が前記敵対基地局による前記フレームの送信有無に関わらず前記フレームを送信するときの前記タイムスロット当たりの零以上のデータ量からなる、請求項13に記載のコンピュータに実行させるためのプログラム。
【請求項15】
前記第2の報酬は、前記制御対象基地局が前記敵対基地局による前記フレームの送信有無に関わらず前記フレームを送信しないときの正の一定値または負の一定値からなる、請求項13に記載のコンピュータに実行させるためのプログラム。
【請求項16】
前記第2の行動価値関数に含まれる報酬は、前記第1の行動価値関数に含まれる報酬の符号を反転した報酬である、請求項13から請求項15のいずれか1項に記載のコンピュータに実行させるためのプログラム。
【請求項17】
前記第1の学習器は、前記第2のステップにおいて、
前記敵対基地局によるフレームの送信確率がしきい値よりも大きいとき、前記第1の敵対的強化学習を前記Nitcr個のタイムスロット内の前記N個のタイムスロットごとに繰り返し実行して前記性能維持行動を更新し、前記N個のタイムスロットにおいて前記性能維持行動を最終的に更新するごとに前記最終的に更新した前記性能維持行動を前記第2の学習器へ出力するとともに、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の敵対的強化学習の結果を前記制御手段へ出力し、
前記フレームの送信確率が前記しきい値以下であるとき、更に、前記成功/失敗情報および前記第1の送信区間に基づいて、前記敵対基地局による妨害が存在しない通信環境において前記制御対象基地局による無線通信のスループットが最大になるスループット最大行動を学習する強化学習をN’itcr(N’itcrは、Nの自然数倍の整数)個のタイムスロットにおいて繰り返し実行して前記スループット最大行動を更新し、前記第1の送信スケジュールに基づいて前記制御対象基地局による前記フレームの送信タイミングになったことを検知すると、前記第1の敵対的強化学習の結果に代えて前記強化学習の結果を前記制御手段へ出力し、
前記第2の学習器は、前記第3のステップにおいて、前記第1の学習器が前記強化学習を実行するとき、前記第2の敵対的強化学習を停止し、前記第1の学習器から前記性能維持行動を受けると、前記第2の敵対的強化学習を実行する、請求項10から請求項16のいずれか1項に記載のコンピュータに実行させるためのプログラム。
【請求項18】
請求項10から請求項17のいずれか1項に記載のプログラムを記録したコンピュータ読み取り可能な記録媒体。
【発明の詳細な説明】
【技術分野】
【0001】
この発明は、制御装置、それを備えた基地局、コンピュータに実行させるためのプログラムおよびプログラムを記録したコンピュータ読み取り可能な記録媒体に関するものである。
【背景技術】
【0002】
最近、無線通信は、急速に普及しており、それにより、無線デバイスが稠密に配置されるようになっている。このため、無線デバイスは、その通信機会を求めて競合を起こしている。無線通信では、このような状況でも通信が行えるようにCSMA/CA(Carrier Sense Multiple Access with Collision Avoidance)によるアクセス制御を行っているが、この方式では、無線デバイスが稠密であればあるほど近くのAP(Access Point)と干渉が起こり易くなり、結果として、フレーム損失が発生し、スループットが大幅に低下してしまう。
【0003】
このような問題を解決するために、無線LAN(Local Area Network)における複数のAPを協調させ、複数のAPのフレーム送信情報を集約することと、強化学習により集約した情報を活用することが提案されている(非特許文献1)。
【0004】
具体的には、他のAPの過去・未来の送信区間情報を収集することで他のAPの通信によって受ける干渉の程度や通信失敗要因を推定し、その推定に基づいて適切な通信タイミングや伝送速度の選択を行う。これにより、他の通信からの干渉により通信失敗が起こらない中で最大の伝送速度を選択することができ、結果として周波数利用効率を改善することができる。
【先行技術文献】
【非特許文献】
【0005】
【文献】山本高至、紀平悠人、香田優介、西尾理志、守倉正博, “無線LANにおける冗長検査情報による通信品質要因解析,”2020年 電子情報通信学会総合大会,B-5-147, p. 435.
【文献】L. Pinto, J. Davidson, R. Sukthankar, and A. Gupta, “Robust adversarial reinforcement learning," Proc. ICML, pp.2817-2826, Sydney, Australia, Aug. 2017.
【文献】M.L. Littman, “Markov games as a framework for multiagent reinforcement learning," Proc. ICML-94, pp.157-163, New Brunswick, NJ, USA, Jul. 1994.
【文献】J. Perolat, B. Scherrer, and O. Pietquin, “Approximate dynamic programming for two-player zero-sum markov games," Proc. ICML, pp.1321-1329, Lille, France, Jul. 2015.
【文献】R.S. Sutton and Andrew G.Barto, Reinforcement Learning:An Introduction, MIT, Cambridge, 1998.
【発明の概要】
【発明が解決しようとする課題】
【0006】
しかし、非特許文献1における方式においては、運用段階において通信環境に存在する全てのAPが協調するとは限らず、制御対象のAPの付近に制御外のAPが存在する可能性がある。このような場合、非特許文献1における方式においては、協調しているAP群から収集した情報に基づいて通信失敗要因を推定するため、制御外のAPが原因で通信に失敗した場合、推定と通信の成否の結果が一致せず、学習が不安定になってしまうという問題がある。また、学習を行うことで制御外のAPが存在する場合に適応したとしても、通信環境(制御外のAPのフレーム送出確率など)が変化すると、獲得していた方策では新たな通信環境に即座に対応することができず、パフォーマンスが低下してしまうという問題もある。
【0007】
そこで、この発明の実施の形態によれば、制御外のAPが存在しても無線通信におけるスループットを向上させる制御を実行する制御装置を提供する。
【0008】
また、この発明の実施の形態によれば、制御外のAPが存在しても無線通信におけるスループットを向上させる制御を実行する制御装置を備える基地局を提供する。
【0009】
更に、この発明の実施の形態によれば、制御外のAPが存在しても無線通信におけるスループットを向上させる制御をコンピュータに実行させるためのプログラムを提供する。
【0010】
更に、この発明の実施の形態によれば、制御外のAPが存在しても無線通信におけるスループットを向上させる制御をコンピュータに実行させるためのプログラムを記録したコンピュータ読み取り可能な記録媒体を提供する。
【課題を解決するための手段】
【0011】
(構成1)
この発明の実施の形態によれば、制御装置は、各々が基地局と端末装置とを含み、かつ、タイムスロットを用いてフレームを無線通信によって送受信する複数のサービスセットのうちの任意の1つのサービスセットである制御対象サービスセットを制御する制御装置であって、収集手段と、第1および第2の学習器と、制御手段とを備える。収集手段は、制御対象サービスセットに含まれる基地局である制御対象基地局によるフレームの送信スケジュールである第1の送信スケジュールと、制御対象基地局によるフレームの送信区間である第1の送信区間と、制御対象基地局によるフレームの送信が成功したか失敗したかを示す成功/失敗情報と、制御対象基地局による無線通信を妨害する基地局である敵対基地局によるフレームの送信区間である第2の送信区間と、複数のサービスセットのうちの制御対象サービスセット以外の1個以上のサービスセットであり、かつ、制御対象サービスセットと協調して無線通信を行う協調サービスセットに含まれる基地局である協調基地局によるフレームの送信スケジュールである第2の送信スケジュールとを収集する。第1の学習器は、制御対象基地局による無線通信への敵対基地局による妨害行動を固定して、成功/失敗情報と第1および第2の送信区間とに基づいて、敵対基地局による妨害が存在する通信環境において制御対象基地局の無線通信性能を維持する性能維持行動を学習する第1の敵対的強化学習をN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して第1の敵対的強化学習の結果を出力する。第2の学習器は、制御対象基地局の性能維持行動を固定して、敵対基地局の妨害行動を学習する第2の敵対的強化学習をN個のタイムスロットと異なるN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して第2の敵対的強化学習の結果を出力する。制御手段は、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の学習器から受けた第1の敵対的強化学習の結果と第2の送信スケジュールとに基づいて制御対象基地局の行動を制御する。そして、第1の学習器は、第2の学習器から妨害行動を受けると、その受けた妨害行動を固定して、N個のタイムスロットにおける第1の敵対的強化学習をNitcr(Nitcrは、(N+N)の自然数倍の整数)個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して性能維持行動を更新し、N個のタイムスロットにおいて性能維持行動を最終的に更新するごとに最終的に更新した性能維持行動を第2の学習器へ出力するとともに、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の敵対的強化学習の結果を制御手段へ出力する。また、第2の学習器は、第1の学習器から性能維持行動を受けると、その受けた性能維持行動を固定して、N個のタイムスロットにおける第2の敵対的強化学習をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して妨害行動を更新し、N個のタイムスロットにおいて妨害行動を最終的に更新するごとに最終的に更新した妨害行動を第1の学習器へ出力する。第1の学習器は、Nitcr個のタイムスロットにおいて、N個のタイムスロットにおける第1の敵対的強化学習をN個のタイムスロットにおける第2の学習器による第2の敵対的強化学習と交互に実行する。
【0012】
(構成2)
構成1において、第1の学習器は、第1の敵対的強化学習において、制御対象基地局がフレームを送信する予定であるタイムスロットにおいて取得し得る報酬を累積した期待累積報酬が最大になるように第1の行動価値関数をQ学習によって更新する第1の更新処理をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行し、Q学習におけるQ値が最大になるときの第1の行動価値関数の行動を性能維持行動として第2の学習器へ出力するとともに、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、フレームの送信タイミングになったときのQ学習におけるQテーブルを第1の敵対的強化学習の結果として制御手段へ出力する。第2の学習器は、第2の敵対的強化学習において、期待累積報酬が最小になるように第2の行動価値関数をQ学習によって更新する第2の更新処理をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行し、Q学習におけるQ値が最小になるときの第2の行動価値関数の行動を妨害行動として第1の学習器へ出力する。第1の行動価値関数は、制御対象基地局が自己の行動を選択することである方策に基づいて協調基地局によるフレームの送信有無の状態を示す第1の状態と、制御対象基地局および敵対基地局の過去の所定数のタイムスロットにおけるフレームの送信有無の履歴の状態を示す第2の状態とから状態集合のうちの1つの状態において制御対象基地局が実行可能な行動集合のうちの1つの行動を実行するときの価値を表す。第2の行動価値関数は、敵対基地局が自己の行動を選択することである方策に基づいて状態集合のうちの1つの状態において敵対基地局がフレームの送信を行う行動と敵対基地局がフレームの送信を行わない行動とのうちの1つの行動を実行するときの価値を表す。
【0013】
(構成3)
構成2において、第1の学習器は、第1の更新処理において、所定の確率によって制御対象基地局の行動を選択し、その選択した制御対象基地局の行動に基づいて第1の行動価値関数をQ学習によって更新する。第2の学習器は、第2の更新処理において、所定の確率によって敵対基地局の行動を選択し、その選択した敵対基地局の行動に基づいて第2の行動価値関数をQ学習によって更新する。
【0014】
(構成4)
構成2または構成3において、第1の行動価値関数に含まれる報酬は、各タイムスロットにおいて制御対象基地局がフレームを送信したときに得られる第1の報酬と、各タイムスロットにおいて制御対象基地局がフレームを送信しなかったときに得られる第2の報酬とを含む。
【0015】
(構成5)
構成4において、第1の報酬は、制御対象基地局が敵対基地局によるフレームの送信有無に関わらずフレームを送信するときのタイムスロット当たりの零以上のデータ量からなる。
【0016】
(構成6)
構成4において、第2の報酬は、制御対象基地局が敵対基地局によるフレームの送信有無に関わらずフレームを送信しないときの正の一定値または負の一定値からなる。
【0017】
(構成7)
構成4から構成6のいずれかにおいて、第2の行動価値関数に含まれる報酬は、第1の行動価値関数に含まれる報酬の符号を反転した報酬である。
【0018】
(構成8)
構成1から構成7のいずれかにおいて、第1の学習器は、敵対基地局によるフレームの送信確率がしきい値よりも大きいとき、第1の敵対的強化学習をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して性能維持行動を更新し、N個のタイムスロットにおいて性能維持行動を最終的に更新するごとに最終的に更新した性能維持行動を第2の学習器へ出力するとともに、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の敵対的強化学習の結果を制御手段へ出力し、フレームの送信確率がしきい値以下であるとき、更に、成功/失敗情報および第1の送信区間に基づいて、敵対基地局による妨害が存在しない通信環境において制御対象基地局による無線通信のスループットが最大になるスループット最大行動を学習する強化学習をN’itcr(N’itcrは、Nの自然数倍の整数)個のタイムスロットにおいて繰り返し実行してスループット最大行動を更新し、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の敵対的強化学習の結果に代えて強化学習の結果を制御手段へ出力する。第2の学習器は、第1の学習器が強化学習を実行するとき、第2の敵対的強化学習を停止し、第1の学習器から性能維持行動を受けると、第2の敵対的強化学習を実行する。
【0019】
(構成9)
また、この発明の実施の形態によれば、基地局は、構成1から構成8のいずれかに記載の制御装置を備える。
【0020】
(構成10)
更に、この発明の実施の形態によれば、プログラムは、各々が基地局と端末装置とを含み、かつ、タイムスロットを用いてフレームを無線通信によって送受信する複数のサービスセットのうちの任意の1つのサービスセットである制御対象サービスセットの制御をコンピュータに実行させるためのプログラムであって、
収集手段が、制御対象サービスセットに含まれる基地局である制御対象基地局によるフレームの送信スケジュールである第1の送信スケジュールと、制御対象基地局によるフレームの送信区間である第1の送信区間と、制御対象基地局によるフレームの送信が成功したか失敗したかを示す成功/失敗情報と、制御対象基地局による無線通信を妨害する基地局である敵対基地局によるフレームの送信区間である第2の送信区間と、複数のサービスセットのうちの制御対象サービスセット以外の1個以上のサービスセットであり、かつ、制御対象サービスセットと協調して無線通信を行う協調サービスセットに含まれる基地局である協調基地局によるフレームの送信スケジュールである第2の送信スケジュールとを収集する第1のステップと、
第1の学習器が、制御対象基地局による無線通信への敵対基地局による妨害行動を固定して、成功/失敗情報と第1および第2の送信区間とに基づいて、敵対基地局による妨害が存在する通信環境において制御対象基地局の無線通信性能を維持する性能維持行動を学習する第1の敵対的強化学習をN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して第1の敵対的強化学習の結果を出力する第2のステップと、
第2の学習器が、制御対象基地局の性能維持行動を固定して、敵対基地局の妨害行動を学習する第2の敵対的強化学習をN個のタイムスロットと異なるN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行して第2の敵対的強化学習の結果を出力する第3のステップと、
制御手段が、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の学習器から受けた第1の敵対的強化学習の結果と第2の送信スケジュールとに基づいて制御対象基地局の行動を制御する第4のステップとをコンピュータに実行させ、
第1の学習器は、第2のステップにおいて、第2の学習器から妨害行動を受けると、その受けた妨害行動を固定して、N個のタイムスロットにおける第1の敵対的強化学習をNitcr(Nitcrは、(N+N)の自然数倍の整数)個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して性能維持行動を更新し、N個のタイムスロットにおいて性能維持行動を最終的に更新するごとに最終的に更新した性能維持行動を第2の学習器へ出力するとともに、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の敵対的強化学習の結果を制御手段へ出力し、
第2の学習器は、第3のステップにおいて、第1の学習器から性能維持行動を受けると、その受けた性能維持行動を固定して、N個のタイムスロットにおける第2の敵対的強化学習をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して妨害行動を更新し、N個のタイムスロットにおいて妨害行動を最終的に更新するごとに最終的に更新した妨害行動を第1の学習器へ出力し、
第2のステップは、Nitcr個のタイムスロットにおいて、第3のステップと交互に実行される、コンピュータに実行させるためのプログラムである。
【0021】
(構成11)
構成10において、第1の学習器は、第2のステップの第1の敵対的強化学習において、制御対象基地局がフレームを送信する予定であるタイムスロットにおいて取得し得る報酬を累積した期待累積報酬が最大になるように第1の行動価値関数をQ学習によって更新する第1の更新処理をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行し、Q学習におけるQ値が最大になるときの第1の行動価値関数の行動を性能維持行動として第2の学習器へ出力するとともに、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、フレームの送信タイミングになったときのQ学習におけるQテーブルを第1の敵対的強化学習の結果として制御手段へ出力する。第2の学習器は、第3のステップの第2の敵対的強化学習において、期待累積報酬が最小になるように第2の行動価値関数をQ学習によって更新する第2の更新処理をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行し、Q学習におけるQ値が最小になるときの第2の行動価値関数の行動を妨害行動として第1の学習器へ出力する。第1の行動価値関数は、制御対象基地局が自己の行動を選択することである方策に基づいて協調基地局によるフレームの送信有無の状態を示す第1の状態と、制御対象基地局および敵対基地局の過去の所定数のタイムスロットにおけるフレームの送信有無の履歴の状態を示す第2の状態とから状態集合のうちの1つの状態において制御対象基地局が実行可能な行動集合のうちの1つの行動を実行するときの価値を表す。第2の行動価値関数は、敵対基地局が自己の行動を選択することである方策に基づいて状態集合のうちの1つの状態において敵対基地局がフレームの送信を行う行動と敵対基地局がフレームの送信を行わない行動とのうちの1つの行動を実行するときの価値を表す。
【0022】
(構成12)
構成11において、第1の学習器は、第2のステップの第1の更新処理において、所定の確率によって制御対象基地局の行動を選択し、その選択した制御対象基地局の行動に基づいて第1の行動価値関数をQ学習によって更新する。第2の学習器は、第3のステップの第2の更新処理において、所定の確率によって敵対基地局の行動を選択し、その選択した敵対基地局の行動に基づいて第2の行動価値関数をQ学習によって更新する。
【0023】
(構成13)
構成11または構成12において、第1の行動価値関数に含まれる報酬は、各タイムスロットにおいて制御対象基地局がフレームを送信したときに得られる第1の報酬と、各タイムスロットにおいて制御対象基地局がフレームを送信しなかったときに得られる第2の報酬とを含む。
【0024】
(構成14)
構成13において、第1の報酬は、制御対象基地局が敵対基地局によるフレームの送信有無に関わらずフレームを送信するときのタイムスロット当たりの零以上のデータ量からなる。
【0025】
(構成15)
構成13において、第2の報酬は、制御対象基地局が敵対基地局によるフレームの送信有無に関わらずフレームを送信しないときの正の一定値または負の一定値からなる。
【0026】
(構成16)
構成13から構成15のいずれかにおいて、第2の行動価値関数に含まれる報酬は、第1の行動価値関数に含まれる報酬の符号を反転した報酬である。
【0027】
(構成17)
構成10から構成16のいずれかにおいて、第1の学習器は、第2のステップにおいて、敵対基地局によるフレームの送信確率がしきい値よりも大きいとき、第1の敵対的強化学習をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して性能維持行動を更新し、N個のタイムスロットにおいて性能維持行動を最終的に更新するごとに最終的に更新した性能維持行動を第2の学習器へ出力するとともに、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、第1の敵対的強化学習の結果を制御手段へ出力し、フレームの送信確率がしきい値以下であるとき、更に、成功/失敗情報および第1の送信区間に基づいて、敵対基地局による妨害が存在しない通信環境において制御対象基地局による無線通信のスループットが最大になるスループット最大行動を学習する強化学習をN’itcr(N’itcrは、Nの自然数倍の整数)個のタイムスロットにおいて繰り返し実行してスループット最大行動を更新し、第1の送信スケジュールに基づいて制御対象基地局によるフレームの送信タイミングになったことを検知すると、1の敵対的強化学習の結果に代えて強化学習の結果を制御手段へ出力する。第2の学習器は、第3のステップにおいて、第1の学習器が強化学習を実行するとき、第2の敵対的強化学習を停止し、第1の学習器から性能維持行動を受けると、第2の敵対的強化学習を実行する。
【0028】
(構成18)
更に、この発明の実施の形態によれば、記録媒体は、構成10から構成17のいずれかに記載のプログラムを記録したコンピュータ読み取り可能な記録媒体である。
【発明の効果】
【0029】
制御外のAPが存在しても無線通信におけるスループットを向上できる。
【図面の簡単な説明】
【0030】
図1】この発明の実施の形態による通信システムの概略図である。
図2図1に示す制御装置の概略図である。
図3】制御対象のアクセスポイントから収集した情報を記憶する対応表の概念図である。
図4】制御対象のアクセスポイントによる無線通信を妨害するアクセスポイントのフレームの送信区間を記憶する対応表の概念図である。
図5】協調APであるアクセスポイントの送信スケジュールを記憶する対応表の概念図である。
図6】敵対的強化学習の方法を説明するための図である。
図7】協調アクセスポイントの状態を説明するための図である。
図8】協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す図である。
図9】協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す図である。
図10】協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す図である。
図11】制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)をQ学習によって更新するときのQテーブルの概念図である。
図12】敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)をQ学習によって更新するときのQテーブルの概念図である。
図13】Qテーブルの更新方法を説明するための第1の概略図である。
図14】Qテーブルの更新方法を説明するための第2の概略図である。
図15】Qテーブルの更新方法を説明するための第3の概略図である。
図16】Qテーブルの更新方法を説明するための第4の概略図である。
図17】Qテーブルの更新方法を説明するための第5の概略図である。
図18】Qテーブルの更新方法を説明するための第6の概略図である。
図19】Qテーブルの更新方法を説明するための第7の概略図である。
図20】制御対象のアクセスポイントおよび敵対アクセスポイントの通信の履歴を示す図である。
図21図1に示す制御装置の動作を説明するためのフローチャートである。
図22図21のステップS7の詳細な動作を説明するためのフローチャートである。
図23図22のステップS74の詳細な動作を説明するためのフローチャートである。
図24図22のステップS77の詳細な動作を説明するためのフローチャートである。
図25】敵対的強化学習と制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVによる無線通信との関係を示す図である。
図26図1に示す通信システムの動作を説明するためのフローチャートである。
図27】制御対象のアクセスポイントおよび協調外のアクセスポイントのスループットの和と、協調外のアクセスポイントによるフレームの送信確率との関係を示す図である。
図28】制御対象のアクセスポイントの送信確率と協調外のアクセスポイントによるフレームの送信確率との関係を示す図である。
図29図1に示す制御装置の別の概略図である。
図30】敵対アクセスポイント無しの強化学習におけるQテーブルの概念図である。
図31】敵対アクセスポイント無しの強化学習におけるQテーブルの更新方法を説明するための第1の概略図である。
図32】敵対アクセスポイント無しの強化学習におけるQテーブルの更新方法を説明するための第2の概略図である。
図33】敵対アクセスポイント無しの強化学習におけるQテーブルの更新方法を説明するための第3の概略図である。
図34図29に示す制御装置の動作を説明するためのフローチャートである。
図35図34のステップS11の詳細な動作を説明するためのフローチャートである。
図36図35のステップS115の詳細な動作を説明するためのフローチャートである。
図37図1に示す制御装置を備えるアクセスポイントの概略図である。
【発明を実施するための形態】
【0031】
本発明の実施の形態について図面を参照しながら詳細に説明する。なお、図中同一または相当部分には同一符号を付してその説明は繰返さない。
【0032】
図1は、この発明の実施の形態による通信システムの概略図である。図1を参照して、この発明の実施の形態による通信システム100は、制御装置10と、BSS_1~BSS_N(Nは、2以上の整数)と、BSS_UNCOORDとを備える。
【0033】
BSS_1~BSS_N,BSS_UNCOORDの各々は、アクセスポイントAPと端末装置TMとからなるBSS(Basic Service Set)である。以下、BSSを「サービスセット」と言う。
【0034】
サービスセットBSS_1は、アクセスポイントAP_1と端末装置TM_1とからなる。サービスセットBSS_2は、アクセスポイントAP_2と端末装置TM_2とからなる。以下、同様にして、サービスセットBSS_N-1は、アクセスポイントAP_N-1と端末装置TM_N-1とからなり、サービスセットBSS_Nは、アクセスポイントAP_Nと端末装置TM_Nとからなる。サービスセットBSS_UNCOORDは、アクセスポイントAP_UNCOORDと端末装置TM_UNCOORDとからなる。
【0035】
サービスセットBSS_1~BSS_Nは、フレームの送信情報を共有し、相互に協調して無線通信を行うサービスセットである。サービスセットBSS_UNCOORDは、サービスセットBSS_1~BSS_Nにおける無線通信を妨害するサービスセットである。
【0036】
アクセスポイントAP_1~AP_Nは、それぞれ、タイムスロットを用いて端末装置TM_1~TM_Nと相互に無線通信を行う。アクセスポイントAP_UNCOORDは、アクセスポイントAP_1~AP_Nのうちの制御対象のアクセスポイントAP_CTLにおける無線通信を妨害するように、タイムスロットを用いて端末装置TM_UNCOORDと相互に無線通信を行う。
【0037】
制御対象のアクセスポイントAP_CTLは、アクセスポイントAP_1~AP_Nのうちの任意の1つのアクセスポイントAPからなる。アクセスポイントAP_1~AP_Nのうちの制御対象のアクセスポイントAP_CTL以外のアクセスポイントAPは、協調APである。
【0038】
以下においては、例えば、アクセスポイントAP_Nを制御対象のアクセスポイントAP_CTLとし、アクセスポイントAP_1~AP_N-1を協調APとする。そして、アクセスポイントAP_UNCOORDは、制御対象のアクセスポイントAP_CTLと協調して無線通信を行わない協調外のアクセスポイントである。
【0039】
制御対象のアクセスポイントAP_CTLであるアクセスポイントAP_Nは、フレームを端末装置TM_Nへ送信し、その後、端末装置TM_NからACKを受信したか否かによってフレームの端末装置TM_Nへの送信が成功したか失敗したかを判定することによってフレームの端末装置TM_Nへの送信が成功したか失敗したかを示す成功/失敗情報IF_SUCCESS/FAILUREを検出する。この場合、アクセスポイントAP_Nは、端末装置TM_NからACKを受信したとき、フレームの端末装置TM_Nへの送信が成功したと判定し、端末装置TM_NからACKを受信しないとき、フレームの端末装置TM_Nへの送信が失敗したと判定する。
【0040】
また、アクセスポイントAP_Nは、フレームの送信に用いた送信区間TRS_CTLと、各送信区間TRS_CTLにおけるフレームの伝送速度TRD_CTLとを検出する。
【0041】
更に、アクセスポイントAP_Nは、フレームの送信を予定する送信スケジュールSCH_CTLを生成する。
【0042】
そして、アクセスポイントAP_Nは、送信者としての自己のMACアドレスAdd_AP_N、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTLおよび送信スケジュールSCH_CTLを制御装置10へ送信する。
【0043】
更に、アクセスポイントAP_Nは、アクセスポイントAP_UNCOORDと端末装置TM_UNCOORDとの無線通信を検知したとき、アクセスポイントAP_UNCOORDおよび端末装置TM_UNCOORDが相互に無線通信を行った送信区間TRS_UNCOORDを検出する。そして、アクセスポイントAP_Nは、アクセスポイントAP_UNCOORDのMACアドレスAdd_AP_UNCOORDと送信区間TRS_UNCOORDとを制御装置10へ送信する。
【0044】
協調APであるアクセスポイントAP_1~AP_N-1は、アクセスポイントAP_N(=制御対象のアクセスポイントAP_CTL)とフレーム送信情報を共有し、アクセスポイントAP_N(=制御対象のアクセスポイントAP_CTL)と協調して、それぞれ、端末装置TM_1~TM_N-1と相互に無線通信を行う。
【0045】
そして、アクセスポイントAP_1~AP_N-1は、それぞれ、フレームの送信を予定する送信スケジュールSCH_COORD_1~SCH_COORD_N-1を生成し、その生成した送信スケジュールSCH_COORD_1~SCH_COORD_N-1とMACアドレスAdd_AP_1~Add_AP_N-1とを制御装置10へ送信する。
【0046】
アクセスポイントAP_UNCOORDは、アクセスポイントAP_N(=制御対象のアクセスポイントAP_CTL)とフレーム送信情報を共有することなく、アクセスポイントAP_N(=制御対象のアクセスポイントAP_CTL)による無線通信を妨害するように端末装置TM_UNCOORDと相互に無線通信を行う。
【0047】
なお、図1においては、サービスセットBSS_1~BSS_N,BSS_UNCOORDの各々は、1つのアクセスポイントAPと1つの端末装置TMとからなるように示されているが、この発明の実施の形態においては、これに限らず、サービスセットBSS_1~BSS_N,BSS_UNCOORDの各々は、1つのアクセスポイントAPと複数の端末装置TMとからなっていてもよい。
【0048】
制御装置10は、有線ケーブルを介してアクセスポイントAP_1~AP_Nと接続されている。そして、制御装置10は、有線ケーブルを介して制御対象のアクセスポイントAP_NからMACアドレスAdd_AP_N、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL、MACアドレスAdd_AP_UNCOORDおよび送信区間TRS_UNCOORDを収集し、協調APのアクセスポイントAP_1~AP_N-1からそれぞれMACアドレスAdd_AP_1~Add_AP_N-1および送信スケジュールSCH_COORD_1~SCH_COORD_N-1を収集する。
【0049】
制御装置10は、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL、送信区間TRS_UNCOORDおよび送信スケジュールSCH_COORD(=SCH_COORD_1~SCH_COORD_N-1)に基づいて、後述する方法によって、敵対的強化学習を実行して、アクセスポイントAP_Nと端末装置TM_Nとの無線通信へのアクセスポイントAP_UNCOORDによる妨害が存在する通信環境において、アクセスポイントAP_Nの無線通信性能を維持するアクセスポイントAP_Nの行動(「性能維持行動」と言う。)を生成し、その生成した性能維持行動を行うように制御対象のアクセスポイントAP_Nを制御する。
【0050】
図2は、図1に示す制御装置10の概略図である。図2を参照して、制御装置10は、収集手段1と、データベース2と、制御手段3と、学習器4,5とを備える。
【0051】
収集手段1は、有線ケーブル6を介して制御対象のアクセスポイントAP_NからMACアドレスAdd_AP_N、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL、MACアドレスAdd_AP_UNCOORDおよび送信区間TRS_UNCOORDを受信し、協調APのアクセスポイントAP_1~AP_N-1からそれぞれMACアドレスAdd_AP_1~Add_AP_N-1および送信スケジュールSCH_COORD_1~SCH_COORD_N-1を受信する。
【0052】
そして、収集手段1は、その受信したMACアドレスAdd_AP_N、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL、MACアドレスAdd_AP_UNCOORD、送信区間TRS_UNCOORD、MACアドレスAdd_AP_1~Add_AP_N-1および送信スケジュールSCH_COORD_1~SCH_COORD_N-1をデータベース2に格納する。
【0053】
データベース2は、MACアドレスAdd_AP_N、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL、MACアドレスAdd_AP_UNCOORD、送信区間TRS_UNCOORD、MACアドレスAdd_AP_1~Add_AP_N-1および送信スケジュールSCH_COORD(=SCH_COORD_1~SCH_COORD_N-1)を記憶する。
【0054】
制御手段3は、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL、送信区間TRS_UNCOORDおよび送信スケジュールSCH_COORDをデータベース2から読み出す。そして、制御手段3は、アクセスポイントAP_Nが制御対象のアクセスポイントAP_CTLであることを示す信号S_CTL_AP(AP_N)を生成する。その後、制御手段3は、後述する方法によって、送信区間TRS_CTLおよび送信区間TRS_UNCOORDに基づいて、直近Xスロットにおける制御対象のアクセスポイントAP_Nおよび協調外のアクセスポイントAP_UNCOORDによるフレームの送信有無の履歴Shistoryを生成する。そうすると、制御手段3は、信号S_CTL_AP(AP_N)、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、送信区間TRS_UNCOORD、伝送速度TRD_CTL、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを学習器4,5へ出力する。
【0055】
また、制御手段3は、制御対象のアクセスポイントAP_Nが次にフレームを送信するタイミングになると、敵対的強化学習の結果を学習器4から受け、その受けた敵対的強化学習の結果に基づいて、次にフレームを送信するタイムスロットにおける制御対象のアクセスポイントAP_Nの行動を制御する。
【0056】
更に、制御手段3は、制御対象のアクセスポイントAP_Nが次にフレームを送信するタイミングになると、敵対的強化学習の結果を学習器5から受け、その受けた敵対的強化学習の結果に基づいて、次にフレームを送信するタイムスロットにおける協調外のアクセスポイントAP_UNCOORDの行動を制御する。
【0057】
学習器4は、信号S_CTL_AP(AP_N)、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを制御手段3から受ける。そして、学習器4は、信号S_CTL_AP(AP_N)に基づいて、アクセスポイントAP_Nが制御対象のアクセスポイントAP_CTLであり、アクセスポイントAP_1~AP_N-1が協調APであることを検知する。また、学習器4は、アクセスポイントAP_UNCOORDの行動価値関数FUNCTION_UNCOORDを学習器5から受ける。
【0058】
そうすると、学習器4は、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを入力情報として、後述する方法によって、アクセスポイントAP_UNCOORDの行動価値関数FUNCTION_UNCOORDを固定して敵対的強化学習をN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行することによって制御対象のアクセスポイントAP_Nの期待累積報酬が最大になるように制御対象のアクセスポイントAP_Nの行動価値関数FUNCTION_CTLを繰り返し更新し、その更新した行動価値関数FUNCTION_CTLを学習器5へ出力することをNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行する。
【0059】
また、学習器4は、送信スケジュールSCH_CTLに基づいて制御対象のアクセスポイントAP_Nが次にフレームを送信するタイミングになったことを検知すると、制御対象のアクセスポイントAP_Nが次にフレームを送信するタイミングになったときの敵対的強化学習の結果を制御手段3へ出力する。
【0060】
学習器5は、信号S_CTL_AP(AP_N)、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを制御手段3から受ける。そして、学習器5は、信号S_CTL_AP(AP_N)に基づいて、アクセスポイントAP_Nが制御対象のアクセスポイントAP_CTLであり、アクセスポイントAP_1~AP_N-1が協調APであることを検知する。また、学習器5は、制御対象のアクセスポイントAP_Nの行動価値関数FUNCTION_CTLを学習器4から受ける。
【0061】
そうすると、学習器5は、制御対象のアクセスポイントAP_Nの行動価値関数FUNCTION_CTLを固定して敵対的強化学習をN(Nは、1以上の整数)個のタイムスロットにおいて繰り返し実行することによって制御対象のアクセスポイントAP_Nの期待累積報酬が最小になるようにアクセスポイントAP_UNCOORDの行動価値関数FUNCTION_UNCOORDを繰り返し更新し、その更新した行動価値関数FUNCTION_UNCOORDを学習器4へ出力することをNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行する。
【0062】
また、学習器5は、送信スケジュールSCH_CTLに基づいて制御対象のアクセスポイントAP_Nが次にフレームを送信するタイミングになったことを検知すると、制御対象のアクセスポイントAP_Nが次にフレームを送信するタイミングになったときの敵対的強化学習の結果を制御手段3へ出力する。
【0063】
このように、学習器4は、学習器5から出力されるアクセスポイントAP_UNCOORDの行動価値関数FUNCTION_UNCOORDを固定して敵対的強化学習を実行し、学習器5は、学習器4から出力されるアクセスポイントAP_Nの行動価値関数FUNCTION_CTLを固定して敵対的強化学習する。つまり、学習器4,5は、それぞれN個のタイムスロットおよびN個のタイムスロットにおいて敵対的強化学習を交互に実行することをNitcr個のタイムスロットにおいて実行する。従って、Nitcrは、(N+N)を自然数倍した整数からなる。
【0064】
また、学習器4,5は、制御対象のアクセスポイントAP_Nの送信スケジュールSCH_CTLに基づいて制御対象のアクセスポイントAP_Nによるフレームの送信タイミングになったことを検知すると、制御対象のアクセスポイントAP_Nによるフレームの送信タイミングにおける敵対的強化学習の最新の結果を制御手段3へ出力する。
【0065】
図3は、制御対象のアクセスポイントAP_Nから収集した情報を記憶する対応表の概念図である。
【0066】
図3を参照して、テーブルTBL1-1は、名前と、送信者と、送信区間と、伝送速度と、成功/失敗情報と、送信スケジュールとを含む。
【0067】
名前、送信者、送信区間、伝送速度、成功/失敗情報および送信スケジュールは、相互に対応付けられる。
【0068】
送信者は、制御対象であるアクセスポイントAP_NのMACアドレスAdd_AP_Nからなる。送信区間は、過去の直近Xスロットにおいて、アクセスポイントAP_Nがフレームの送信に用いたタイムスロットの開始時刻および終了時刻[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・からなる。その結果、開始時刻および終了時刻[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・で表される送信区間以外の送信区間は、過去の直近Xスロットにおいて、アクセスポイントAP_Nがフレームを送信しなかったタイムスロットを表す。伝送速度は、TR_rate_N_1,TR_rate_N_2,・・・からなる。そして、伝送速度TR_rate_N_1,TR_rate_N_2,・・・は、それぞれ、送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・に対応付けられる。
【0069】
成功/失敗情報は、“0”または“1”(=0/1)からなる。“0”は、フレームの送信が失敗したことを表し、“1”は、フレームの送信が成功したことを表す。そして、各成功/失敗情報は、それぞれ、送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・および伝送速度TR_rate_N_1,TR_rate_N_2,・・・に対応付けられる。
【0070】
送信スケジュールSCH_CTLは、制御対象のアクセスポイントAP_Nがフレームの送信を予定するタイムスロットの開始時刻および終了時刻[tSTART_SCH_N_1,tEND_SCH_N_1],[tSTART_SCH_N_2,tEND_SCH_N_2],・・・からなる。そして、送信スケジュールSCH_CTLは、送信者Add_AP_Nに対応付けられる。
【0071】
収集手段1は、アクセスポイントAP_NからMACアドレスAdd_AP_N、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTLおよび送信スケジュールSCH_CTLを受信すると、MACアドレスAdd_AP_N、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILUREおよび送信スケジュールSCH_CTLをデータベース2内の対応表TBL1-1に格納する。
【0072】
図4は、制御対象のアクセスポイントAP_Nによる無線通信を妨害するアクセスポイントAP_UNCOORDのフレームの送信区間TRS_UNCOORDを記憶する対応表の概念図である。
【0073】
図4を参照して、対応表TBL1-2は、名前と、送信者と、送信区間とを含む。名前、送信者および送信区間は、相互に対応付けられる。
【0074】
送信者は、アクセスポイントAP_UNCOORDのMACアドレスAdd_AP_UNCOORDからなる。送信区間TRS_UNCOORDは、過去の直近Xスロットにおいて、アクセスポイントAP_UNCOORDがフレームを送信したタイムスロットの開始時刻および終了時刻[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]からなる。dは、アクセスポイントAP_UNCOORDがフレームを送信した直近のタイムスロットの個数を表し、0以上の整数からなる。その結果、開始時刻および終了時刻[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]で表される送信区間以外の送信区間は、過去の直近Xスロットにおいて、アクセスポイントAP_UNCOORDがフレームを送信しなかったタイムスロットを表す。
【0075】
対応表TBL1-2における送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]の引数1,2,・・・,dは、アクセスポイントAP_UNCOORDがフレームを送信した直近のタイムスロットの個数を表すため、対応表TBL1-1における送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・の引数1,2,・・・と同じである場合もあれば、異なる場合もある。
【0076】
収集手段1は、アクセスポイントAP_NからMACアドレスAdd_AP_UNCOORDおよび送信区間TRS_UNCOORDを受信すると、MACアドレスAdd_AP_UNCOORDおよび送信区間TRS_UNCOORDを対応表TBL1-2に格納する。
【0077】
図5は、協調APであるアクセスポイントAP_1~AP_N-1の送信スケジュールを記憶する対応表の概念図である。
【0078】
図5を参照して、テーブルTBL2-1は、名前と、送信者と、送信スケジュールとを含む。名前、送信者および送信スケジュールは、相互に対応付けられる。
【0079】
送信者は、協調APであるアクセスポイントAP_1~AP_N-1のMACアドレスAdd_AP_1~Add_AP_N-1からなる。
【0080】
送信スケジュールは、タイムスロットの開始時刻および終了時刻“[tSTART_1_1,tEND_1_1],[tSTART_1_2,tEND_1_2],・・・”、“[tSTART_2_1,tEND_2_1],[tSTART_2_2,tEND_2_2],・・・”、“[tSTART_3_1,tEND_3_1],[tSTART_3_2,tEND_3_2],・・・”、・・・、“[tSTART_N-1_1,tEND_N-1_1],[tSTART_N-1_2,tEND_N-1_2],・・・”からなる。
【0081】
送信スケジュール[tSTART_1_1,tEND_1_1],[tSTART_1_2,tEND_1_2],・・・は、送信者Add_AP_1に対応付けられ、送信スケジュール[tSTART_2_1,tEND_2_1],[tSTART_2_2,tEND_2_2],・・・は、送信者Add_AP_2に対応付けられ、送信スケジュール[tSTART_3_1,tEND_3_1],[tSTART_3_2,tEND_3_2],・・・は、送信者Add_AP_3に対応付けられ、以下、同様にして、送信スケジュール[tSTART_N-1_1,tEND_N-1_1],[tSTART_N-1_2,tEND_N-1_2],・・・は、送信者Add_AP_N-1に対応付けられる。
【0082】
収集手段1は、アクセスポイントAP_1~AP_N-1からそれぞれMACアドレスAdd_AP_1~Add_AP_N-1および送信スケジュールSCH_COORD_1~SCH_COORD_N-1を受信すると、MACアドレスAdd_AP_1~Add_AP_N-1および送信スケジュールSCH_COORD_1~SCH_COORD_N-1を対応表TBL2-1に格納する。
【0083】
学習器4,5における敵対的強化学習(非特許文献2)について説明する。この発明の実施の形態においては、学習器4は、フレームの送信タイミングにおける制御対象のアクセスポイントAP_Nの方策(即ち、制御対象のアクセスポイントAP_Nが行動を選択すること)を獲得するため、学習段階において制御対象のアクセスポイントAP_Nの無線通信を妨害する仮想的なアクセスポイントである敵対アクセスポイントAP_ADVの存在下において敵対的強化学習を実行する。従って、上述したアクセスポイントAP_UNCOORDは、学習段階においては、敵対アクセスポイントAP_ADVからなる。
【0084】
学習器5は、制御対象のアクセスポイントAP_Nによる無線通信をより効果的に妨害するような敵対アクセスポイントAP_ADVの方策を獲得しようと学習する。
【0085】
一方、学習器4は、制御対象のアクセスポイントAP_Nが妨害に晒されたとしても無線通信の性能を維持できるような方策を獲得しようと学習する。
【0086】
学習段階において、主体エージェント(制御対象のアクセスポイントAP_N)と敵対者(敵対アクセスポイントAP_ADV)が競争を行うシナリオを考える際、この二者の競争を2プレーヤーゼロサムマルコフゲーム(非特許文献3,4)で表現する。
【0087】
マルコフゲームは、(S,A,A,T,r,γ,P)によって表すことができる。Sは、状態空間を表し、Aは、主体エージェントの行動空間を表し、Aは、敵対者の行動空間を表し、Tは、S×A×A×Sからなり、状態遷移確率を表し、rは、S×A×Aからなり、報酬を表し、γは、割引率を表し、Pは、初期状態の確率分布を表す。なお、γは、0≦γ≦1を満たす実数からなる。
【0088】
制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、各タイムスロットにおいて同じ状態(=状態空間Sのうちの1つの状態)を観測する。この状態は、(1)協調APであるアクセスポイントAP_1~AP_N-1のフレームの送信有無の状態と、(2)制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴とからなる。なお、Xは、1以上の整数である。
【0089】
従って、状態空間Sは、次式によって表される。
【0090】
【数1】
【0091】
式(1)において、S(i=1,2,・・・,N-1)は、協調APであるアクセスポイントAP_1~AP_N-1のフレームの送信有無の状態を表し、次式によって定義される。
【0092】
【数2】
【0093】
式(2)において、“-1”は、1つのタイムスロットにおいてフレームを送信していない状態を表し、“1”は、1つのタイムスロットにおいてフレームを送信している状態を表す。
【0094】
また、式(1)において、Shistoryは、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴を表しており、次式によって定義される。
【0095】
【数3】
【0096】
式(3)において、Sは、0以上の整数である。また、x,x,xは、直近Xスロットの間にそれぞれのタイムスロットに対応する制御対象のアクセスポイントAP_Nと敵対アクセスポイントAP_ADVとの行動組のスロット数を表す。
【0097】
そして、xは、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両者が共にフレームを送信していたスロット数を表し、xは、制御対象のアクセスポイントAP_Nがフレームの送信を行っていたが、敵対アクセスポイントAP_ADVがフレームの送信を行っていなかったスロット数を表し、xは、敵対アクセスポイントAP_ADVのフレームの送信の有無に関わらず、制御対象のアクセスポイントAP_Nがフレームの送信を行っていなかったスロット数を表す。なお、初期状態Sのうち、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットの通信履歴によって決定されるS0,history∈Shistoryは、一様分布によって決定される。
【0098】
制御手段3は、データベース2の対応表TBL1-1から送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・を読み出し、データベース2の対応表TBL1-2から送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]を読み出す。
【0099】
そして、制御手段3は、送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・と送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]とにおいて、相互に一致する送信区間を検出し、その検出した送信区間の個数をスロット数xとする。
【0100】
また、制御手段3は、送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・から、送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]のいずれとも一致しない送信区間を検出し、その検出した送信区間の個数をスロット数xとする。送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・のうち、送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]のいずれとも一致しない送信区間は、制御対象のアクセスポイントAP_Nがフレームを送信し、かつ、敵対アクセスポイントAP_ADVがフレームを送信しなかった送信区間を表すからである。
【0101】
更に、制御手段3は、送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・と異なる送信区間(制御対象のアクセスポイントAP_Nがフレームを送信しなかった区間)のうちで、送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]のいずれかと一致する送信区間と、送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]と異なる送信区間(アクセスポイントAP_UNCOORDがフレームを送信しなかった送信区間)のいずれかと一致する送信区間とを検出し、その検出した2つの送信区間の個数をスロット数xとする。制御対象のアクセスポイントAP_Nがフレームを送信しなかった区間のうちで、送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]のいずれかと一致する送信区間は、制御対象のアクセスポイントAP_Nがフレームを送信せず、かつ、敵対アクセスポイントAP_ADVがフレームを送信した送信区間TRS_1を表し、制御対象のアクセスポイントAP_Nがフレームを送信しなかった区間のうちで、アクセスポイントAP_UNCOORDがフレームを送信しなかった送信区間のいずれかと一致する送信区間は、制御対象のアクセスポイントAP_NおよびアクセスポイントAP_UNCOORDの両方がフレームを送信しなかった区間TRS_2を表すので、上記の2つの区間TRS_1,TRS_2は、敵対アクセスポイントAP_ADVのフレームの送信の有無に関わらず、制御対象のアクセスポイントAP_Nがフレームの送信を行っていなかったスロット数を表すからである。
【0102】
このように、制御手段3は、送信区間[tSTART_N_1,tEND_N_1],[tSTART_N_2,tEND_N_2],・・・と送信区間[tSTART_UNCOORD_1,tEND_UNCOORD_1],[tSTART_UNCOORD_2,tEND_UNCOORD_2],・・・,[tSTART_UNCOORD_d,tEND_UNCOORD_d]とに基づいて、スロット数x,x,xを生成する。即ち、制御手段3は、制御対象のアクセスポイントAP_Nの送信区間TRS_CTLとアクセスポイントAP_UNCOORDの送信区間TRS_UNCOORDとに基づいて直近Xスロット(X=x+x+x)におけるフレームの送信有無の履歴Shistoryを生成する。
【0103】
次に、行動空間について説明する。各タイムスロットにおいて、制御対象のアクセスポイントAP_Nは、獲得した方策に基づいてフレームを送信するか否かを決定する。そして、制御対象のアクセスポイントAP_Nは、フレームを送信する場合、MCS(Modulation and coding scheme)index(以下、「MCSインデックス」と言う。)に基づいてフレームの伝送速度TRD_CTLを決定する。つまり、制御対象のアクセスポイントAP_Nの行動空間Aは、次式によって表される。
【0104】
【数4】
【0105】
式(4)において、“-1”は、フレームを送信しないことを表し、Mは、フレームを送信する場合に選択できるMCSインデックスの集合を表す。
【0106】
MCSインデックスの集合Mは、次式によって表される。
【0107】
【数5】
【0108】
式(5)の右辺の各数字は、制御対象のアクセスポイントAP_Nがフレームを送信する場合に選択するMCSインデックスの値を表す。ここで、式(5)の右辺の数字が大きい方がより速い伝送速度でフレームを送信する行動を表し、数字が小さい方がより遅い伝送速度でフレームを送信する行動を表してもよく、数字が大きい方がより遅い伝送速度でフレームを送信する行動を表し、数字が小さい方がより速い伝送速度でフレームを送信する行動を表してもよく、一般的には、数字が異なれば、異なる伝送速度でフレームを送信することを表していればよい。
【0109】
敵対アクセスポイントAP_ADVは、フレームを送信するか送信しないかのみを決定する。従って、敵対アクセスポイントAP_ADVの行動空間Aは、次式によって表される。
【0110】
【数6】
【0111】
式(6)において、“-1”は、フレームを送信しないことを表し、“1”は、フレームを送信することを表す。
【0112】
次に、制御対象のアクセスポイントAP_Nが獲得する報酬rについて説明する。制御対象のアクセスポイントAP_Nの報酬および敵対アクセスポイントAP_ADVの報酬は、互いに符号を反転させた関係を有する。従って、学習器5は、制御対象のアクセスポイントAP_Nが獲得する報酬が小さくなるように、即ち、制御対象のアクセスポイントAP_Nの無線通信を妨害するように学習する。
【0113】
制御対象のアクセスポイントAP_Nが獲得する報酬rは、次式によって表される。
【0114】
【数7】
【0115】
式(7)において、aは、制御対象のアクセスポイントAP_Nの行動を表し、aは、敵対アクセスポイントAP_ADVの行動を表す。また、cは、正の整数である。そして、制御対象のアクセスポイントAP_Nがフレームを送信する行動(a=“1”)は、式(5)に示す集合Mの1つの要素(集合Mの1つのMCSインデックスで表される伝送速度でフレームを送信する行動)からなる。
【0116】
式(7A)は、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両方がフレームを送信した場合に制御対象のアクセスポイントAP_Nが得られる報酬を表す。式(7A)においては、制御対象のアクセスポイントAP_Nがフレームの送信に成功したとき、報酬rは、タイムスロット当たりの“0”よりも大きいデータ量(Data/slot(>0))からなり、制御対象のアクセスポイントAP_Nがフレームの送信に失敗したとき、報酬rは、“0”からなる。従って、式(7A)においては、制御対象のアクセスポイントAP_Nが得られる報酬rをタイムスロット当たりの“0”以上のデータ量(Data/slot(≧0))としている。
【0117】
また、式(7B)は、制御対象のアクセスポイントAP_Nがフレームを送信せず、かつ、敵対アクセスポイントAP_ADVがフレームを送信した場合に制御対象のアクセスポイントAP_Nが得られる報酬rを表す。
【0118】
更に、式(7C)は、制御対象のアクセスポイントAP_Nがフレームを送信し、かつ、敵対アクセスポイントAP_ADVがフレームを送信しなかった場合に制御対象のアクセスポイントAP_Nが得られる報酬rを表す。式(7C)においては、制御対象のアクセスポイントAP_Nがフレームの送信に成功したとき、報酬rは、タイムスロット当たりの“0”よりも大きいデータ量(Data/slot(>0))からなり、制御対象のアクセスポイントAP_Nがフレームの送信に失敗したとき、報酬rは、“0”からなる。つまり、敵対アクセスポイントAP_ADVがフレームを送信しない場合、制御対象のアクセスポイントAP_Nは、必ずしも、フレームの送信に成功するということはなく、例えば、伝送速度が速過ぎたためにフレームの送信に失敗することもある。従って、式(7C)においても、制御対象のアクセスポイントAP_Nが得られる報酬rをタイムスロット当たりの“0”以上のデータ量(Data/slot(≧0))としている。
【0119】
なお、式(7A)によって得られる報酬rと式(7C)によって得られる報酬rとを比較した場合、一般的には、式(7A)によって得られる報酬rは、式(7C)によって得られる報酬rよりも小さくなる。式(7A)においては、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両方がフレームを送信するので、制御対象のアクセスポイントAP_Nによるフレームの送信が敵対アクセスポイントAP_ADVによるフレームの送信と衝突し、制御対象のアクセスポイントAP_Nがフレームの送信に失敗する場合があるが、式(7C)においては、敵対アクセスポイントAP_ADVがフレームを送信しないので、制御対象のアクセスポイントAP_Nによるフレームの送信と敵対アクセスポイントAP_ADVによるフレームの送信との衝突によって制御対象のアクセスポイントAP_Nがフレームの送信に失敗する場合が無いからである。つまり、式(7C)の場合の方が式(7A)の場合よりも制御対象のアクセスポイントAP_Nがフレームの送信に成功する可能性が大きくなるからである。
【0120】
このように、式(7A)によって得られる報酬rは、式(7C)によって得られる報酬rよりも小さくなるので、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVとの衝突を避ける行動を取るようになる。
【0121】
更に、式(7D)は、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両方がフレームを送信しなかった場合に制御対象のアクセスポイントAP_Nが得られる報酬rを表す。
【0122】
従って、制御対象のアクセスポイントAP_Nが式(7)によって得る報酬rは、各タイムスロットにおいて制御対象のアクセスポイントAP_Nがフレームを送信したときに得られる第1の報酬(式(7A)または式(7C)によって得られる報酬)と、各タイムスロットにおいて制御対象のアクセスポイントAP_Nがフレームを送信しなかったときに得られる第2の報酬(式(7B)または式(7D)によって得られる報酬)とを含む。
【0123】
式(7)において、式(7D)によって得られる報酬r(=-c)を式(7B)によって得られる報酬r(=c)よりも小さく設定することによって、敵対アクセスポイントAP_ADVがフレームを送信する場合と比較して、敵対アクセスポイントAP_ADVがフレームを送信しない場合に制御対象のアクセスポイントAP_Nの報酬rがより小さくなるため(つまり、制御対象のアクセスポイントによる無線通信を妨害できるため)、敵対アクセスポイントAP_ADVが常にフレームを送信するようになることを回避できる。
【0124】
このように、報酬rは、協調外の敵対アクセスポイントAP_ADVの行動にも依存するため、制御対象のアクセスポイントAP_Nは、後述する運用段階において、敵対アクセスポイントAP_ADVのような外部のアクセスポイントとの衝突を避けようとするようになる。
【0125】
なお、式(7)においては、式(7B)において、制御対象のアクセスポイントAP_Nがフレームを送信せず、かつ、敵対アクセスポイントAP_ADVがフレームを送信したときに制御対象のアクセスポイントAP_Nが得られる報酬rをG(>0)とし、式(7D)において、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両方がフレームを送信しなかったときに制御対象のアクセスポイントAP_Nが得られる報酬rを-Y(Y>0)としてもよい。この場合、Gは、式(7B)に示す“c”と同じ値であってもよく、“c”と異なる値であってもよい。また、-Yは、式(7D)に示す“-c”と同じ値であってもよく、“-c”と異なる値であってもよい。その結果、Gは、Yと同じ値であることもあれば、Yと異なる値であることもある。
【0126】
敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nによる無線通信を妨害する。つまり、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nが取得する報酬rが少なくなる行動を取ろうとする。従って、制御対象のアクセスポイントAP_Nによる無線通信を妨害する観点からすれば、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nがフレームを送信しないとき、自己もフレームを送信しない行動(a=-1)を取ることによって、制御対象のアクセスポイントAP_Nが取得する報酬rを最も少なくできる(r=-c)。
【0127】
また、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nがフレームを送信するとき(a=1)、自己もフレームを送信する行動(a=1)を取って制御対象のアクセスポイントAP_Nによるフレームの送信を失敗させることによって、または制御対象のアクセスポイントAP_Nによるフレームの送信が失敗することが無くても制御対象のアクセスポイントAP_Nがフレームを送信するときの伝送速度を低下させることによって制御対象のアクセスポイントAP_Nが取得する報酬rを2番目に少なくできる(r≧0)。
【0128】
制御対象のアクセスポイントAP_Nがフレームを送信せず、かつ、敵対アクセスポイントAP_ADVがフレームを送信する場合(a=-1,a=1)、および制御対象のアクセスポイントAP_Nがフレームを送信し、かつ、敵対アクセスポイントAP_ADVがフレームを送信しない場合(a=1,a=-1)においては、cの具体的な値によって、報酬r=cと報酬r=データ量/Slotとの大小関係が決まる。
【0129】
従って、c>データ量/Slotであるとき、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nがフレームを送信すれば(a=1)、フレームを送信しない行動(a=-1)を制御対象のアクセスポイントAP_Nの無線通信を妨害する行動として3番目に取る。そして、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nがフレームを送信しないとき(a=-1)、自己がフレームを送信する行動(a=1)を制御対象のアクセスポイントAP_Nの無線通信を妨害する行動として4番目に取る。
【0130】
また、データ量/Slot>cであるとき、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nがフレームを送信しないとき(a=-1)、自己がフレームを送信する行動(a=1)を制御対象のアクセスポイントAP_Nの無線通信を妨害する行動として3番目に取る。そして、敵対アクセスポイントAP_ADVは、制御対象のアクセスポイントAP_Nがフレームを送信すれば(a=1)、フレームを送信しない行動(a=-1)を制御対象のアクセスポイントAP_Nの無線通信を妨害する行動として4番目に取る。データ量/Slot>cであるときに敵対アクセスポイントAP_ADVが1番目および2番目に取る行動は、c>データ量/Slotであるときと同じである。
【0131】
一方、制御対象のアクセスポイントAP_Nが敵対アクセスポイントAP_ADVによる妨害が存在する通信環境において自己の無線通信の性能を維持する観点からは、制御対象のアクセスポイントAP_Nは、できるだけ多くの報酬rを取得できる行動を取ろうとする。
【0132】
従って、データ量/Slot>cであるとき、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信しないとき(a=-1)、フレームを送信する行動(a=1)を1番目に取る。そして、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信するとき(a=1)、フレームを送信する行動(a=1)を2番目に取る。また、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信するとき(a=1)、フレームを送信しない行動(a=-1)を3番目に取る。更に、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信しないとき(a=-1)、フレームを送信しない行動(a=-1)を4番目に取る。
【0133】
一方、c>データ量/Slotであるとき、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信するとき(a=1)、フレームを送信しない行動(a=-1)を1番目に取る。そして、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信しないとき(a=-1)、フレームを送信する行動(a=1)を2番目に取る。また、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信するとき(a=1)、フレームを送信する行動(a=1)を3番目に取る。更に、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVがフレームを送信しないとき(a=-1)、フレームを送信しない行動(a=-1)を4番目に取る。
【0134】
図6は、敵対的強化学習の方法を説明するための図である。図6を参照して、学習器4は、敵対アクセスポイントAP_ADVの方策を固定した状態で制御対象のアクセスポイントAP_Nの方策をN個のタイムスロットにおいて学習する。
【0135】
次に、学習器5は、制御対象のアクセスポイントAP_Nの方策を固定した状態で敵対アクセスポイントAP_ADVの方策をN個のタイムスロットにおいて学習する。
【0136】
以後、学習器4,5は、それぞれ、N個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの方策を学習することと、N個のタイムスロットにおいて敵対アクセスポイントAP_ADVの方策を学習することとを交互にNitcr個のタイムスロットにおいて繰り返し実行する。即ち、学習器4は、Nitcr個のタイムスロットにおいて、N個のタイムスロットごとに、敵対アクセスポイントAP_ADVの方策を固定した状態で制御対象のアクセスポイントAP_Nの方策を学習し、学習器5は、Nitcr個のタイムスロットにおいて、N個のタイムスロットごとに、制御対象のアクセスポイントAP_Nの方策を固定した状態で敵対アクセスポイントAP_ADVの方策を学習する。なお、Nは、Nと同じであってもよく、Nと異なっていてもよい。
【0137】
学習器4,5がそれぞれ制御対象のアクセスポイントAP_Nの方策および敵対アクセスポイントAP_ADVの方策を交互に更新することによって、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)および敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)が最適化されて行く。
【0138】
ここで、行動価値関数Qπ (s,a),i∈{p,a}は、エージェントiが方策πに基づいて状態sで行動aを取る場合の価値を表し、次式によって表される。
【0139】
【数8】
【0140】
式(8)において、sは、初期の状態を表し、aは、初期の行動を表す。また、式(8)において、r_{i,t+1}は、制御対象のアクセスポイントAP_Nの報酬r_{p,t+1}または敵対アクセスポイントAP_ADVの報酬r_{a,t+1}である。
【0141】
学習器4は、最初のN個のタイムスロットにおいて、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を固定して、次式に示す期待累積報酬Rが最大になるように制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を更新する。
【0142】
【数9】
【0143】
式(9)において、rは、制御対象のアクセスポイントAP_Nがkスロット先に観測する報酬を表す。その結果、式(9)は、制御対象のアクセスポイントAP_Nがフレームを送信する予定であるタイムスロットにおいて取得し得る報酬を累積した期待累積報酬を表す。
【0144】
学習器4は、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を固定した状態で、N個のタイムスロットの各タイムスロットにおいて、式(9)に示す期待累積報酬Rが最大になるように制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)をQ学習(非特許文献5)によって次式のように更新する。
【0145】
【数10】
【0146】
式(10)において、αは、学習率であり、0<α<1を満たす実数である。また、s’は、次のタイムスロットにおける状態を表す。
【0147】
次に、学習器5は、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を固定した状態で、N個のタイムスロットの各タイムスロットにおいて、式(9)に示す期待累積報酬Rが最小になるように敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)をQ学習によって次式のように更新する。
【0148】
【数11】
【0149】
式(11)に示すように、敵対アクセスポイントAP_ADVが取得する報酬(=-r)は、式(10)に示す制御対象のアクセスポイントAP_Nが取得する報酬rの符号を反転させた報酬である。
【0150】
学習器4,5は、それぞれ、式(10)に示す行動価値関数Qπ (s,a)の更新と式(11)に示す行動価値関数Qπ (s,a)の更新とを交互にNitcr個のタイムスロットにおいて繰り返し実行する。
【0151】
制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、それぞれ、自己の行動価値関数Qπ (s,a),Qπ (s,a)に基づいて行動を選択する場合、ソフトマックス(Softmax)行動選択則(非特許文献5)またはε-greedy行動則(非特許文献5)に従って行動a,aを選択する。
【0152】
ソフトマックス(Softmax)行動選択則によって行動を選択する場合、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、それぞれ、自己の行動a,aを次式に示す確率で選択する。
【0153】
【数12】
【0154】
式(12)において、Q(s,b)は、行動価値関数を表し、式(12)の分母のシグマは、全ての行動bに対する和を表す。τは、温度と呼ばれる正の数である。τが高くなれば、全ての行動がほぼ同じ確率で選択されるようになり、τが低くなれば、価値の高い行動が選ばれ易くなる。
【0155】
また、ε-greedy行動則によって行動を選択する場合、制御対象のアクセスポイントAP_Nは、確率1-εで行動価値関数Qπ (s,a)が最大になる行動aを選択し、確率εで行動aをランダムに選択する。一方、敵対アクセスポイントAP_ADVは、確率1-εで行動価値関数Qπ (s,a)が最小になる行動aを選択し、確率εで行動aをランダムに選択する。εは、例えば、0.3に設定される。
【0156】
図7は、協調アクセスポイントの状態を説明するための図である。図7を参照して、時刻t1~t2のタイムスロットSlot_1においては、協調APであるアクセスポイントAP_1が送信を行っている状態であり、時刻t2~t3のタイムスロットSlot_2においては、協調APであるアクセスポイントAP_N-1が送信を行っている状態である。
【0157】
また、時刻t3~t4のタイムスロットSlot_3においては、協調APであるアクセスポイントAP_1~AP_N-1の全てが送信を行っていない状態であり、時刻t4~t5のタイムスロットSlot_4においては、協調APであるアクセスポイントAP_1,AP_N-1が送信を行っている状態である。
【0158】
従って、協調APであるアクセスポイントAP_1~AP_N-1から収集した送信スケジュールSCH_COORDを参照すれば、各タイムスロットSlotにおいて、協調APであるアクセスポイントAP_1~AP_N-1の状態(=“-1”または“1”)を容易に決定することができる。
【0159】
制御対象のアクセスポイントAP_Nは、タイムスロットSlot_1において、協調APであるアクセスポイントAP_1がフレームの送信を行っている状態で3Mbit/slotの伝送速度でフレームを送信し、端末装置TM_NからのACKの有無によってフレームの送信が成功したか失敗したかを示す成功/失敗情報IF_SUCCESS/FAILUREを検出する。そして、制御対象のアクセスポイントAP_Nは、その検出した成功/失敗情報IF_SUCCESS/FAILUREを制御装置10へ送信する。
【0160】
また、制御対象のアクセスポイントAP_Nは、タイムスロットSlot_3において、協調APであるアクセスポイントAP_1~AP_N-1の全てがフレームの送信を行っていない状態で1Mbit/slotの伝送速度でフレームを送信し、端末装置TM_NからのACKの有無によってフレームの送信が成功したか失敗したかを示す成功/失敗情報IF_SUCCESS/FAILUREを検出する。そして、制御対象のアクセスポイントAP_Nは、その検出した成功/失敗情報IF_SUCCESS/FAILUREを制御装置10へ送信する。
【0161】
更に、制御対象のアクセスポイントAP_Nは、タイムスロットSlot_4において、協調APであるアクセスポイントAP_1,AP_N-1がフレームの送信を行っている状態で2Mbit/slotの伝送速度でフレームを送信し、端末装置TM_NからのACKの有無によってフレームの送信が成功したか失敗したかを示す成功/失敗情報IF_SUCCESS/FAILUREを検出する。そして、制御対象のアクセスポイントAP_Nは、その検出した成功/失敗情報IF_SUCCESS/FAILUREを制御装置10へ送信する。
【0162】
この発明の実施の形態においては、式(7A)および式(7C)における“0”よりも大きい報酬rは、ある1つのタイムスロットにおいて制御対象のアクセスポイントAP_Nがフレームの送信に成功したときのデータ量である。
【0163】
従って、式(7A)および式(7C)における“0”よりも大きい報酬rは、図3に示す対応表TBL1-1の送信区間、伝送速度および成功/失敗情報に基づいて算出される。より具体的には、成功/失敗情報が“1”からなる場合、式(7A)および式(7C)における“0”よりも大きい報酬rは、r=送信区間の時間長(=tEND_N-tSTART_N)×伝送速度によって算出され、成功/失敗情報が“0”からなる場合、報酬rは、r=0である。
【0164】
以下においては、協調APであるアクセスポイントAP_1~AP_N-1を2個のアクセスポイント(=アクセスポイントAP_1,AP_2)に設定し、制御対象のアクセスポイントAP_Nが取り得る行動aを、フレームを送信しない行動(=“-1”)、MCSインデックスが“1”である伝送速度でフレームを送信する行動(=“1”)、MCSインデックスが“2”である伝送速度でフレームを送信する行動(=“2”)、およびMCSインデックスが“3”である伝送速度でフレームを送信する行動(=“3”)の4個に設定して、Q学習の方法について説明する。
【0165】
図8から図10は、協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す図である。
【0166】
図8は、X(=x+x+x)が“1”であるときの協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す。
【0167】
図9は、X(=x+x+x)が“2”であるときの協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す。
【0168】
図10は、X(=x+x+x)が“3”であるときの協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す。
【0169】
図8から図10においては、協調APであるアクセスポイントAP_1,AP_2の状態を2ビットの数値[n,n]で表し、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態を式(3)に示すように3個の数値[x,x,x]で表す。xは、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両方がフレームを送信したスロット数を表し、xは、制御対象のアクセスポイントAP_Nがフレームを送信し、かつ、敵対アクセスポイントAP_ADVがフレームを送信しなかったスロット数を表し、xは、敵対アクセスポイントAP_ADVのフレームの送信有無に関わらず、制御対象のアクセスポイントAP_Nがフレームを送信しなかったスロット数を表す。
【0170】
その結果、協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とは、2ビットの数値[n,n]と3個の数値[x,x,x]とからなる状態[n,n,x,x,x]で表される。
【0171】
図8を参照して、X(=x+x+x)が“1”であるとき、x,x,xのうちの1つが“1”であり、残りの2つが“0”であるので、x,x,xの状態[x,x,x]は、[1,0,0],[0,1,0],[0,0,1]の3通りである。そして、アクセスポイントAP_1,AP_2の状態[n,n]は、n,nの各々がフレームを送信する状態(=“1”)とフレームを送信しない状態(=“-1”)とからなるので、[-1,-1],[1,-1],[-1,1],[1,1]の4通りである。その結果、3通りの状態[x,x,x]は、アクセスポイントAP_1,AP_2の4通りの状態[n,n]の各々に対して存在するので、アクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す[n,n,x,x,x]は、12(=4×3)通りである。
【0172】
図9を参照して、X(=x+x+x)が“2”であるとき、x,x,xのうちの1つが“2”であり、残りの2つが“0”である場合と、x,x,xのうちの2つが“1”であり、残りの1つが“0”である場合とがあるので、x,x,xの状態[x,x,x]は、[2,0,0],[0,2,0],[0,0,2],[1,1,0],[1,0,1],[0,1,1]の6通りである。その結果、アクセスポイントAP_1,AP_2の状態[n,n]が4通りであり、6通りの状態[x,x,x]がアクセスポイントAP_1,AP_2の4通りの状態[n,n]の各々に対して存在するので、アクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す[n,n,x,x,x]は、24(=4×6)通りである。
【0173】
図10を参照して、X(=x+x+x)が“3”であるとき、x,x,xのうちの1つが“3”であり、残りの2つが“0”である場合と、x,x,xのうちの1つが“2”であり、別の1つが“1”であり、残りの1つが“0”である場合と、x,x,xの各々が“1”である場合とがあるので、x,x,xの状態[x,x,x]は、[3,0,0],[0,3,0],[0,0,3],[2,1,0],[2,0,1],[0,2,1],[1,2,0],[1,0,2],[0,1,2],[1,1,1]の10通りである。その結果、アクセスポイントAP_1,AP_2の状態[n,n]が4通りであり、10通りの状態[x,x,x]がアクセスポイントAP_1,AP_2の4通りの状態[n,n]の各々に対して存在するので、アクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す[n,n,x,x,x]は、40(=4×10)通りである。
【0174】
図8から図10において説明したように、スロット数x,x,xのうちの1つによってXを構成する場合と、スロット数x,x,xのうちの2つによってXを構成する場合と、スロット数x,x,xの全てによってXを構成する場合とについて、スロット数x,x,xの各々がとり得る値を決定することによって履歴Shistoryの状態が何通りあるかを決定し、その決定した履歴Shistoryの状態の通り数を協調APであるアクセスポイントAP_1,AP_2の各状態に適用してアクセスポイントAP_1,AP_2および履歴Shistoryの状態を求める。
【0175】
Xが“4”以上である場合について、[n,n,x,x,x]の通り数は、次の方法によって求める。xがXである場合には、x,xの状態[x,x]は、[0,0]の1通り、xがX-1である場合には、x,xの状態[x,x]は、[0,1],[1,0]の2通り、xがX-2である場合には、x,xの状態[x,x]は、[0,2],[1,1],[2,0]の3通り、・・・、xが0である場合には、x,xの状態[x,x]は、[0,X],[1,X-1],…,[X,0]のX+1通りあり、これらの合計1+2+…+(X+1)=(X+1)(X+2)/2通りの状態がアクセスポイントAP_1,AP_2の4通りの状態[n,n]の各々に対して存在するので、アクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す[n,n,x,x,x]は、2(X+1)(X+2)(=(X+1)(X+2)/2×4)通りである。
【0176】
従って、Xが“4”以上である場合も、アクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態とを示す[n,n,x,x,x]を求めることができる。
【0177】
以下においては、X(=x+x+x)が“2”であるときを例として制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの敵対的強化学習を説明する。
【0178】
図11は、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)をQ学習によって更新するときのQテーブルの概念図である。
【0179】
図11を参照して、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)をQ学習によって更新するときのQテーブルTBL-Q1は、協調APであるアクセスポイントAP_1,AP_2および直近Xスロットにおけるフレームの送信有無の履歴Shistoryの状態と、制御対象のアクセスポイントAP_Nの行動とによって構成される。
【0180】
X=2であるので、QテーブルTBL-Q1における協調APであるアクセスポイントAP_1,AP_2およびShistoryの状態は、図9に示すアクセスポイントAP_1,AP_2およびShistoryの状態からなる。
【0181】
制御対象のアクセスポイントAP_Nの行動aは、上述したように、[-1,1,2,3]の4個であるので、QテーブルTBL-Q1における行動は、4個の行動からなる。
【0182】
従って、QテーブルTBL-Q1は、24行×4列の行列によって表され、96個のQ値(=Q1,1~Q24,4)を含む。そして、96個のQ値(=Q1,1~Q24,4)の初期値は、“0”である。
【0183】
図12は、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)をQ学習によって更新するときのQテーブルの概念図である。
【0184】
図12を参照して、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)をQ学習によって更新するときのQテーブルTBL-Q2は、協調APであるアクセスポイントAP_1,AP_2および履歴Shistoryの状態と、敵対アクセスポイントAP_ADVの行動とによって構成される。
【0185】
協調APであるアクセスポイントAP_1,AP_2および履歴Shistoryの状態は、図11において説明した通りである。
【0186】
敵対アクセスポイントAP_ADVの行動空間Aは、式(6)に示すように、フレームを送信する(=“1”)と、フレームを送信しない(=“-1”)とからなるので、敵対アクセスポイントAP_ADVが取り得る行動aは、2個である。
【0187】
従って、QテーブルTBL-Q2は、24行×2列の行列によって表され、48個のQ値(=Q1,1~Q24,2)を含む。そして、48個のQ値(=Q1,1~Q24,2)の初期値は、“0”である。
【0188】
図13から図19は、それぞれ、Qテーブルの更新方法を説明するための第1から第7の概略図である。また、図20は、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの通信の履歴を示す図である。なお、図20において、“-1/1”は、敵対アクセスポイントAP_ADVがフレームを送信する行動およびフレームを送信しない行動のうちのいずれかの行動を実行したことを示す。
【0189】
図13を参照して、Q学習の初期状態においては、QテーブルTBL-Q1_1の全てのQ値(Q1,1~Q24,4)は、“0”である(図13の(a)参照)。
【0190】
そして、学習器4は、アクセスポイントAP_1,AP_2の状態、および制御手段3から受けた履歴Shistoryに基づいてアクセスポイントAP_1,AP_2および履歴Shistoryの状態sを決定する。
【0191】
図20に示すように、制御対象のアクセスポイントAP_Nは、タイムスロットSlot_5においてフレームを送信し、成功/失敗情報IF_SUCCESS/FAILUREを取得する。また、制御対象のアクセスポイントAP_Nは、タイムスロットSlot_5において、敵対アクセスポイントAP_ADVがフレームを送信したことを観測する。そして、制御対象のアクセスポイントAP_Nは、タイムスロットSlot_5において、成功/失敗情報IF_SUCCESS/FAILUREと、自己の送信区間TRS_CTL(=タイムスロットSlot_5の開始時刻および終了時刻)と、自己の伝送速度TRD_CTLと、敵対アクセスポイントAP_ADVの送信区間TRS_ADV(=タイムスロットSlot_5の開始時刻および終了時刻)とを制御装置10へ送信する。
【0192】
更に、タイムスロットSlot_6において、敵対アクセスポイントAP_ADVは、フレームを送信する行動およびフレームを送信しない行動のうちのいずれかを実行し、制御対象のアクセスポイントAP_Nは、フレームを送信しなかった。その結果、タイムスロットSlot_6は、敵対アクセスポイントAP_ADVがフレームを送信する行動およびフレームを送信しない行動のうちのいずれを実行したかに関らず、制御対象のアクセスポイントAP_Nがフレームを送信しなかったタイムスロットを示す。
【0193】
従って、制御手段3は、制御対象のアクセスポイントAP_Nの送信区間TRD_CTL(=タイムスロットSlot_5の開始時刻および終了時刻)と、敵対アクセスポイントAP_ADVの送信区間TRS_ADV(=タイムスロットSlot_5の開始時刻および終了時刻)とに基づいて、タイムスロットSlot_5がスロット数x(=1)に該当し、タイムスロットSlot_6がスロットx(=1)に該当することを検知するとともに、タイムスロットSlot_5,Slot_6に基づいて、履歴Shistoryの状態[1,0,1]を生成する。
【0194】
そして、学習器4は、制御手段3から受けた履歴Shistoryの状態[1,0,1]を含む[-1,-1,1,0,1],[1,-1,1,0,1],[-1,1,1,0,1],[1,1,1,0,1]の状態[n,n,x,x,x]において、ソフトマックス行動選択則またはε-greedy行動則に従って制御対象のアクセスポイントAP_Nの行動aを選択する。この場合、学習器4は、例えば、[-1,-1,1,0,1]の状態[n,n,x,x,x]において、制御対象のアクセスポイントAP_Nの行動aとして“2”(MCSインデックスが“2”である伝送速度でフレームを送信する行動)を選択したものとする。
【0195】
そうすると、学習器4は、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)(即ち、Q値)を固定してQ学習によって制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を更新する。
【0196】
より具体的には、学習器4は、制御対象のアクセスポイントAP_Nの行動aが“2”(MCSインデックスが“2”である伝送速度でフレームを送信する行動)であるので、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)から検出した敵対アクセスポイントAP_ADVの行動aに応じて式(7A)または式(7C)に基づいて報酬rを算出する。この場合、式(7A)または式(7C)によって得られる報酬rは、共に“0”以上のデータ量/Slotであるが、上述したように、一般的には、式(7C)によって得られる報酬rは、式(7A)によって得られる報酬rよりも大きい。
【0197】
その後、学習器4は、次のタイムスロットにおける状態s(=s’)において、制御対象のアクセスポイントAP_Nが行動空間Aの全ての行動aを取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))を算出する。この場合、QテーブルTBL-Q1において、全てのQ値が“0”であるので、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、“0”からなる。
【0198】
引き続いて、学習器4は、算出した報酬rと、予め設定されたα,γと、算出した行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))と、行動価値関数Qπ (s,a)(=Q値)とを式(10)に代入して行動価値関数Qπ (s,a)を更新する。この場合、QテーブルTBL-Q1の全てのQ値が“0”であるので、行動価値関数Qπ (s,a)(=Q値)は、“0”からなる。その結果、式(10)の右辺は、0+α[r+γ×0-0]=αrとなるので、更新された行動価値関数Qπ (s,a)は、Q値(q5,3=αr)からなる。これによって、図13の(a)に示すQテーブルTBL-Q1_1は、図14に示すQテーブルTBL-Q1_2に更新される。
【0199】
引き続いて、N個のタイムスロットの2番目のタイムスロットにおいて、学習器4は、ソフトマックス行動選択則またはε-greedy行動則に従って、状態s(=[-1,1,1,0,1])における制御対象のアクセスポイントAP_Nの行動aを選択する。この場合、学習器4は、例えば、制御対象のアクセスポイントAP_Nの行動aとして“-1”(フレームを送信しない行動)を選択したものとする。
【0200】
そうすると、学習器4は、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)(即ち、Q値)を固定してQ学習によって制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を更新する。
【0201】
より具体的には、学習器4は、制御対象のアクセスポイントAP_Nの行動aが“-1”(フレームを送信しない行動)であるので、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)から検出した敵対アクセスポイントAP_ADVの行動aに応じて式(7B)または式(7D)に基づいて報酬rを算出する。この場合、学習器4は、敵対アクセスポイントAP_ADVの行動aが“1”(フレームを送信する行動)であれば、式(7B)に基づいて報酬r(=c)を算出し、敵対アクセスポイントAP_ADVの行動aが“-1”(フレームを送信しない行動)であれば、式(7D)に基づいて報酬r(=-c)を算出する。
【0202】
その後、学習器4は、次のタイムスロットにおける状態s(=s’)において、制御対象のアクセスポイントAP_Nが行動空間Aの全ての行動aを取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))を算出する。この場合、次のタイムスロットにおける状態s(=s’)が[-1,-1,1,0,1]であるとき、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、q5,3からなり、次のタイムスロットにおける状態s(=s’)が[-1,-1,1,0,1]以外であるとき、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、“0”からなる(図14のQテーブルTBL-Q2参照)。
【0203】
引き続いて、学習器4は、算出した報酬rと、予め設定されたα,γと、算出した行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))と、行動価値関数Qπ (s,a)(=Q値)とを式(10)に代入して行動価値関数Qπ (s,a)を更新する。この場合、行動価値関数Qπ (s,a)(=Q値)は、q5,3からなる。その結果、式(10)の右辺は、q5,3+α[r+γ×q5,3-q5,3]またはq5,3+α[r+γ×0-q5,3]=q5,3+α[r-q5,3]となる。即ち、更新された行動価値関数Qπ (s,a)のQ値は、q17,1(=q5,3+α[r+γ×q5,3-q5,3]またはq5,3+α[r-q5,3])からなる。これによって、図14に示すQテーブルTBL-Q1_2は、図15に示すQテーブルTBL-Q1_3に更新される。
【0204】
その後、学習器4は、N個のタイムスロットの最後のタイムスロットまで、上述した方法によって、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)(即ち、Q値)を固定してQ学習によって制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新する。
【0205】
そして、N個のタイムスロットの最後のタイムスロットにおいて、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を更新すると、図15に示すQテーブルTBL-Q1_3は、図16に示すQテーブルTBL-Q1_4に更新される。
【0206】
学習器4は、N個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新すると、行動価値関数Qπ (s,a)を最終的に更新したときのQテーブルTBL-Q1_4に含まれる最大のQ値(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値)を有する行動価値関数Qπ (s,a)を学習器5へ出力する。また、学習器4は、N個のタイムスロットにおける敵対的強化学習(上述した方法による行動価値関数Qπ (s,a)の更新)を実行中に、制御対象のアクセスポイントAP_Nの送信スケジュールSCH_CTLに基づいて制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると、送信タイミングtg_TRになったときのQテーブルTBL-Q1を制御手段3へ出力する。
【0207】
なお、学習器4がN個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新する間、学習器5が実行するQ学習のQテーブルTBL-Q2は、一定に維持される。
【0208】
学習器4によるN個のタイムスロットにおける敵対的強化学習が終了すると、学習器5は、行動価値関数Qπ (s,a)(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値を有する行動価値関数Qπ (s,a))を学習器4から受ける。
【0209】
そして、学習器5は、行動価値関数Qπ (s,a)(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値を有する行動価値関数Qπ (s,a))を固定して、式(11)によって、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)をN個のタイムスロットにおいて繰り返し更新する。
【0210】
学習器5は、行動価値関数Qπ (s,a)(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値を有する行動価値関数Qπ (s,a))を学習器4から受けると、行動価値関数Qπ (s,a)(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値を有する行動価値関数Qπ (s,a))の状態s、行動aおよび報酬rを検出する。即ち、学習器5は、行動価値関数Qπ (s,a)の状態s(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値が得られるときの状態)と、行動a(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値が得られるときの行動a)と、報酬r(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値が得られるときの報酬r)とを検出する。
【0211】
そして、学習器5は、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新する場合、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)の状態s(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値が得られるときの状態)と同じ状態において敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新する。
【0212】
ここで、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)の状態s(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値が得られるときの状態)は、例えば、状態[1,1,1,0,1]であるものとする。
【0213】
従って、学習器5は、N個のタイムスロットの最初のタイムスロットにおいて、アクセスポイントAP_1,AP_2および履歴Shistoryの状態sを状態[1,1,1,0,1]に決定する。
【0214】
そして、学習器5は、ソフトマックス行動選択則またはε-greedy行動則に従って敵対アクセスポイントAP_ADVの行動aを選択する。敵対アクセスポイントAP_ADVの行動空間Aは、式(6)に示すように、フレームを送信する行動(=“1”)と、フレームを送信しない行動(=“-1”)との2つの行動からなる。
【0215】
従って、学習器5は、行動価値関数Qπ (s,a)の行動a(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値が得られるときの行動a)を妨害するために、状態s(=[1,1,1,0,1])において、敵対アクセスポイントAP_ADVの行動aとして、“1”(=フレームを送信する行動)を選択する。
【0216】
この行動(=“1”)を選択するのは、次の理由による。QテーブルTBL-Q1_4のQ値(=q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2)は、実質的に報酬rに等しく、報酬rは、制御対象のアクセスポイントAP_Nがフレームの送信に成功したときに大きくなるので、q5,2,q5,3,q11,2,q11,4,q17,1,q17,3,q23,1,q23,2のうちの最大のQ値は、制御対象のアクセスポイントAP_Nがフレームを送信するときに得られる。そこで、敵対アクセスポイントAP_ADVがフレームを送信することによって、制御対象のアクセスポイントAP_Nによるフレームの送信と衝突させ、報酬rを低下させることが制御対象のアクセスポイントAP_Nによる無線通信を妨害することになるからである。
【0217】
学習器5は、敵対アクセスポイントAP_ADVの行動(=“1”)を選択すると、次のタイムスロットにおける状態s(=s’)において、敵対アクセスポイントAP_ADVが行動空間Aの全ての行動aを取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))を算出する。この場合、図13の(b)に示すQテーブルTBL-Q2_1において、全てのQ値が“0”であるので、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、“0”からなる。
【0218】
引き続いて、学習器5は、検出した報酬rと、予め設定されたα,γと、算出した行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))と、行動価値関数Qπ (s,a)(=Q値)とを式(11)に代入して行動価値関数Qπ (s,a)を更新する。この場合、図13の(b)に示すQテーブルTBL-Q2_1の全てのQ値が“0”であるので、行動価値関数Qπ (s,a)(=Q値)は、“0”からなる。また、報酬rを式(11)のrに代入することによって行動価値関数Qπ (s,a)における報酬は、-rになる。その結果、式(11)の右辺は、0+α[-r+γ×0-0]=-αrとなるので、更新された行動価値関数Qπ (s,a)は、Q値(q23,2=-αr)からなる。これによって、図13の(b)に示すQテーブルTBL-Q2_1は、図17に示すQテーブルTBL-Q2_2に更新される。
【0219】
その後、N個のタイムスロットの2番目のタイムスロットにおいて、学習器5は、ソフトマックス行動選択則またはε-greedy行動則に従って、状態s(=[1,1,1,0,1])における敵対アクセスポイントAP_ADVの行動aを選択する。
【0220】
この場合、制御対象のアクセスポイントAP_Nが得る報酬rを“-c”にするために(即ち、制御対象のアクセスポイントAP_Nを妨害するために)、学習器5は、敵対アクセスポイントAP_ADVの行動aとして“-1”(=フレームを送信しない行動)を選択する。
【0221】
また、学習器5は、更新された行動価値関数Qπ (s,a)(=q23,2=-αr)から報酬rを検出する。
【0222】
更に、学習器5は、次のタイムスロットにおける状態s(=s’)において、敵対アクセスポイントAP_ADVが行動空間Aの全ての行動aを取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))を算出する。この場合、次のタイムスロットにおける状態s(=s’)が状態[1,1,1,0,1]であるとき、状態[1,1,1,0,1]に対応する2つのQ値(“0”,q23,2(=-αr))のうちの最大値が“0”であるので、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、“0”からなる(図17のQテーブルTBL-Q2_2参照)。一方、次のタイムスロットにおける状態s(=s’)が状態[1,1,1,0,1]以外であるとき、状態[1,1,1,0,1]以外の状態に対応する全てのQ値が“0”であるので、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、“0”からなる(図17のQテーブルTBL-Q2_2参照)。従って、次のタイムスロットにおける状態s(=s’)が状態[1,1,1,0,1]であるか否かに関わらず、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))は、“0”からなる。
【0223】
そうすると、学習器5は、検出した報酬rと、予め設定されたα,γと、算出した行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A)(=最大のQ値))と、更新された行動価値関数Qπ (s,a)(=q23,2)とを式(11)に代入して行動価値関数Qπ (s,a)を更新する。この場合、式(11)の右辺は、q23,2+α[-r+γ×0-q23,2]=q23,2+α[-r-q23,2]となる。その結果、更新された行動価値関数Qπ (s,a)は、q23,1=q23,2+α[-r-q23,2]からなる。これによって、図17に示すQテーブルTBL-Q2_2は、図18に示すQテーブルTBL-Q2_3に更新される。
【0224】
その後、学習器5は、N個のタイムスロットの最後のタイムスロットまで、上述した方法によって、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)(即ち、Q値)を固定してQ学習によって敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新する。
【0225】
そして、N個のタイムスロットの最後のタイムスロットにおいて、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新すると、図18に示すQテーブルTBL-Q2_3は、図19に示すQテーブルTBL-Q2_4に更新される。
【0226】
学習器5は、N個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新すると、最終的に更新した行動価値関数Qπ (s,a)(=QテーブルTBL-Q2_4に含まれる最小のQ値(=q’23,1,q”23,2のうちの最小のQ値)を有する行動価値関数)を学習器4へ出力する。
【0227】
学習器5は、N個のタイムスロットにおける敵対的強化学習(上述した方法による行動価値関数Qπ (s,a)の更新)を実行中に、制御対象のアクセスポイントAP_Nの送信スケジュールSCH_CTLに基づいて制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると、送信タイミングtg_TRになったときのQテーブルTBL-Q2を制御手段3へ出力する。
【0228】
なお、学習器5がN個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新する間、学習器4が実行するQ学習のQテーブルTBL-Q1は、一定(図16に示すQテーブルTBL-Q1_4)に維持される。
【0229】
学習器5が上述した方法によってN個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新すると、その後、学習器4が上述した方法によってN個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新する学習と、学習器5が上述した方法によってN個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新する学習とが交互にNitcr個のタイムスロットにおいて繰り返し実行される。
【0230】
学習器4が2回目にN個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新するとき、図16に示すQテーブルTBL-Q1_4において、図13から図16において説明した方法によってQ値を順次更新することによって制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新する。そして、学習器4がm(mは、2以上の整数)回目にN個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新するとき、(m-1)回目にN個のタイムスロットにおいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新したときの最終的に更新されたQテーブルにおいて、図13から図16において説明した方法によってQ値を順次更新することによって制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新する。
【0231】
また、学習器5が2回目にN個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新するとき、図19に示すQテーブルTBL-Q2-4において、図13図17から図19において説明した方法によってQ値を順次更新することによって敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新する。そして、学習器5がm回目にN個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新するとき、(m-1)回目にN個のタイムスロットにおいて敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新したときの最終的に更新されたQテーブルにおいて、図13図17から図19において説明した方法によってQ値を順次更新することによって敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を繰り返し更新する。
【0232】
その結果、学習器4は、QテーブルTBL-Q1におけるQ値が大きくなるようにQ学習を実行し、学習器5は、QテーブルTBL-Q2におけるQ値が小さくなるようにQ学習を実行する。
【0233】
従って、制御対象のアクセスポイントAP_Nは、QテーブルTBL-Q1においてQ値が最大になるときの行動aを実行することによって自己の無線通信に対する敵対アクセスポイントAP_ADVの妨害を克服する方策を取ることができる。
【0234】
一方、敵対アクセスポイントAP_ADVは、QテーブルTBL-Q2においてQ値が最小になるときの行動aを実行することによって制御対象のアクセスポイントAP_Nによる無線通信を妨害する方策を取ることができる。
【0235】
図20を参照して、タイミングT1になると、制御手段3は、学習器4から最終的に更新されたQテーブルTBL-Q1を受け、学習器5から最終的に更新されたQテーブルTBL-Q2を受ける。
【0236】
そして、制御手段3は、QテーブルTBL-Q1において、最大のQ値が得られるときの制御対象のアクセスポイントAP_Nの行動aを検出し、QテーブルTBL-Q2において、最小のQ値が得られるときの敵対アクセスポイントAP_ADVの行動aを検出する。
【0237】
そうすると、制御手段3は、タイムスロットSlot_7におけるアクセスポイントAP_1,AP_2のフレームの送信スケジュール(アクセスポイントAP_1がフレームを送信し、アクセスポイントAP_2がフレームを送信しないスケジュール)と、検出した行動aとに基づいて、フレームを送信する行動を実行するように制御対象のアクセスポイントAP_Nを制御する。また、制御手段3は、検出した行動a(=フレームを送信しない行動)を実行するように敵対アクセスポイントAP_ADVを制御する。
【0238】
なお、タイミングT1の時点で、学習器4が制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を上述した方法によって繰り返し更新しているとき、制御手段3は、N個のタイムスロットにおいて敵対的強化学習を実行中のQテーブルTBL-Q1を学習器4から受け、N個のタイムスロットよりも1つ前のN個のタイムスロットにおいて実行された敵対的強化学習によって最終的に更新されたQテーブルTBL-Q2を学習器5から受ける。
【0239】
一方、タイミングT1の時点で、学習器5が敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を上述した方法によって繰り返し更新しているとき、制御手段3は、N個のタイムスロットにおいて敵対的強化学習を実行中のQテーブルTBL-Q2を学習器5から受け、N個のタイムスロットよりも1つ前のN個のタイムスロットにおいて実行された敵対的強化学習によって最終的に更新されたQテーブルTBL-Q1を学習器4から受ける。
【0240】
そして、タイムスロットSlot_7において、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVがそれぞれ上述した行動を実行すると、直近Xスロット(X=2)は、タイムスロットSlot_5,Slot_6からタイムスロットSlot_6,Slot_7に更新される。即ち、履歴Shistoryは、履歴Shistory_1から履歴Shistory_2に更新される。
【0241】
その後、タイムスロットSlot_6,Slot_7における制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの行動に基づいて、上述した方法によって、直近Xスロット(X=2)における履歴Shistory_2の状態[x,x,x](=[0,1,1])が決定される。この場合、タイムスロットSlot_6は、xに該当し、タイムスロットSlot_7は、xに該当する。そして、学習器4,5は、決定された履歴Shistory_2の状態[0,1,1]を用いて、上述した方法によって、それぞれ、行動価値関数Qπ (s,a)および行動価値関数Qπ (s,a)を繰り返し更新し、タイミングT2になると、それぞれ、QテーブルTBL-Q1およびQテーブルTBL-Q2を制御手段3へ出力する。
【0242】
制御手段3は、タイミングT2において、QテーブルTBL-Q1およびQテーブルTBL-Q2をそれぞれ学習器4,5から受けると、その受けたQテーブルTBL-Q1,TBL-Q2およびタイムスロットSlot_8におけるアクセスポイントAP_1,AP_2のフレームの送信スケジュールに基づいて、上述した方法によって、タイムスロットSlot_8において、フレームを送信しない行動を実行するように制御対象のアクセスポイントAP_Nを制御するとともに、フレームを送信する行動とフレームを送信しない行動とのいずれの行動を実行してもよいように敵対アクセスポイントAP_ADVを制御する。
【0243】
そして、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVがそれぞれ制御手段3による制御に従って上述した行動を実行すると、直近Xスロット(X=2)は、タイムスロットSlot_6,Slot_7からタイムスロットSlot_7,Slot_8に更新される。即ち、履歴Shistoryは、履歴Shistory_2から履歴Shistory_3に更新される。なお、履歴Shistory_3は、[x,x,x]=[0,1,1]からなる。
【0244】
以後、上述した動作が繰り返され、タイミングT3になると、タイムスロットSlot_9において、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、履歴Shistory_3を用いて学習された行動を実行する。即ち、タイムスロットSlot_9において、制御対象のアクセスポイントAP_Nがフレームを送信する行動を実行し、かつ、敵対アクセスポイントAP_ADVがフレームを送信しない行動を実行する。
【0245】
また、タイミングT4になると、タイムスロットSlot_10において、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、履歴Shistory_4を用いて学習された行動を実行する。即ち、タイムスロットSlot_10において、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの両方がフレームを送信する行動を実行する。なお、履歴Shistory_4は、[x,x,x]=[0,1,1]からなる。
【0246】
このように、履歴Shistoryは、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVが各タイムスロットSlot_7,Slot_8,Slot_9において、それぞれ学習器4,5によって学習された行動a,aに基づいて決定された行動を実行することによって更新される。
【0247】
上記においては、直近Xスロットが“2”である場合について学習器4による敵対的強化学習および学習器5による敵対的強化学習を説明したが、直近Xスロットが“1”,“3”,“4”,・・・である場合についても、上述した方法によって、学習器4による敵対的強化学習および学習器5による敵対的強化学習を実行することができる。
【0248】
図21は、図1に示す制御装置10の動作を説明するためのフローチャートである。図21を参照して、制御装置10の動作が開始されると、収集手段1は、有線ケーブル6を介して制御対象のアクセスポイントAP_NからMACアドレスAdd_AP_N、フレームの送信区間TRS_CTL、伝送速度TRD_CTL、フレームの成功/失敗情報IF_SUCCESS/FAILURE、フレームの送信スケジュールSCH_CTL、MACアドレスAdd_AP_ADVおよび送信区間TRS_ADVを収集する(ステップS1)。ここで、学習段階では、アクセスポイントAP_UNCOORDは、敵対アクセスポイントAP_ADVからなるので、収集手段1は、敵対アクセスポイントAP_ADVのMACアドレスAdd_AP_ADVを収集する。その結果、送信区間TRS_ADVは、敵対アクセスポイントAP_ADVの送信区間である。
【0249】
ステップS1の後、収集手段1は、有線ケーブル6を介して協調アクセスポイント(アクセスポイントAP_1~AP_N-1)から協調アクセスポイント(アクセスポイントAP_1~AP_N-1)のMACアドレスAdd_AP_1~Add_AP_N-1およびフレームの送信スケジュールSCH_COORDを収集する(ステップS2)。
【0250】
その後、収集手段1は、その収集したMACアドレスAdd_AP_N、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、および送信スケジュールSCH_CTLをデータベース2の対応表TBL1-1に格納するとともに、MACアドレスAdd_AP_ADVおよび送信区間TRS_ADVをデータベース2の対応表TBL1-2に格納する(ステップS3)。
【0251】
引き続いて、収集手段1は、MACアドレスAdd_AP_1~Add_AP_N-1およびフレームの送信スケジュールSCH_COORDをデータベース2の対応表TBL2-1に格納する(ステップS4)。
【0252】
その後、制御手段3は、データベース2の対応表TBL1-1から送信区間TRS_CTLを読み出し、データベース2の対応表TBL1-2から送信区間TRS_ADVを読み出す。そして、制御手段3は、送信区間TRS_CTLおよび送信区間TRS_ADVに基づいて、上述した方法によって、直近Xスロットにおける制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVによるフレームの送信有無の履歴Shistoryを生成する(ステップS5)。
【0253】
引き続いて、制御手段3は、データベース2の対応表TBL1-1から伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILUREおよび送信スケジュールSCH_CTLを読み出し、データベース2の対応表TBL2-1から送信スケジュールSCH_COORDを読み出す。また、制御手段3は、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)を生成する。そして、制御手段3は、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを学習器4,5へ出力する(ステップS6)。
【0254】
学習器4,5は、制御手段3から制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを受ける。そして、学習器4,5は、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)に基づいて、アクセスポイントAP_Nが制御対象のアクセスポイントであり、アクセスポイントAP_1~AP_N-1が協調APであることを検知する。そうすると、学習器4,5は、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryに基づいて敵対的強化学習を実行しながら、所定のタイミングで、それぞれ、QテーブルTBL-Q1,TBL-Q2を制御手段3へ出力する(ステップS7)。
【0255】
制御手段3は、学習器4,5からそれぞれQテーブルTBL-Q1,TBL-Q2を受けると、QテーブルTBL-Q1および協調APであるアクセスポイントAP_1~AP_N-1のフレームの送信スケジュールSCH_COORDに基づいて制御対象のアクセスポイントAP_Nの行動aを制御し、QテーブルTBL-Q2に基づいて敵対アクセスポイントAP_ADVの行動aを制御する(ステップS8)。これによって、制御装置10の動作が終了する。
【0256】
ステップS8において、QテーブルTBL-Q1とアクセスポイントAP_1~AP_N-1の送信スケジュールSCH_COORDとに基づいて制御対象のアクセスポイントAP_Nの行動aを制御するのは、制御対象のアクセスポイントAP_NおよびアクセスポイントAP_1~AP_N-1は、フレーム送出情報を共有し、相互に協調的な制御を行うからである。
【0257】
図22は、図21のステップS7の詳細な動作を説明するためのフローチャートである。図22を参照して、図21のステップS6の後、学習器4,5は、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、送信スケジュールSCH_CTL,SCH_COORDおよび履歴Shistoryを制御手段3から受ける(ステップS71)。
【0258】
そして、学習器4,5は、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)に基づいて、アクセスポイントAP_1~AP_Nのうち、アクセスポイントAP_Nが制御対象のアクセスポイントであり、アクセスポイントAP_1~AP_N-1が協調アクセスポイントであることを検知する(ステップS72)。
【0259】
その後、学習器4,5は、i=1を設定する(ステップS73)。ここで、iは、敵対的強化学習におけるタイムスロットの引数を表し、1≦i≦Nitcrを満たす整数である。
【0260】
ステップS73の後、学習器4は、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILUREおよび履歴Shistoryに基づいて、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を固定して、敵対アクセスポイントAP_ADVによる妨害が存在する通信環境において制御対象のアクセスポイントAP_Nによる無線通信の性能を維持する行動を学習する敵対的強化学習をN個のタイムスロットにおいて実行する(ステップS74)。そして、学習器4は、ステップS74における敵対的強化学習の終了時点における制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を学習器5へ出力する。
【0261】
また、学習器4,5は、ステップS74における学習器4による敵対的強化学習の実行と並行して、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると(ステップS75)、それぞれ、QテーブルTBL-Q1,TBL-Q2を制御手段3へ出力する(ステップS76)。
【0262】
ステップS75においては、学習器4,5は、制御対象のアクセスポイントAP_Nのフレームの送信スケジュールSCH_CTLに基づいて制御対象のアクセスポイントAP_Nがフレームを送信する次のタイムスロットSlot_Nextを検出し、タイミングtgが次のタイムスロットSlot_Nextの開始時になったことを検知したとき(例えば、図20のタイムスロットSlot_7の開始時になったことを検知したとき)、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知し、タイミングtgが次のタイムスロットSlot_Nextの開始時になったことを検知しないとき、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知しない。
【0263】
また、ステップS76においては、学習器4,5は、それぞれ、送信タイミングtg_TRにおいて、敵対的強化学習(=Q学習)における最新のQテーブルTBL-Q1,TBL-Q2を制御手段3へ出力する。より具体的には、学習器4は、ステップS74のN個のタイムスロットにおいて実行されている敵対的強化学習によって送信タイミングtg_TRの時点までに更新された最新のQテーブルTBL-Q1を制御手段3へ出力し、学習器5は、ステップS74のN個のタイムスロットよりも1つ前のN個のタイムスロットにおいて実行された敵対的強化学習によって最終的に更新されたQテーブルTBL-Q2を制御手段3へ出力する。
【0264】
ステップS76の後、一連の動作は、ステップS74および図21のステップS8へ移行する。
【0265】
そして、ステップS74の後、学習器5は、学習器4から受けた制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)の状態s(=s)を検出し、その検出した状態s(=s)において、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を固定して、制御対象のアクセスポイントAP_Nによる無線通信を妨害する行動を学習する敵対的強化学習をN個のタイムスロットにおいて実行する(ステップS77)。そして、学習器5は、ステップS77における敵対的強化学習の終了時点における敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を学習器4へ出力する。
【0266】
また、学習器4,5は、ステップS77における敵対的強化学習の実行と並行して、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると(ステップS78)、それぞれ、QテーブルTBL-Q1,TBL-Q2を制御手段3へ出力する(ステップS79)。
【0267】
ステップS78において、学習器4,5は、ステップS75における方法と同じ方法によって、タイミングtgが送信タイミングtg_TRになったことを検知する。
【0268】
また、ステップS79においては、学習器4,5は、それぞれ、送信タイミングtg_TRにおいて、敵対的強化学習(=Q学習)における最新のQテーブルTBL-Q1,TBL-Q2を制御手段3へ出力する。より具体的には、学習器4は、ステップS77のN個のタイムスロットよりも1つ前のN個のタイムスロットにおいて実行された敵対的強化学習によって最終的に更新されたQテーブルTBL-Q1を制御手段3へ出力し、学習器5は、ステップS77のN個のタイムスロットにおいて実行されている敵対的強化学習によって送信タイミングtg_TRの時点までに更新された最新のQテーブルTBL-Q2を制御手段3へ出力する。
【0269】
ステップS79の後、一連の動作は、ステップS77および図21のステップS8へ移行する。
【0270】
そして、ステップS77の後、学習器4,5は、i=Nitcrであるか否かを判定する(ステップS80)。ステップS80において、i=Nitcrでないと判定されたとき、学習器4,5は、i=i+1を設定する(ステップS81)。その後、一連の動作は、ステップS74,S75へ移行し、ステップS80において、i=Nitcrであると判定されるまで、ステップS74~ステップS81が繰り返し実行される。
【0271】
そして、ステップS80において、i=Nitcrであると判定されると、学習器4,5は、敵対的強化学習を終了するか否かを判定する(ステップS82)。この場合、学習器4,5は、Nitcrが規定値(予め決定された(N+N)の自然数倍からなる数値)に一致するとき、敵対的強化学習を終了すると判定し、Nitcrが規定値に一致しないとき、敵対的強化学習を終了しないと判定する。なお、規定値は、例えば、N=N=100であるとき、100000に設定される。
【0272】
ステップS82において、敵対的強化学習を終了しないと判定されたとき、一連の動作は、ステップS73へ移行し、ステップS82において、敵対的強化学習を終了すると判定されるまで、ステップS73~ステップS82が繰り返し実行される。
【0273】
そして、ステップS82において、敵対的強化学習を終了すると判定されると、学習器4,5は、敵対的強化学習を停止する(ステップS83)。
【0274】
図22に示すフローチャートによれば、学習器4が、N個のタイムスロットにおいて、制御対象のアクセスポイントAP_Nによる無線通信の性能を維持する行動を学習する敵対的強化学習(Q学習)を実行するステップS74と、学習器5が、N個のタイムスロットにおいて、制御対象のアクセスポイントAP_Nによる無線通信を妨害する行動を学習する敵対的強化学習(Q学習)を実行するステップS77とが、i=Nitcrになるまで繰り返し交互に実行される(ステップS74,S77,S80,S81参照)。
【0275】
そして、学習器4,5は、ステップS74またはステップS77に並行して、送信スケジュールSCH_CTLに基づいてタイミングtgが送信タイミングtg_TRになったことを検知すると、それぞれ、送信タイミングtg_TRになったときの最新のQテーブルTBL-Q1,TBL-Q2を制御手段3へ出力する(ステップS76,S79参照)。
【0276】
なお、ステップS75,S76がステップS74と並行して実行される場合、タイミングtgがステップS74における敵対的強化学習の終了時点において送信タイミングtg_TRになるまでは、QテーブルTBL-Q1,TBL-Q2は、ステップS76において制御手段3へ出力される。また、ステップS78,S79がステップS77と並行して実行される場合、タイミングtgがステップS77における敵対的強化学習の終了時点において送信タイミングtg_TRになるまでは、QテーブルTBL-Q1,TBL-Q2は、ステップS79において制御手段3へ出力される。
【0277】
また、図22に示すフローチャートによれば、ステップS76またはステップS79において、QテーブルTBL-Q1,TBL-Q2が制御手段3へ出力された後、図21のステップS8が実行されるので、学習器4,5は、制御手段3の動作と並行してステップS74の敵対的強化学習とステップS77の敵対的強化学習とを交互に繰り返し実行する。つまり、学習器4,5は、ステップS82において、学習を終了すると判定されるまでは、制御手段3の動作と並行してステップS74の敵対的強化学習とステップS77の敵対的強化学習とを交互に繰り返し実行する。
【0278】
図23は、図22のステップS74の詳細な動作を説明するためのフローチャートである。
【0279】
図23を参照して、図22のステップS73の後、学習器4は、i=1を設定する(ステップS741)。ここで、iは、Nitcr個のタイムスロットにおけるN個のタイムスロットの引数を表し、1≦i≦Nを満たす整数である。
【0280】
ステップS741の後、学習器4は、履歴Shistoryに基づいて、i番目のタイムスロットにおける協調アクセスポイント(アクセスポイントAP_1~AP_N-1)および履歴Shistoryの状態s(=[n,n,・・・,nN-1,x,x,x])を決定する(ステップS742)。
【0281】
そして、学習器4は、状態s(=[n,n,・・・,nN-1,x,x,x])のうちの1つの状態において、所定の行動選択則(ソフトマックス行動選択則またはε-greedy行動則)に従って、Q学習におけるQ値が最大になるように、i番目のタイムスロットにおける制御対象のアクセスポイントAP_Nの行動aを選択する(ステップS743)。
【0282】
その後、学習器4は、固定した敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)に基づいて敵対アクセスポイントAP_ADVの行動aを検出する(ステップS744)。
【0283】
引き続いて、学習器4は、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTL、伝送速度TRD_CTL、および敵対アクセスポイントAP_ADVの行動aに基づいて、状態sにおいて、制御対象のアクセスポイントAP_Nが行動aを実行したときのi番目のタイムスロットにおける報酬r(=r)を算出する(ステップS745)。この場合、学習器4は、制御対象のアクセスポイントAP_Nの行動aおよび敵対アクセスポイントAP_ADVの行動aに基づいて式(7)によって報酬r(=r)を算出する。
【0284】
ステップS745の後、学習器4は、次のタイムスロット(=(i+1)番目のタイムスロット)の状態s’において、制御対象のアクセスポイントAP_Nが取り得る全ての行動を取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を算出する(ステップS746)。
【0285】
そうすると、学習器4は、報酬r(=r)および行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を用いて、状態sおよび行動aに対応する制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を制御対象のアクセスポイントAP_Nの期待累積報酬Rが最大になるようにQ学習によって更新する(ステップS747)。即ち、学習器4は、Q学習に基づいて期待累積報酬Rが最大になるように制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を式(10)によって更新する。
【0286】
そして、ステップS747の後、学習器4は、i=Nであるか否かを判定する(ステップS748)。
【0287】
ステップS748において、i=Nでないと判定されたとき、学習器4は、i=i+1を設定する(ステップS749)。その後、一連の動作は、ステップS742へ移行し、ステップS748において、i=Nであると判定されるまで、ステップS742~ステップS749が繰り返し実行される。
【0288】
そして、ステップS748において、i=Nであると判定されると、学習器4は、制御対象のアクセスポイントAP_Nの最終的に更新された行動価値関数Qπ (s,a)を学習器5へ出力する(ステップS750)。
【0289】
その後、学習器4は、i=Nを設定する(ステップS751)。そして、一連の動作は、図22のステップS77,S78へ移行する。
【0290】
図23に示すフローチャートにおいて、ステップS742~ステップS747を[Nitcr/(N+N)]回繰り返し実行することは、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を固定して(即ち、敵対アクセスポイントAP_ADVの妨害行動を固定して)、N個のタイムスロットにおける学習器4による敵対的強化学習をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して性能維持行動を更新することに相当する。学習器4が敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を固定して敵対的強化学習を実行するのは、敵対アクセスポイントAP_ADVによる妨害行動を克服する制御対象のアクセスポイントAP_Nの行動a(=性能維持行動)を学習するためであるからである。
【0291】
図24は、図22のステップS77の詳細な動作を説明するためのフローチャートである。
【0292】
図24を参照して、図22のステップS74の後、学習器5は、制御対象のアクセスポイントAP_Nの最終的に更新された行動価値関数Qπ (s,a)を学習器4から受ける。
【0293】
そして、学習器5は、i=1を設定する(ステップS771)。ここで、iは、Nitcr個のタイムスロットにおけるN個のタイムスロットの引数を表し、1≦i≦Nを満たす整数である。
【0294】
ステップS771の後、学習器5は、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)から状態sを検出し、その検出した状態sをi番目のタイムスロットにおける敵対的アクセスポイントAP_ADVの状態sとして決定する(ステップS772)。
【0295】
そして、学習器5は、状態sにおいて、所定の行動選択則(ソフトマックス行動選択則またはε-greedy行動則)に従って、Q学習におけるQ値が最小になるように、i番目のタイムスロットにおける敵対アクセスポイントAP_ADVの行動aを選択する(ステップS773)。
【0296】
その後、学習器5は、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)に含まれる報酬rの符号を反転して、状態sにおいて、敵対アクセスポイントAP_ADVが行動aを実行したときのi番目のタイムスロットにおける報酬r(=-r)を算出する(ステップS774)。
【0297】
引き続いて、学習器5は、次のタイムスロット(=(i+1)番目のタイムスロット)の状態s’において、敵対アクセスポイントAP_ADVが取り得る全ての行動を取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を算出する(ステップS775)。
【0298】
そうすると、学習器5は、報酬rおよび行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を用いて、状態sおよび行動aに対応する敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を制御対象のアクセスポイントAP_Nの期待累積報酬Rが最小になるようにQ学習によって更新する(ステップS776)。即ち、学習器5は、Q学習に基づいて期待累積報酬Rが最小になるように敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を式(11)によって更新する。
【0299】
そして、ステップS776の後、学習器5は、i=Nであるか否かを判定する(ステップS777)。
【0300】
ステップS777において、i=Nでないと判定されたとき、学習器5は、i=i+1を設定する(ステップS778)。その後、一連の動作は、ステップS772へ移行し、ステップS777において、i=Nであると判定されるまで、ステップS772~ステップS778が繰り返し実行される。
【0301】
そして、ステップS777において、i=Nであると判定されると、学習器5は、敵対アクセスポイントAP_ADVの最終的に更新された行動価値関数Qπ (s,a)を学習器4へ出力する(ステップS779)。
【0302】
その後、学習器5は、i=N+Nを設定する(ステップS780)。そして、一連の動作は、図22のステップS80へ移行する。
【0303】
図24に示すフローチャートにおいて、ステップS772~ステップS776を[Nitcr/(N+N)]回繰り返し実行することは、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を固定して(即ち、制御対象のアクセスポイントAP_Nの性能維持行動を固定して)、N個のタイムスロットにおける学習器5による敵対的強化学習をNitcr個のタイムスロット内のN個のタイムスロットごとに繰り返し実行して敵対アクセスポイントAP_ADVの妨害行動を更新することに相当する。学習器5が行動価値関数Qπ (s,a)を固定して敵対的強化学習を実行するのは、制御対象のアクセスポイントAP_Nの性能維持行動を妨害する敵対アクセスポイントAP_ADVの行動a(=妨害行動)を学習するためであるからである。
【0304】
なお、ステップS780において、i=N+Nを設定するのは、図22のステップS74の詳細な動作を説明する図23のフローチャートのステップS751において、i=Nが設定されており、図24のステップS779に至った時点でステップS772~ステップS778がN回実行されているので、図22のステップS74に示す敵対的強化学習およびステップS77に示す敵対的強化学習に用いられたスロット数iが(N+N)個になるからである。
【0305】
そして、図22のステップS74(=図23に示すフローチャート)および図22のステップS77(=図24に示すフローチャート)がW(Wは、W=Nitcr/(N+N)を満たす自然数)回実行されると、i=Nitcrになる。従って、学習器4は、学習器5から引数iを受け、その受けた引数iを(N+N)で除算した除算結果がWに一致すれば、図22のステップS80において、i=Nitcrであると判定し、学習器5から受けた引数iを(N+N)で除算した除算結果がWに一致しなければ、図22のステップS80において、i=Nitcrでないと判定する。
【0306】
図23に示すフローチャートにおいては、学習器4は、Q学習のQ値が最大になるように制御対象のアクセスポイントAP_Nの行動aを選択し(ステップS743参照)、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)に基づいて敵対アクセスポイントAP_ADVの行動aを検出し(ステップS744参照)、敵対アクセスポイントAP_ADVの行動aに基づいて報酬r(=r)を算出し(ステップS745参照)、制御対象のアクセスポイントAP_Nの期待累積報酬Rが最大になるように制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を更新するので(ステップS747)、図23に示すフローチャートに従って行動価値関数Qπ (s,a)を繰り返し更新することによって、敵対アクセスポイントAP_ADVによる妨害行動を克服する制御対象のアクセスポイントAP_Nの行動を学習できる。
【0307】
また、図24に示すフローチャートにおいては、学習器5は、Q学習のQ値が最小になるように敵対アクセスポイントAP_ADVの行動aを選択し(ステップS773参照)、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)の状態sを敵対アクセスポイントAP_ADVについてのQ学習のQテーブルにおける状態sとして決定し(ステップS772参照)、制御対象のアクセスポイントAP_Nの報酬rの符号を反転して敵対アクセスポイントAP_ADVの報酬r(=-r)を算出し(ステップS774参照)、制御対象のアクセスポイントAP_Nの期待累積報酬Rが最小になるように敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新するので(ステップS776)、図24に示すフローチャートに従って行動価値関数Qπ (s,a)を繰り返し更新することによって、制御対象のアクセスポイントAP_Nによる無線通信を妨害する敵対アクセスポイントAP_ADVの行動を学習できる。
【0308】
そして、図23に示すフローチャートおよび図24に示すフローチャートは、i=Nitcrになるまで、交互に実行されるので(図22のステップS74,S77,S80,S81参照)、学習器4は、敵対アクセスポイントAP_ADVによる妨害行動を克服する制御対象のアクセスポイントAP_Nのより強い行動を学習し、学習器5は、制御対象のアクセスポイントAP_Nによる無線通信を妨害する敵対アクセスポイントAP_ADVのより強い行動を学習する。即ち、Nitcr個のタイムスロットにおいて、学習器4による敵対的強化学習と学習器5による敵対的強化学習とを交互に繰り返し実行することによって、学習器4は、敵対アクセスポイントAP_ADVによる妨害を克服する制御対象のアクセスポイントAP_Nの行動を取得する。従って、学習器4は、敵対アクセスポイントAP_ADVによる妨害が存在する通信環境において制御対象のアクセスポイントAP_Nによる無線通信の性能を維持する性能維持行動を取得できる。その結果、制御対象のアクセスポイントAP_Nは、敵対アクセスポイントAP_ADVが存在する通信環境において無線通信のスループットを向上できる。
【0309】
図25は、敵対的強化学習と制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVによる無線通信との関係を示す図である。
【0310】
図25を参照して、タイムスロットSlot_7の開始時点において、学習器4がN個のタイムスロットN_1において上述した敵対的強化学習を実行しているとき、学習器4は、タイムスロットSlot_7の開始時点において、N個のタイムスロットN_1における敵対的強化学習の最新のQテーブルTBL-Q1を制御手段3へ出力し、学習器5は、N個のタイムスロットN_1よりも1つ前のN個のタイムスロットN_1における敵対的強化学習の最新のQテーブルTBL-Q2を制御手段3へ出力する。
【0311】
また、タイムスロットSlot_7の開始時点において、学習器5がN個のタイムスロットN_2において、上述した敵対的強化学習を実行しているとき、学習器4は、N個のタイムスロットN_2よりも1つ前のN個のタイムスロットN_2における敵対的強化学習の最新のQテーブルTBL-Q1を制御手段3へ出力し、学習器5は、タイムスロットSlot_7の開始時点において、N個のタイムスロットN_2における敵対的強化学習の最新のQテーブルTBL-Q2を制御手段3へ出力する。
【0312】
制御手段3は、タイムスロットSlot_7の開始時点において、それぞれ、学習器4,5からQテーブルTBL-Q1,TBL-Q2を受け、その受けたQテーブルTBL-Q1および協調APであるアクセスポイントAP_1,AP_2のタイムスロットSlot_7における送信スケジュールに基づいて、フレームを送信する行動を実行するように制御対象のアクセスポイントAP_Nを制御するとともに、QテーブルTBL-Q2に基づいて、フレームを送信しない行動を実行するように敵対アクセスポイントAP_ADVを制御する。そして、制御対象のアクセスポイントAP_Nは、タイムスロットSlot_7において、制御手段3による制御に従って、フレームを送信し、敵対アクセスポイントAP_ADVは、タイムスロットSlot_7において、制御手段3による制御に従って、フレームを送信しない。
【0313】
各タイムスロットSlot_8,Slot_9,Slot_10の開始時点においても、上述した動作と同様な動作が実行される。
【0314】
このように、制御手段3は、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVによる無線通信とは別に実行されている学習器4,5による敵対的強化学習の結果(QテーブルTBL-Q1,TBL-Q2)に基づいて制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVを制御し、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、学習器4,5による敵対的強化学習とは別に、制御手段3による制御に従ってフレームを送信する行動、またはフレームを送信しない行動を実行する。
【0315】
なお、この発明の実施の形態においては、制御装置10の動作は、ソフトウェアによって実現されてもよい。この場合、制御装置10は、CPU(Central Processing Unit)、ROM(Read Only memory)およびRAM(Random Access Memory)を備える。そして、ROMは、図21に示すフローチャート(図22から図24に示すフローチャートを含む)の各ステップからなるプログラムProg_Aを記憶する。
【0316】
CPUは、ROMからプログラムProg_Aを読み出し、その読み出したプログラムProg_Aを実行して、制御対象のアクセスポイントAP_CTLおよび敵対アクセスポイントAP_ADVを制御する。
【0317】
また、プログラムProg_Aは、CD,DVD等の記録媒体に記録されて流通してもよい。プログラムProg_Aを記録した記録媒体がコンピュータに装着されると、コンピュータは、記録媒体からプログラムProg_Aを読み出して実行し、制御対象のアクセスポイントAP_CTLおよび敵対アクセスポイントAP_ADVを制御する。
【0318】
従って、プログラムProg_Aを記録した記録媒体は、コンピュータ読み取り可能な記録媒体である。
【0319】
上述したように、学習段階においては、制御装置10は、協調外のアクセスポイントAP_UNCOORDとして敵対アクセスポイントAP_ADVを仮想的に想定し、上述した方法によって、制御対象のアクセスポイントAP_Nの性能維持行動を学習する。
【0320】
そして、実際の運用段階においては、協調外のアクセスポイントAP_UNCOORDとして制御外のアクセスポイントAP_OUTを想定して、制御対象のアクセスポイントAP_Nが性能維持行動を実行して制御外のアクセスポイントAP_OUTによる妨害を克服して無線通信を行う。
【0321】
図26は、図1に示す通信システム100の動作を説明するためのフローチャートである。
【0322】
図26を参照して、通信システム100の動作が開始されると、学習段階に入り、制御装置10は、i=1を設定する(ステップS201)。
【0323】
そして、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信の有無を観測する(ステップS202)。制御対象のアクセスポイントAP_Nは、協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信有無の観測結果に基づいて協調アクセスポイント(アクセスポイントAP_1~AP_N-1)のフレームの送信区間TRS_COORDを生成して制御装置10へ送信する。
【0324】
その後、制御装置10は、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVによる協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信の有無の観測結果に基づいて、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの状態を更新する(ステップS203)。
【0325】
引き続いて、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVは、自己の通信の有無および伝送速度を決定する(ステップS204)。
【0326】
そして、制御対象のアクセスポイントAP_Nは、端末装置TM_NからACKを受信したか否かによって通信の成否を観測する(ステップS205)。
【0327】
そうすると、制御装置10は、制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVの通信の成否および行動対に基づいて制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)および敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新する(ステップS206)。ここで、行動対は、制御対象のアクセスポイントAP_Nの行動aと敵対アクセスポイントAP_ADVの行動aとの対である。
【0328】
そして、ステップS206の後、制御装置10は、i=Nitcrであるか否かを判定する(ステップS207)。
【0329】
ステップS207において、i=Nitcrでないと判定されたとき、制御装置10は、i=i+1を設定する(ステップS208)。その後、一連の動作は、ステップS202へ移行し、ステップS207において、i=Nitcrであると判定されるまで、ステップS202~ステップS208が繰り返し実行される。
【0330】
そして、ステップS207において、i=Nitcrであると判定されると、一連の動作は、運用段階に移行する。そして、制御対象のアクセスポイントAP_Nは、運用段階に移行すると、i=1を設定する(ステップS209)。
【0331】
その後、制御対象のアクセスポイントAP_Nは、協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信の有無を観測する(ステップS210)。制御対象のアクセスポイントAP_Nは、協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信有無の観測結果に基づいて協調アクセスポイント(アクセスポイントAP_1~AP_N-1)のフレームの送信区間TRS_COORDを生成して制御装置10へ送信する。
【0332】
引き続いて、制御対象のアクセスポイントAP_Nは、協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信の有無の観測結果に基づいて状態を更新する(ステップS211)。
【0333】
そして、制御対象のアクセスポイントAP_Nおよび制御外のアクセスポイントAP_OUTは、自己の通信の有無および伝送速度を決定する(ステップS212)。
【0334】
その後、制御対象のアクセスポイントAP_Nは、通信の成否を観測する(ステップS213)。
【0335】
そうすると、制御対象のアクセスポイントAP_Nは、i=Nitcrであるか否かを判定する(ステップS214)。
【0336】
ステップS214において、i=Nitcrでないと判定されたとき、制御対象のアクセスポイントAP_Nは、i=i+1を設定する(ステップS215)。その後、一連の動作は、ステップS210へ移行し、ステップS214において、i=Nitcrであると判定されるまで、ステップS210~ステップS215が繰り返し実行される。
【0337】
そして、ステップS214において、i=Nitcrであると判定されると、一連の動作は、終了する。
【0338】
なお、図26に示すフローチャートにおいては、ステップS209,S214,S215を削除し、ステップS207において、i=Nitcrであると判定されたとき、ステップS210~ステップS213が無限に繰り返し実行されるようにしてもよい。
【0339】
図26に示すフローチャートによれば、学習段階(ステップS201~ステップS208)において、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)および敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)がNitcr個のタイムスロットにおいて繰り返し更新され、制御対象のアクセスポイントAP_Nの性能維持行動が取得される。
【0340】
そして、運用段階(ステップS209~ステップS215)に入ると、敵対アクセスポイントAP_ADVに代えて制御外のアクセスポイントAP_OUTが導入され、制御対象のアクセスポイントAP_Nは、協調アクセスポイント(アクセスポイントAP_1~AP_N-1)の通信の有無を観測し、その観測結果に基づいて自己の状態を更新する(ステップS210,S211参照)。
【0341】
その後、制御対象のアクセスポイントAP_Nおよび制御外のアクセスポイントAP_OUTは、自己の通信の有無および伝送速度を決定し(ステップS212参照)、制御対象のアクセスポイントAP_Nは、運用段階において、制御外のアクセスポイントAP_OUTの存在を認識せずに、学習段階で取得した性能維持行動によってフレームを送信したときの通信の成否を観測する(ステップS213参照)。
【0342】
従って、制御対象のアクセスポイントAP_Nは、運用段階において、制御外のアクセスポイントAP_OUTの存在を認識せずに、制御外のアクセスポイントAP_OUTによる妨害が存在する通信環境において端末装置TM_Nへのフレームの送信に成功する確率を高くできる。その結果、運用段階において、制御対象のアクセスポイントAP_Nは、認識していない制御外のアクセスポイントAP_OUTが存在する通信環境において無線通信のスループットを向上できる。
【0343】
上述した方法によって制御対象のアクセスポイントAP_Nを制御したときのシミュレーションについて説明する。
【0344】
シミュレーションにおいては、以下の2つの方式について、協調外のアクセスポイントAP_UNCOORDと制御対象のアクセスポイントAP_CTLとの合計スループットの比較を行う。
(1)理想的な方式
この方式では、制御対象のアクセスポイントAP_CTLは、協調外のアクセスポイントAP_UNCOORDを含む全てのアクセスポイントのフレームの送信状態を得ることができると仮定する。この方式は、あくまで理想的な場合であり、この方式によって得られるスループットが上限値となる。
(2)敵対者無しの強化学習方式
この方式では、制御対象のアクセスポイントAP_CTLは、学習段階において敵対アクセスポイントAP_ADVと競争を行うことなく、単独で学習(Q学習)を行う。よって、運用段階において、制御対象のアクセスポイントAP_CTLは、協調外のアクセスポイントAP_UNCOORDとのフレーム衝突の影響を考えることなくフレームを送信する。その結果、協調外のアクセスポイントAP_UNCOORDのフレームの送信確率が高い場合には、頻繁にフレーム衝突が起こることが予想される。
【0345】
シミュレーションの諸元を表1に示す。
【0346】
【表1】
【0347】
シミュレーションにおいては、制御対象のアクセスポイントAP_CTLが選択できるMCSインデックスは、M={1,2,3}とする。ここで、“1”は、1Mbit/slotの伝送速度を表し、“2”は、2Mbit/slotの伝送速度を表し、“3”は、3Mbit/slotの伝送速度を表す。また、協調外のアクセスポイントAP_UNCOORDの伝送速度は、3Mbit/slotに固定されており、協調外のアクセスポイントAP_UNCOORDは、各タイムスロットごとにある決まった確率でフレームを送信する。
【0348】
全てのアクセスポイントAPおよび端末装置TMの位置を固定とすることによって、制御対象のアクセスポイントAP_CTLの通信が他のアクセスポイントAPから受ける干渉の度合いは、各アクセスポイントAPごとに決まっている。
【0349】
学習段階において、制御対象のアクセスポイントAP_CTLは、協調アクセスポイントAP_1~AP_N-1からの情報に基づいて、それぞれの干渉度合いに応じてフレーム衝突を避けることのできるMCSインデックスを学習している。制御対象のアクセスポイントAP_CTLと協調外のアクセスポイントAP_UNCOORDとは、互いに強く干渉し合うとし、伝送速度に関わらず通信が失敗する。また、この発明の実施の形態による学習段階において、制御対象のアクセスポイントAP_CTLと敵対アクセスポイントAP_ADVとは、100スロットごとに敵対的強化学習を交互に行う。
【0350】
図27は、制御対象のアクセスポイントおよび協調外のアクセスポイントのスループットの和と、協調外のアクセスポイントによるフレームの送信確率との関係を示す図である。図27において、縦軸は、制御対象のアクセスポイントおよび協調外のアクセスポイントのスループットの和を表し、横軸は、協調外のアクセスポイントによるフレームの送信確率を表す。また、曲線k1は、理想的な方式における制御対象のアクセスポイントおよび協調外のアクセスポイントのスループットの和と、協調外のアクセスポイントによるフレームの送信確率との関係を示し、曲線k2は、この発明の実施の形態による方式における制御対象のアクセスポイントおよび協調外のアクセスポイントのスループットの和と、協調外のアクセスポイントによるフレームの送信確率との関係を示し、曲線k3は、敵対者無しの強化学習方式における制御対象のアクセスポイントおよび協調外のアクセスポイントのスループットの和と、協調外のアクセスポイントによるフレームの送信確率との関係を示す。
【0351】
図28は、制御対象のアクセスポイントの送信確率と協調外のアクセスポイントによるフレームの送信確率との関係を示す図である。図28において、縦軸は、制御対象のアクセスポイントAP_CTLの送信確率を表し、横軸は、協調外のアクセスポイントによるフレームの送信確率を表す。また、曲線k4は、理想的な方式における制御対象のアクセスポイントAP_CTLの送信確率と、協調外のアクセスポイントによるフレームの送信確率との関係を示し、曲線k5は、この発明の実施の形態による方式における制御対象のアクセスポイントAP_CTLの送信確率と、協調外のアクセスポイントによるフレームの送信確率との関係を示し、曲線k6は、敵対者無しの強化学習方式における制御対象のアクセスポイントAP_CTLの送信確率と、協調外のアクセスポイントによるフレームの送信確率との関係を示す。
【0352】
図27を参照して、協調外のアクセスポイントAP_UNCOORDによるフレームの送信確率が高いときの合計スループットに注目すると、敵対的強化学習を行った方式(この発明の実施の形態による方式(曲線k2参照))の方が敵対者無しで強化学習を行った方式(曲線k3参照)に比べて高くなっていることが分かる。
【0353】
一方、協調外のアクセスポイントAP_UNCOORDによるフレームの送信確率が低いとき、敵対的強化学習を行った方式(曲線k2参照)の方が敵対者無しで強化学習を行った方式(曲線k3参照)よりも低くなっていることが分かる。
【0354】
また、図27の曲線k2に注目すると、協調外のアクセスポイントAP_UNCOORDによるフレームの送信確率がどのような確率であったとしても、ある程度のスループットを維持していることが分かる。これは、図28に示されているように、制御対象のアクセスポイントAP_CTLが自身のフレーム送信確率を未知である協調外のアクセスポイントAP_UNCOORDのフレーム送信確率に適応して変化させているからだと考えられる(曲線k4,k5参照)。この意味では、この発明の実施の形態による方式を用いることで制御対象のアクセスポイントAP_CTLは、協調外のアクセスポイントAP_UNCOORDのフレーム送信確率の変化に対してロバストな方策を獲得できたと言える。対照的に、敵対者無しの強化学習を行った場合、協調外のアクセスポイントAP_UNCOORDのフレーム送信確率が高い場合に合計スループットが著しく低下してしまっているのが分かる(曲線k3参照)。
【0355】
これは、協調外のアクセスポイントAP_UNCOORDとのフレーム衝突の影響を考えることなく制御対象のアクセスポイントAP_CTLが高確率でフレーム送信を行うため、頻繁にフレーム衝突が起こるからだと考えられる。
【0356】
しかし、協調外のアクセスポイントAP_UNCOORDのフレーム送出確率が低いときでは、この発明の実施の形態による方式の方が敵対者無しの強化学習を行った場合に比べて合計スループットが低くなっている(曲線k2,k3参照)。これは、制御対象のアクセスポイントAP_CTLの学習不足が原因であると考えられる。学習段階において、敵対アクセスポイントAP_ADVは、妨害のために制御対象のアクセスポイントAP_CTLにとって厳しい状態になるような行動を取ろうと学習する。従って、制御対象のアクセスポイントAP_CTLの通信を妨害するために、フレームを送信しない行動を避けるようになる。その結果、制御対象のアクセスポイントAP_CTLは、協調外のアクセスポイントAP_UNCOORDのフレームが少ないという状態に対する学習が不足し、適切な行動を取り難くなっているからであると考えられる。この学習不足から制御対象のアクセスポイントAP_CTLは、過去にフレーム損失があまり起こっておらず、協調外のアクセスポイントAP_UNCOORDのフレーム送信確率が低い場合でも、自身のフレーム送信確率を上げられず、合計スループットが低くなったと考えられる。
【0357】
一方、学習段階において敵対者無しの強化学習を行った場合、制御対象のアクセスポイントAP_CTLは、協調外のアクセスポイントAP_UNCOORDとの衝突によってフレーム損失が起こるという可能性を考慮せずに、最もデータが送れるような行動選択を行うようになる。これにより、図28に示されるように、協調外のアクセスポイントAP_UNCOORDの送信確率に関わらず、ほぼ、100%の確率で送信を行っていることが分かる(曲線k6参照)。よって、協調外のアクセスポイントAP_UNCOORDが、殆ど、通信を行わない場合には、この発明の実施の形態による方式よりも合計スループットが大きくなったと考えられる。
【0358】
図28により、この発明の実施の形態による方式では、制御対象のアクセスポイントAP_CTLがフレーム送信確率を理想的な場合に沿うように変化させていることが分かる(曲線k4,k5参照)。
【0359】
一方、敵対者無しの強化学習を用いた場合、制御対象のアクセスポイントAP_CTLのフレーム送信確率は、ほぼ、一定であることが分かる(曲線k6)。しかし、協調外のアクセスポイントAP_UNCOORDのフレーム送信確率が低い場合には、この発明の実施の形態による方式と理想的な方式の間には乖離が見られるようになる(曲線k4,k5参照)。これは、上述と同様に、制御対象のアクセスポイントAP_CTLが協調外のアクセスポイントAP_UNCOORDのフレーム送信確率が低い場合に対する学習が不足しているからだと考えられる。
【0360】
図29は、図1に示す制御装置10の別の概略図である。この発明の実施の形態による制御装置は、図29に示す制御装置10Aであってもよい。
【0361】
図29を参照して、制御装置10Aは、図2に示す制御装置10の制御手段3および学習器4をそれぞれ制御手段3Aおよび学習器4Aに変えたものであり、その他は、制御装置10と同じである。
【0362】
制御手段3Aは、図27に示す曲線k2と曲線k3との交点における協調外のアクセスポイントAP_UNCOORDによるフレームの送信確率をしきい値TRP_thとして予め保持する。
【0363】
また、制御手段3Aは、データベース2の対応表TBL1-1に格納された成功/失敗情報IF_SUCCESS/FAILUREに基づいて敵対アクセスポイントAP_ADVによるフレームの送信確率を算出する。より具体的には、制御手段3Aは、対応表TBL1-1に格納された複数の成功/失敗情報IF_SUCCESS/FAILUREを検出し、その検出した複数の成功/失敗情報IF_SUCCESS/FAILUREに基づいて、“0”からなる成功/失敗情報IF_SUCCESS/FAILUREを検出する。
【0364】
そして、制御手段3Aは、“0”からなる成功/失敗情報IF_SUCCESS/FAILUREの個数を複数の成功/失敗情報IF_SUCCESS/FAILUREの総数で除算して敵対アクセスポイントAP_ADVによるフレームの送信確率TRP_ADVを算出する。成功/失敗情報IF_SUCCESS/FAILUREが“0”からなるとき、制御対象のアクセスポイントAP_Nによって送信されたフレームが敵対アクセスポイントAP_ADVによって送信されたフレームと衝突したと考えることができる。従って、“0”からなる成功/失敗情報IF_SUCCESS/FAILUREの個数を成功/失敗情報IF_SUCCESS/FAILUREの総数で除算することによって敵対アクセスポイントAP_ADVによるフレームの送信確率TRP_ADVを算出することができる。
【0365】
制御手段3Aは、フレームの送信確率TRP_ADVを算出すると、その算出したフレームの送信確率TRP_ADVをしきい値TRP_thと比較する。そして、フレームの送信確率TRP_ADVがしきい値TRP_th以下であるとき、制御手段3Aは、敵対アクセスポイントAP_ADV無しの強化学習(Q学習)(=「敵対者無しの強化学習」)を実行するための指示信号INS1を生成して学習器4Aへ出力する。
【0366】
また、制御手段3Aは、フレームの送信確率TRP_ADVがしきい値TRP_th以下であるとき、データベース2の対応表TBL1-1から制御対象のアクセスポイントAP_Nがフレームを送信したときの送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILUREおよび送信スケジュールSCH_CTLを読み出すとともにデータベース2の対応表TBL2-1から送信スケジュールSCH_COORDを読み出し、その読み出した送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILUREおよび送信スケジュールSCH_CTL,SCH_COORDを学習器4Aへ出力する。
【0367】
一方、フレームの送信確率TRP_ADVがしきい値TRP_thよりも大きいとき、制御手段3Aは、上述した敵対的強化学習(Q学習)を実行するための指示信号INS2を生成して学習器4Aへ出力する。
【0368】
そして、制御手段3Aは、学習器4Aから制御対象のアクセスポイントAP_Nについての強化学習または敵対的強化学習の結果を受け、その受けた結果に基づいて制御対象のアクセスポイントAP_Nを制御する。
【0369】
制御手段3Aは、その他、制御手段3と同じ機能を果たす。
【0370】
学習器4Aは、制御手段3Aから指示信号INS1を受けると、敵対アクセスポイントAP_ADV無しの強化学習を実行する。より具体的には、学習器4Aは、学習器5と行動価値関数Qπ (s,a),Qπ (s,a)のやり取りをせずに、単独で、敵対アクセスポイントAP_ADV無しの強化学習をQ学習によってN’itcr個のタイムスロットにおいて実行し、期待累積報酬Rが最大になるように制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を繰り返し更新する。そして、学習器4Aは、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると、送信タイミングtg_TRになったときの強化学習(Q学習)の結果(=QテーブルTBL-Q3)を制御手段3Aへ出力する。
【0371】
また、学習器4Aは、制御手段3Aから指示信号INS2を受けると、学習器5と共に、上述した敵対的強化学習(Q学習)を実行し、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると、送信タイミングtg_TRになったときの敵対的強化学習(Q学習)の結果(=QテーブルTBL-Q1)を制御手段3Aへ出力する。
【0372】
学習器4Aは、その他、学習器4と同じ機能を果たす。
【0373】
学習器4Aにおける敵対アクセスポイントAP_ADV無しの強化学習(Q学習)について説明する。
【0374】
図30は、敵対アクセスポイントAP_ADV無しの強化学習におけるQテーブルの概念図である。
【0375】
図30を参照して、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を敵対アクセスポイントAP_ADV無しの強化学習(Q学習)によって更新するときのQテーブルTBL-Q3は、協調APであるアクセスポイントAP_1,AP_2の状態と、制御対象のアクセスポイントAP_Nの行動とによって構成される。
【0376】
協調APであるアクセスポイントAP_1,AP_2の状態を2ビットの数値[n,n]によって表せば、[-1,-1]~[1,1]の4個である。
【0377】
一方、制御対象のアクセスポイントAP_Nの行動aは、図11において説明した通り、4個の行動からなる。
【0378】
従って、QテーブルTBL-Q3は、4行×4列の行列によって表され、16個のQ値(=Q1,1~Q4,4)を含む。そして、16個のQ値(=Q1,1~Q4,4)の初期値は、“0”である。
【0379】
図31から図33は、それぞれ、敵対アクセスポイントAP_ADV無しの強化学習におけるQテーブルの更新方法を説明するための第1から第3の概略図である。
【0380】
図31を参照して、Q学習の初期状態においては、QテーブルTBL-Q3_1の全てのQ値(Q1,1~Q4,4)は、“0”である(図31の(a)参照)。
【0381】
そして、学習器4Aは、Q学習において最大のQ値を得るためのアクセスポイントAP_1,AP_2の状態sを決定する。16個のQ値(=Q1,1~Q4,4)の全ての初期値が“0”であるので、学習器4Aは、例えば、アクセスポイントAP_1,AP_2の状態sを[-1,-1]に決定したものとする。
【0382】
学習器4Aは、アクセスポイントAP_1,AP_2の状態sを決定すると、所定の行動選択則(ソフトマックス行動選択則またはε-greedy行動則)に従って制御対象のアクセスポイントAP_Nの行動aを選択する。この場合、Qテーブルの全てのQ値(Q1,1~Q4,4)が“0”であるので、学習器4Aは、ランダムに制御対象のアクセスポイントAP_Nの行動aを選択する。そして、学習器4Aは、例えば、制御対象のアクセスポイントAP_Nの行動aとして“1”(1Mbit/slotの伝送速度でフレームを送信する行動)を選択したものとする。
【0383】
そうすると、学習器4Aは、制御手段3Aから受けた送信区間TRS_CTL、伝送速度TRD_CTLおよび成功/失敗情報IF_SUCCESS/FAILUREに基づいて制御対象のアクセスポイントAP_Nの報酬rを算出する。この場合、敵対アクセスポイントAP_ADVが存在しないので、学習器4Aは、伝送速度×IF_SUCCESS/FAILURE×[送信区間TRS_CTLの時間長]によって報酬rを算出する。より具体的には、学習器4Aは、成功/失敗情報IF_SUCCESS/FAILUREが“1”からなるとき、r=1Mbit/slot×[送信区間TRS_CTLの時間長]によって報酬rを算出し、成功/失敗情報IF_SUCCESS/FAILUREが“0”からなるとき、報酬rをr=0と算出する。
【0384】
また、学習器4Aは、次のタイムスロットにおける状態s(=s’)において制御対象のアクセスポイントAP_Nが行動空間Aの全ての行動を取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を算出する。この場合、QテーブルTBL-Q3-1において、16個のQ値(=Q1,1~Q4,4)の全ての初期値が“0”であるので、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))は、“0”である。
【0385】
その後、学習器4Aは、算出した報酬rおよび行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))と、予め設定されたα,γと、行動価値関数Qπ (s,a)(=Q値)とを式(10)に代入して行動価値関数Qπ (s,a)を更新する。この場合、QテーブルTBL-Q3_1の全てのQ値が“0”であるので、行動価値関数Qπ (s,a)(=Q値)は、“0”からなる。その結果、式(10)の右辺は、0+α[r+γ×0-0]=αrとなるので、更新された行動価値関数Qπ (s,a)は、Q値(q1,2=αr)からなる。これによって、QテーブルTBL-Q3_1は、QテーブルTBL-Q3_2に更新される(図31の(b)参照)。
【0386】
引き続いて、学習器4Aは、例えば、協調APのアクセスポイントAP_1,AP_2の状態sを[-1,1]に決定する。そして、学習器4Aは、最大のQ値を得るために、所定の行動選択則(ソフトマックス行動選択則またはε-greedy行動則)に従って、状態s(=[-1,1])における制御対象のアクセスポイントAP_Nの行動aを選択する。この場合、学習器4Aは、例えば、制御対象のアクセスポイントAP_Nの行動aとして“-1”(フレームを送信しない行動)を選択したものとする。
【0387】
そうすると、学習器4Aは、上述した方法によって制御対象のアクセスポイントAP_Nの報酬rを算出する。この場合、制御対象のアクセスポイントAP_Nは、“-1”(フレームを送信しない行動)を選択したので、報酬rは、“0”である。
【0388】
また、学習器4Aは、次のタイムスロットにおける状態s(=s’)において制御対象のアクセスポイントAP_Nが行動空間Aの全ての行動を取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を算出する。この場合、次のタイムスロットにおける状態s(=s’)が状態[-1,-1]であるとき、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))は、q1,2(=αr)からなり、次のタイムスロットにおける状態s(=s’)が状態[-1,-1]以外であるとき、状態[-1,-1]以外の状態に対応するQ値の全てが“0”であるので(図31の(b)に示すQテーブルTBL-Q3_2参照)、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))は、“0”からなる(図31のQテーブルTBL-Q3_2参照)。従って、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))は、q1,2(=αr)または“0”からなる。
【0389】
学習器4Aは、行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を算出すると、算出した報酬rおよび行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))と、予め設定されたα,γと、行動価値関数Qπ (s,a)(=Q値=q1,2)とを式(10)に代入して行動価値関数Qπ (s,a)を更新する。この場合、式(10)の右辺は、q1,2+α[r+γ×q1,2-q1,2]またはq1,2+α[r+γ×0-q1,2]=q1,2+α[r-q1,2]となるので、更新された行動価値関数Qπ (s,a)は、Q値(q3,1=q1,2+α[r+γ×q1,2-q1,2]またはq1,2+α[r-q1,2])からなる。これによって、QテーブルTBL-Q3_2は、QテーブルTBL-Q3_3に更新される(図32の(a)参照)。
【0390】
なお、学習器4Aは、ε-greedy行動則によって制御対象のアクセスポイントAP_Nの行動aを選択した場合において、発生した乱数がε以下でないとき、制御対象のアクセスポイントAP_Nの行動aとしてQ値が最大である行動を選択する。この時点では、QテーブルTBL-Q3は、図31の(b)に示す状態になっているので、最大のQ値は、q1,2になる。従って、学習器4Aは、制御対象のアクセスポイントAP_Nの行動aとして“1”(1Mbit/slotの伝送速度でフレームを送信する行動)を選択する。
【0391】
そして、学習器4Aは、制御対象のアクセスポイントAP_Nが行動“1”(1Mbit/slotの伝送速度でフレームを送信する行動)を実行したときの報酬rを上述した方法によって算出し、その算出した報酬rを用いて式(10)によってQ値(=q1,2)をQ値(=q’1,2)に更新する(図32の(b)参照)。これによって、QテーブルTBL-Q3-2は、QテーブルTBL-Q3-4に更新される。
【0392】
以後、学習器4Aは、N’itcr個のタイムスロットの全てについて、上述した動作を繰り返し実行してQテーブルTBL-Q3のQ値を更新する。
【0393】
そして、N’itcr個のタイムスロットの全てについてQテーブルTBL-Q3のQ値を更新したとき、QテーブルTBL-Q3は、例えば、図33に示すQテーブルTBL-Q3-5に更新されている。
【0394】
学習器4Aは、N’itcr個のタイムスロットの全てについてQテーブルTBL-Q3のQ値を更新すると、制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRにおいて、最終的に更新されたQテーブルTBL-Q3-5(図33参照)を制御手段3Aへ出力する。
【0395】
そして、図31から図33において更新されたQ値は、実質的に報酬rを累積した値からなり、報酬rは、制御対象のアクセスポイントAP_Nの行動aに応じて決定される(式(7)参照)ので、最大のQ値が得られるときの制御対象のアクセスポイントAP_Nの行動aは、制御対象のアクセスポイントAP_Nがフレームを送信すするときのスループットを最大にする行動(「スループット最大行動」と言う。)からなる。
【0396】
なお、学習器4Aが敵対アクセスポイントAP_ADV無しの強化学習を実行している間、学習器5は、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新する敵対的強化学習を停止する。そして、学習器5は、制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を学習器4Aから受けると、上述した方法によって、敵対アクセスポイントAP_ADVの行動価値関数Qπ (s,a)を更新する敵対的強化学習を実行する。
【0397】
図34は、図29に示す制御装置10Aの動作を説明するためのフローチャートである。図34に示すフローチャートは、図21に示すフローチャートのステップS5~ステップS8をステップS9~ステップS13に変えたものであり、その他は、図21に示すフローチャートと同じである。
【0398】
図34を参照して、制御装置10Aの動作が開始されると、上述したステップS1~ステップS4が順次実行される。
【0399】
そして、ステップS4の後、制御手段3Aは、データベース2の対応表TBL1-1に格納された複数の成功/失敗情報IF_SUCCESS/FAILUREを読み出し、その読み出した複数の成功/失敗情報IF_SUCCESS/FAILUREに基づいて、上述した方法によって、敵対アクセスポイントAP_ADVによるフレームの送信確率TRP_ADVを算出する(ステップS9)。
【0400】
その後、制御手段3Aは、フレームの送信確率TRP_ADVがしきい値TRP_th以下であるか否かを判定する(ステップS10)。
【0401】
ステップS10において、フレームの送信確率TRP_ADVがしきい値TRP_th以下であると判定されたとき、制御手段3Aは、信号INS1および制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)を生成し、その生成した信号INS1および制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)を学習器4Aへ出力する。
【0402】
学習器4Aは、制御手段3Aから信号INS1および制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)を受けると、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)に基づいて、アクセスポイントAP_Nが制御対象のアクセスポイントであり、アクセスポイントAP_1~AP_N-1が協調APであることを検知する。そして、学習器4Aは、制御手段3Aから受けた信号INS1に基づいて、敵対アクセスポイントAP_ADV無しの強化学習を実行する(ステップS11)。
【0403】
一方、ステップS10において、フレームの送信確率TRP_ADVがしきい値TRP_th以下でないと判定されたとき、制御手段3Aは、信号INS2を生成し、その生成した信号INS2を学習器4A,5へ出力する。
【0404】
学習器4A,5は、制御手段3Aから信号INS2を受けると、その受けた信号INS2に基づいて、図21のステップS5~ステップS7を順次実行することによって敵対アクセスポイントAP_ADV有りの敵対的強化学習を実行する(ステップS12)。なお、ステップS12において実行されるステップS7の詳細な動作は、上述した図22から図24に示すフローチャートに従って実行される。
【0405】
そして、制御手段3Aは、ステップS11またはステップS12の後、強化学習によって得られたQテーブルTBL-Q3または敵対的強化学習によって得られたQテーブルTBL-Q1と、協調APであるアクセスポイントAP_1~AP_N-1のフレームの送信スケジュールとに基づいて制御対象のアクセスポイントAP_Nの行動aを制御し、敵対的強化学習によって得られたQテーブルTBL-Q2に基づいて敵対アクセスポイントAP_ADVの行動aを制御する(ステップS13)。これによって、制御装置10Aの動作が終了する。
【0406】
なお、図34に示すフローチャートにおいては、ステップS11からステップS13へ移行した場合、制御手段3Aは、敵対アクセスポイントAP_ADV無しの強化学習によって得られたQテーブルTBL-Q3とアクセスポイントAP_1,AP_2のフレームの送信スケジュールとに基づいて制御対象のアクセスポイントAP_Nの行動aを制御する。
【0407】
一方、ステップS12からステップS13へ移行した場合、制御手段3Aは、敵対アクセスポイントAP_ADV有りの敵対的強化学習によって得られたQテーブルTBL-Q1とアクセスポイントAP_1,AP_2のフレームの送信スケジュールとに基づいて制御対象のアクセスポイントAP_Nの行動aを制御し、敵対アクセスポイントAP_ADV有りの敵対的強化学習によって得られたQテーブルTBL-Q2に基づいて敵対アクセスポイントAP_ADVの行動aを制御する。
【0408】
また、ステップS13において、QテーブルTBL-Q1(またはQテーブルTBL-Q3)とアクセスポイントAP_1~AP_N-1のフレームの送信スケジュールとに基づいて制御対象のアクセスポイントAP_Nの行動aを制御するのは、制御対象のアクセスポイントAP_NおよびアクセスポイントAP_1~AP_N-1は、フレーム送出情報を共有し、相互に協調的な制御を行うからである。
【0409】
図35は、図34のステップS11の詳細な動作を説明するためのフローチャートである。
【0410】
図35を参照して、図34のステップS10において、フレームの送信確率TRP_ADVがしきい値TRP_th以下であると判定されたとき、学習器4Aは、信号INS1、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、および送信スケジュールSCH_CTL,SCH_COORDを制御手段3Aから受ける(ステップS111)。
【0411】
そして、学習器4Aは、信号INS1に基づいて、敵対アクセスポイントAP_ADV無しの強化学習(Q学習)を実行することを検知する(ステップS112)。
【0412】
引き続いて、学習器4Aは、制御対象のアクセスポイントを示す信号S_CTL_AP(AP_N)に基づいて、アクセスポイントAP_1~AP_Nのうち、アクセスポイントAP_Nが制御対象のアクセスポイントであり、アクセスポイントAP_1~AP_N-1が協調アクセスポイントであることを検知する(ステップS113)。
【0413】
そうすると、学習器4Aは、i=1を設定する(ステップS114)。そして、学習器4Aは、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、および送信スケジュールSCH_CTL,SCH_COORDに基づいて強化学習(Q学習)をN個のタイムスロットにおいて実行する(ステップS115)。
【0414】
また、学習器4Aは、ステップS115における強化学習の実行と並行して、送信スケジュールSCH_CTLに基づいてタイミングtgが制御対象のアクセスポイントAP_Nによるフレームの送信タイミングtg_TRになったことを検知すると(ステップS116)、QテーブルTBL-Q3を制御手段3Aへ出力する(ステップS117)。
【0415】
ステップS116においては、学習器4Aは、上述した図22のステップS75における方法と同じ方法によって、タイミングtgが送信タイミングtg_TRになったことを検知する。
【0416】
また、ステップS117においては、学習器4Aは、送信タイミングtg_TRにおいて、強化学習(=Q学習)における最新のQテーブルTBL-Q3を制御手段3Aへ出力する。より具体的には、学習器4Aは、ステップS115において実行されている強化学習によって送信タイミングtg_TRの時点までに更新された最新のQテーブルTBL-Q3を制御手段3Aへ出力する。
【0417】
ステップS117の後、一連の動作は、ステップS115および図34のステップS13へ移行する。
【0418】
ステップS115の後、学習器4Aは、i=N’itcrであるか否かを判定する(ステップS118)。ここで、N’itcrは、Nの自然数倍の整数である。なお、N’itcrは、Nitcrと同じであってもよく、Nitcrと異なっていてもよい。
【0419】
ステップS118において、i=N’itcrでないと判定されたとき、学習器4Aは、i=i+1を設定する(ステップS119)。その後、一連の動作は、ステップS115,S116へ移行し、ステップS118において、i=N’itcrであると判定されるまで、ステップS115~ステップS119が繰り返し実行される。
【0420】
そして、ステップS118において、i=N’itcrであると判定されると、学習器4Aは、上述した図22のステップS82における方法と同じ方法によって、強化学習を終了するか否かを判定する(ステップS120)。
【0421】
ステップS120において、強化学習を終了しないと判定されたとき、一連の動作は、ステップS114へ移行し、ステップS120において、強化学習を終了すると判定されるまで、ステップS114~ステップS120が繰り返し実行される。
【0422】
そして、ステップS120において、強化学習を終了すると判定されると、学習器4Aは、強化学習を停止する(ステップS121)。
【0423】
図35に示すフローチャートによれば、学習器4Aが、N個のタイムスロットにおいて、制御対象のアクセスポイントAP_Nの行動を学習する強化学習(Q学習)を実行するステップS115が、i=N’itcrになるまで繰り返し実行される(ステップS115,S118,S119参照)。
【0424】
そして、学習器4Aは、ステップS115に並行して、送信スケジュールSCH_CTLに基づいてタイミングtgが送信タイミングtg_TRになったことを検知すると、送信タイミングtg_TRにおける最新のQテーブルTBL-Q3を制御手段3Aへ出力する(ステップS116,S117参照)。
【0425】
また、図35に示すフローチャートによれば、ステップS117において、QテーブルTBL-Q3が制御手段3Aへ出力された後、図34のステップS13が実行されるので、学習器4Aは、制御手段3Aの動作と並行してステップS115の強化学習を繰り返し実行する。つまり、学習器4Aは、ステップS120において、学習を終了すると判定されるまでは、制御手段3Aの動作と並行してステップS115の強化学習を繰り返し実行する。
【0426】
図36は、図35のステップS115の詳細な動作を説明するためのフローチャートである。
【0427】
図36を参照して、図35のステップS114の後、学習器4Aは、i=1を設定し(ステップS1151)、i番目のタイムスロットにおける協調APのアクセスポイントAP_1~AP_N-1の状態sを決定する(ステップS1152)。
【0428】
引き続いて、学習器4Aは、所定の行動選択則(ソフトマックス行動選択則またはε-greedy行動則)に従って、Q値が最大になるようにi番目のタイムスロットにおける制御対象のアクセスポイントAP_Nの行動aを選択する(ステップS1153)。
【0429】
そして、学習器4Aは、成功/失敗情報IF_SUCCESS/FAILURE、送信区間TRS_CTLおよび伝送速度TRD_CTLに基づいて、状態sにおいて、制御対象のアクセスポイントAP_Nが行動aを実行したときのi番目のタイムスロットにおける報酬rを上述した方法によって算出する(ステップS1154)。
【0430】
その後、学習器4Aは、次のタイムスロット(=(i+1)番目のタイムスロット)の状態s’において、制御対象のアクセスポイントAP_Nが取り得る全ての行動を取ったときの行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を算出する(ステップS1155)。
【0431】
そうすると、学習器4Aは、式(10)によって、報酬rおよび行動価値関数Qπ (s’,a)の最大値(=maxQπ (s’,a)(a∈A))を用いて、状態sおよび行動aに対応する制御対象のアクセスポイントAP_Nの行動価値関数Qπ (s,a)を制御対象のアクセスポイントAP_Nの期待累積報酬Rが最大になるように更新する(ステップS1156)。
【0432】
その後、学習器4Aは、i=Nであるか否かを判定する(ステップS1157)。
【0433】
ステップS1157において、i=Nでないと判定されたとき、学習器4Aは、i=i+1を設定する(ステップS1158)。その後、一連の動作は、ステップS1152へ移行し、ステップS1157において、i=Nであると判定されるまで、ステップS1152~ステップS1158が繰り返し実行される。
【0434】
そして、ステップS1157において、i=Nであると判定されると、学習器4Aは、i=u×Nを設定する(ステップS1159)。ここで、uは、ステップS1157において、i=Nであると判定された回数を示し、u=1,2,3,・・・,N’itcr/Nである。ステップS1159の後、一連の動作は、図35のステップS118へ移行する。
【0435】
図36のステップS1152~ステップS1158がN回実行されると、i=Nとなり、ステップS1157において、i=Nであると判定され、ステップS1159において、i=u×Nが設定される。そして、図35のステップS118において、i=N’itcrであるか否かが判定される。上述したように、N’itcrは、Nの自然数倍の整数であり、u=1,2,3,・・・,N’itcr/Nであるので、ステップS1159におけるuがu=N’itcr/Nになると、i=N’itcrとなる。
【0436】
従って、図35に示すフローチャートに整合して図36に示すフローチャートを実行できる。
【0437】
制御装置10Aの動作が図34に示すフローチャート(図22から図24に示すフローチャートおよび図35,36に示すフローチャートを含む)に従って実行されることによって、敵対アクセスポイントAP_ADVによるフレームの送信確率TRP_ADVがしきい値TRP_th以下であるとき、敵対アクセスポイントAP_ADV無しの強化学習が実行され(図34のステップS11参照)、フレームの送信確率TRP_ADVがしきい値TRP_thよりも大きいとき、敵対アクセスポイントAP_ADV有りの敵対的強化学習が実行される(図34のステップS12参照)。
【0438】
その結果、図27に示す制御対象のアクセスポイントAP_Nおよび協調外のアクセスポイントのスループットの和は、フレームの送信確率TRP_ADVがしきい値TRP_th以下であるとき(即ち、協調外のアクセスポイントの送信確率が曲線k2と曲線k3との交点に対応する送信確率以下であるとき)、協調外のアクセスポイントの送信確率に対して曲線k3に従って変化し(即ち、曲線k2に従って変化する場合よりも大きくなり)、フレームの送信確率TRP_ADVがしきい値TRP_thよりも大きいとき(即ち、協調外のアクセスポイントの送信確率が曲線k2と曲線k3との交点に対応する送信確率よりも大きいとき)、協調外のアクセスポイントの送信確率に対して曲線k2に従って変化する。
【0439】
従って、敵対アクセスポイントAP_ADV有りの敵対的強化学習のみを実行した場合(曲線k2)よりも、協調外のアクセスポイントの全ての送信確率に対して制御対象のアクセスポイントAP_Nおよび協調外のアクセスポイントのスループットの和を大きくできる。
【0440】
なお、制御装置10Aの動作は、ソフトウェアによって実現されてもよい。この場合、制御装置10Aは、CPU、ROMおよびRAMを備える。そして、ROMは、図34に示すフローチャート(図22から図24に示すフローチャートおよび図35,36に示すフローチャートを含む)の各ステップからなるプログラムProg_Bを記憶する。
【0441】
CPUは、ROMからプログラムProg_Bを読み出し、その読み出したプログラムProg_Bを実行して、強化学習または敵対的強化学習を実行して制御対象のアクセスポイントAP_N、または制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVを制御する。
【0442】
また、プログラムProg_Bは、CD,DVD等の記録媒体に記録されて流通してもよい。プログラムProg_Bを記録した記録媒体がコンピュータに装着されると、コンピュータは、記録媒体からプログラムProg_Bを読み出して実行し、強化学習または敵対的強化学習を実行して制御対象のアクセスポイントAP_N、または制御対象のアクセスポイントAP_Nおよび敵対アクセスポイントAP_ADVを制御する。
【0443】
従って、プログラムProg_Bを記録した記録媒体は、コンピュータ読み取り可能な記録媒体である。
【0444】
また、通信システム100が制御装置10に代えて制御装置10Aを備える場合、通信システム100の動作は、フレームの送信確率TRP_ADVがしきい値TRP_thよりも大きいとき、図26に示すフローチャートに従って実行され、フレームの送信確率TRP_ADVがしきい値TRP_th以下であるとき、図26に示すフローチャートのステップS206を「制御対象のアクセスポイントAP_Nの通信の成否および行動に基づいて行動価値関数Qπ (s,a)(=Q値)を更新するステップ」に変えたフローチャートに従って実行される。
【0445】
この発明の実施の形態においては、各アクセスポイントAP_1~AP_Nは、上述した制御装置10を備えていてもよい。図37は、図1に示す制御装置10を備えるアクセスポイントの概略図である。
【0446】
図37を参照して、アクセスポイント20は、制御装置10と、アンテナ21と、通信手段22と、ホストシステム23とを備える。
【0447】
制御装置10は、有線ケーブル6を介して、アクセスポイント20以外のアクセスポイントから送信スケジュールSCH_COORDを収集するとともに、ホストシステム23からアクセスポイント20の送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILUREおよび送信スケジュールSCH_CTLを受けるとともに、協調外のアクセスポイントAP_UNCOORDの送信区間TRS_UNCOORDを受ける。
【0448】
そして、制御装置10は、送信区間TRS_CTL、伝送速度TRD_CTL、成功/失敗情報IF_SUCCESS/FAILURE、送信スケジュールSCH_CTL,SCH_COORDおよび送信区間TRS_UNCOORDに基づいて,上述した方法によって敵対的強化学習を実行し、QテーブルTBL-Q1をホストシステム23へ出力する。
【0449】
通信手段22は、フレームおよび通信条件(フレームを送信するタイムスロットおよび伝送速度)をホストシステム23から受け、その受けた通信条件でフレームをアンテナ21を介して端末装置へ送信する。そして、通信手段22は、端末装置からACKを受信し、その受信したACKをホストシステム23へ出力する。
【0450】
また、通信手段22は、アンテナ21を介して端末装置からフレームを受信し、その受信したフレームをホストシステム23へ出力する。
【0451】
ホストシステム23は、QテーブルTBL-Q1を制御装置10から受ける。そして、ホストシステム23は、QテーブルTBL-Q1に基づいてフレームを送信するか否かを決定し、フレームを送信するとき、フレームと、フレームを送信するタイムスロットおよび伝送速度とを通信手段22へ出力する。
【0452】
ホストシステム23は、フレーム等を通信手段22へ出力した後、通信手段22からACKを受けると、フレームの送信に成功したと判定する。一方、ホストシステム23は、フレーム等を通信手段22へ出力した後、一定時間が経過しても、通信手段22からACKを受けないとき、フレームの送信に失敗したと判定する。そして、ホストシステム23は、成功/失敗情報IF_SUCCESS/FAILUREを生成して制御装置10へ出力する。
【0453】
また、ホストシステム23は、フレームを通信手段22から受ける。
【0454】
なお、アクセスポイント20は、制御装置10に代えて図29に示す制御装置10Aを備えていてもよい。
【0455】
この場合、制御装置10Aは、敵対アクセスポイントAP_ADVによるフレームの送信確率TRP_ADVがしきい値TRP_th以下であるとき、上述した方法によって、敵対アクセスポイントAP_ADV無しの強化学習を実行してQテーブルTBL-Q3をホストシステム23へ出力する。
【0456】
一方、フレームの送信確率TRP_ADVがしきい値TRP_thよりも大きいとき、制御装置10Aは、上述した方法によって敵対的強化学習を実行し、QテーブルTBL-Q1をホストシステム23へ出力する。
【0457】
ホストシステム23は、QテーブルTBL-Q1またはQテーブルTBL-Q3を制御装置10Aから受け、その受けたQテーブルTBL-Q1またはQテーブルTBL-Q3に基づいてフレームを送信するか否かを決定し、フレームを送信するとき、フレームと、フレームを送信するタイムスロットおよび伝送速度とを通信手段22へ出力する。
【0458】
この発明の実施の形態においては、サービスセットBSS_1~BSS_Nは、「複数のサービスセット」を構成し、サービスセットBSS_1~BSS_Nのうちの任意の1つのサービスセットは、「制御対象サービスセット」を構成し、サービスセットBSS_1~BSS_Nのうちの制御対象サービスセット以外の1個以上のサービスセットは、「協調サービスセット」を構成する。
【0459】
また、この発明の実施の形態においては、制御対象サービスセットに含まれるアクセスポイントAPは、「制御対象基地局」を構成し、協調サービスセットに含まれるアクセスポイントAPは、「協調基地局」を構成し、敵対アクセスポイントAP_ADVは、「敵対基地局」を構成する。
【0460】
更に、この発明の実施の形態においては、送信区間TRS_CTLは、「第1の送信区間」を構成し、送信区間TRS_ADVは、「第2の送信区間」を構成する。
【0461】
更に、この発明の実施の形態においては、送信スケジュールSCH_CTLは、「第1の送信スケジュール」を構成し、送信スケジュールSCH_COORDは、「第2の送信スケジュール」を構成する。
【0462】
更に、この発明の実施の形態においては、学習器4,4Aが実行する敵対的強化学習は、「第1の敵対的強化学習」を構成し、学習器5が実行する敵対的強化学習は、「第2の敵対的強化学習」を構成する。
【0463】
更に、この発明の実施の形態においては、学習器4,4Aが行動価値関数Qπ (s,a)を固定して敵対的強化学習を実行することは、「敵対基地局による妨害行動を固定して第1の敵対的強化学習を実行する」ことに相当する。制御対象のアクセスポイントAP_Nが取得する報酬rは、敵対アクセスポイントAP_ADVの妨害行動aにも応じて決定されるので(式(7)参照)、学習器4,4Aは、この妨害行動aを固定して、制御対象のアクセスポイントAP_Nが更に多くの報酬rを得ることができる行動a(即ち、妨害行動aを克服できる行動a)を敵対的強化学習によって学習するからである。
【0464】
更に、この発明の実施の形態においては、学習器5が行動価値関数Qπ (s,a)を固定して敵対的強化学習を実行することは、「制御対象のアクセスポイントAP_Nの性能維持行動を固定して第2の敵対的強化学習を実行する」ことに相当する。制御対象のアクセスポイントAP_Nが取得する報酬rは、制御対象のアクセスポイントAP_Nの性能維持行動a(=フレームの送信に成功する行動)に応じて決定されるので、学習器5は、この性能維持行動を固定して、敵対アクセスポイントAP_ADVが報酬rを少なくできる行動a(即ち、制御対象のアクセスポイントAP_Nの行動aを妨害する妨害行動)を敵対的強化学習によって学習するからである。
【0465】
更に、この発明の実施の形態においては、行動価値関数Qπ (s,a)は、「第1の行動価値関数」を構成し、行動価値関数Qπ (s,a)は、「第2の行動価値関数」を構成する。
【0466】
更に、この発明の実施の形態においては、QテーブルTBL-Q1は、「第1の敵対的強化学習の結果」を構成し、QテーブルTBL-Q2は、「第2の敵対的強化学習の結果」を構成し、QテーブルTBL-Q3は、「強化学習の結果」を構成する。
【0467】
今回開示された実施の形態はすべての点で例示であって制限的なものではないと考えられるべきである。本発明の範囲は、上記した実施の形態の説明ではなくて特許請求の範囲によって示され、特許請求の範囲と均等の意味および範囲内でのすべての変更が含まれることが意図される。
【産業上の利用可能性】
【0468】
この発明は、制御装置、それを備えた基地局、コンピュータに実行させるためのプログラムおよびプログラムを記録したコンピュータ読み取り可能な記録媒体に適用される。
【符号の説明】
【0469】
1 収集手段、2 データベース、3,3A 制御手段、4,4A,5 学習器、6 有線ケーブル、10,10A 制御装置、20 アクセスポイント、21 アンテナ、22 通信手段、23 ホストシステム、100 通信システム。
図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