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

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

▶ トヨタ自動車株式会社の特許一覧

<>
  • 特許-内燃機関の制御装置 図1
  • 特許-内燃機関の制御装置 図2
  • 特許-内燃機関の制御装置 図3
  • 特許-内燃機関の制御装置 図4
  • 特許-内燃機関の制御装置 図5
  • 特許-内燃機関の制御装置 図6
  • 特許-内燃機関の制御装置 図7
  • 特許-内燃機関の制御装置 図8
  • 特許-内燃機関の制御装置 図9
  • 特許-内燃機関の制御装置 図10
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2023-10-02
(45)【発行日】2023-10-11
(54)【発明の名称】内燃機関の制御装置
(51)【国際特許分類】
   F02D 45/00 20060101AFI20231003BHJP
   F02D 29/02 20060101ALI20231003BHJP
   F02D 41/30 20060101ALI20231003BHJP
【FI】
F02D45/00 372
F02D29/02 Z
F02D41/30
F02D45/00 376
【請求項の数】 2
(21)【出願番号】P 2020017815
(22)【出願日】2020-02-05
(65)【公開番号】P2021124055
(43)【公開日】2021-08-30
【審査請求日】2022-03-17
(73)【特許権者】
【識別番号】000003207
【氏名又は名称】トヨタ自動車株式会社
(74)【代理人】
【識別番号】100105957
【弁理士】
【氏名又は名称】恩田 誠
(74)【代理人】
【識別番号】100068755
【弁理士】
【氏名又は名称】恩田 博宣
(72)【発明者】
【氏名】橋本 洋介
(72)【発明者】
【氏名】片山 章弘
(72)【発明者】
【氏名】大城 裕太
(72)【発明者】
【氏名】杉江 和紀
(72)【発明者】
【氏名】岡 尚哉
【審査官】戸田 耕太郎
(56)【参考文献】
【文献】特開平10-176578(JP,A)
【文献】特開2000-250604(JP,A)
【文献】特開平10-254505(JP,A)
【文献】特開2017-191567(JP,A)
【文献】特開2000-203304(JP,A)
【文献】特開2021-110276(JP,A)
【文献】特開2021-115875(JP,A)
【文献】特開2021-116740(JP,A)
【文献】特開2021-116781(JP,A)
【文献】特開2021-116783(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
F02D 45/00
F02D 29/02
F02D 41/30
(57)【特許請求の範囲】
【請求項1】
車両に搭載された内燃機関の燃料噴射弁を操作することで同内燃機関を制御する内燃機関の制御装置であって、
エアフローメータが検出する吸入空気量、吸気温センサが検出する吸気温、吸気圧センサが検出する吸気圧、スロットルセンサが検出するスロットル開口度、車速センサが検出する車速、空燃比センサが検出する混合気の空燃比、アクセルペダルセンサが検出するアクセルペダルの踏み込み量、及び車速センサが検出する車速、のそれぞれを状態変数としたとき、
複数種類の前記状態変数と前記燃料噴射弁の噴射量指令値との関係を規定するデータであって前記車両の走行中に更新される関係規定データが記憶されるとともに、複数種類の前記状態変数に基づく前記噴射量指令値の演算に用いられるデータであって前記車両の走行中に更新されない適合済みデータが予め記憶された記憶装置と、
前記燃料噴射弁の操作を実行する実行装置であって、
前記適合済みデータを用いて複数種類の前記状態変数に基づき演算した前記噴射量指令値にて前記燃料噴射弁を操作する第1操作処理と、
前記関係規定データと複数種類の前記状態変数とにより定まる前記噴射量指令値にて前記燃料噴射弁を操作する第2操作処理と、
前記第2操作処理により前記燃料噴射弁が操作されているときの前記状態変数に基づいて報酬を算出するとともに、前記状態変数、前記噴射量指令値、及び前記報酬に基づいて、前記報酬の期待収益を増加させるように前記関係規定データを更新する強化学習処理と、
前記車両に搭載されている操作パネルへの操作に応じて前記燃料噴射弁を操作する処理を、前記第1操作処理と前記第2操作処理とに切り替える切替処理と、
前記第2操作処理による前記燃料噴射弁の操作中に前記第1操作処理での前記噴射量指令値の演算に使用される複数種類の前記状態変数の中の一部の種類の前記状態変数の値を取得するとともに、取得した同状態変数の値の時系列データを前記記憶装置に記録する記録処理と、
を実行する実行装置と、
を備え
前記第1操作処理には、前記記録処理で前記時系列データを記憶した前記一部の種類の前記状態変数の値を制御量として同制御量の目標値と検出値との偏差に応じて前記噴射量指令値を補正するフィードバック補正処理が含まれている
内燃機関の制御装置。
【請求項2】
前記車両は、運転者のアクセルペダル操作に応じて前記車両の加減速を行う手動アクセル走行と、前記アクセルペダル操作に基づかずに前記車両の加減速を自動で行う自動アクセル走行と、を行うものであり、
かつ前記切替処理は、前記車両が前記手動アクセル走行を行っている場合に前記第2操作処理を実行し、前記自動アクセル走行を行っている場合に前記第1操作処理を実行する処理である
請求項1に記載の内燃機関の制御装置。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、車両に搭載された内燃機関の制御装置に関する。
【背景技術】
【0002】
特許文献1には、アクセルペダルの操作量をフィルタ処理した値に基づき、車両に搭載される内燃機関の操作部としてのスロットルバルブを操作する制御装置が記載されている。
【先行技術文献】
【特許文献】
【0003】
【文献】特開2016-006327号公報
【発明の概要】
【発明が解決しようとする課題】
【0004】
上記フィルタには、内燃機関の効率や排気性状、乗員の快適性などの多数の要求を同時に満たす値をスロットルバルブの操作量として設定するものであることが求められるため、その適合は熟練者が多くの工数を掛けて行う必要がある。そうした実情は、スロットルバルブ以外のエンジンの操作部の操作量の適合についても同様となっている。
【課題を解決するための手段】
【0005】
上記課題を解決する内燃機関の制御装置は、車両に搭載された内燃機関の燃料噴射弁を操作することで同内燃機関を制御する内燃機関の制御装置であって、エアフローメータが検出する吸入空気量、吸気温センサが検出する吸気温、吸気圧センサが検出する吸気圧、スロットルセンサが検出するスロットル開口度、車速センサが検出する車速、空燃比センサが検出する混合気の空燃比、アクセルペダルセンサが検出するアクセルペダルの踏み込み量、及び車速センサが検出する車速、のそれぞれを状態変数としたとき、複数種類の前記状態変数と前記燃料噴射弁の噴射量指令値との関係を規定するデータであって前記車両の走行中に更新される関係規定データが記憶されるとともに、複数種類の前記状態変数に基づく前記噴射量指令値の演算に用いられるデータであって前記車両の走行中に更新されない適合済みデータが予め記憶された記憶装置と、前記燃料噴射弁の操作を実行する実行装置であって、前記適合済みデータを用いて複数種類の前記状態変数に基づき演算した前記噴射量指令値にて前記燃料噴射弁を操作する第1操作処理と、前記関係規定データと複数種類の前記状態変数とにより定まる前記噴射量指令値にて前記燃料噴射弁を操作する第2操作処理と、前記第2操作処理により前記燃料噴射弁が操作されているときの前記各状態変数に基づいて報酬を算出するとともに、前記各状態変数、前記噴射量指令値、及び前記報酬に基づいて、前記報酬の期待収益を増加させるように前記関係規定データを更新する強化学習処理と、前記車両に搭載されている操作パネルへの操作に応じて前記燃料噴射弁を操作する処理を、前記第1操作処理と前記第2操作処理とに切り替える切替処理と、前記第2操作処理による前記燃料噴射弁の操作中に前記第1操作処理での前記噴射量指令値の演算に使用される複数種類の前記状態変数の中の一部の種類の前記状態変数の値を取得するとともに、取得した同状態変数の値の時系列データを前記記憶装置に記録する記録処理と、を実行する実行装置と、を備え、前記第1操作処理には、前記記録処理で前記時系列データを記憶した前記一部の種類の前記状態変数の値を制御量として同制御量の目標値と検出値との偏差に応じて前記噴射量指令値を補正するフィードバック補正処理が含まれている。
【0006】
上記内燃機関の制御装置では、予め記憶装置に記憶された適合済みデータを用いて噴射量指令値の演算が行われる第1操作処理による内燃機関の燃料噴射弁の操作では、車両の出荷前に噴射量指令値の適合を済ませておく必要がある。これに対して、第2操作処理の実行中は、同第2操作処理による燃料噴射弁の操作の結果として変化する車両の状態から報酬が算出されるとともに、その報酬の期待収益が増加するように関係規定データが更新される。すなわち、第2操作処理による内燃機関の燃料噴射弁の操作時には、強化学習による噴射量指令値の適合が進められる。このように第2操作処理により燃料噴射弁を操作する際の噴射量指令値については、車両の走行中に自動で適合することが可能なため、車両出荷前の熟練者による噴射量指令値の適合に係る工数を低減できる。ただし、そうした強化学習は車両の様々な状態のもとでそれぞれ時間を掛けて行う必要があり、車両の運用によっては適合の完了に時間を要することがある。そのため、車両の運転状況によっては、車両走行中の強化学習により噴射量指令値を適合するよりも、車両の出荷前に適合を済ませておいた方が、望ましい結果が得られる場合がある。これに対して上記内燃機関の制御装置における実行装置は、切替処理において、車両の状態に応じて燃料噴射弁を操作する処理を、第1操作処理と第2操作処理とに切り替えている。したがって、上記内燃機関の制御装置によれば、内燃機関の燃料噴射弁噴射量指令値の適合に係る熟練者の工数を好適に軽減できる。
【0007】
ここで、第1操作処理での噴射量指令値の演算に用いられる値に、噴射量指令値の演算毎に、状態変数の値から算出された更新量に応じて更新される値が含まれている場合がある。この場合の上記値の更新は、そのときの状態変数の瞬時値に基づいて行われるが、更新された値は、それまでの噴射量指令値の演算毎の状態変数の値に基づき算出された更新量を積算した値となる。このように、第1操作処理での噴射量指令値の演算が、状態変数の瞬時に基づいて行われる場合にあっても、それまでの状態変数の値の推移を反映した値として噴射量指令値が演算される場合がある。そうした場合、第2操作処理から第1操作処理への切替直後の噴射量指令値の演算値には、第2操作処理中の状態変数の値の推移が反映されないため、以前から第1操作処理が継続されていた場合とは異なった値が噴射量指令値として設定されてしまう。
【0008】
これに対して、上記内燃機関の制御装置における実行装置は、記録処理において、第2操作処理による燃料噴射弁の操作中に、第1操作処理での噴射量指令値の演算に使用する一部の種類の状態変数の値を取得するとともに、その取得した状態変数の値の時系列データを記憶装置に記録している。記録した時系列データを参照することで、燃料噴射弁を操作する処理が第2操作処理から第1操作処理に切り替えられたときに、その切替前の第2操作処理の実行中の状態変数の値の推移を反映した値として噴射量指令値を設定することが可能となる。
【図面の簡単な説明】
【0013】
図1】第1実施形態に係る内燃機関の制御装置の構成を模式的に示す図。
図2】同制御装置における実行装置が実行する処理のフローチャート。
図3】同実行装置が実行する第1操作処理でのスロットルバルブの操作に係る処理の流れを示す制御ブロック図。
図4】同実行装置が実行する第1操作処理での燃料噴射弁の操作に係る処理の流れを示す制御ブロック図。
図5】同実行装置が実行する第1操作処理での点火装置の操作に係る処理の流れを示す制御ブロック図。
図6】同実行装置が実行する第2操作処理、及び強化学習処理に係る処理の流れを示すフローチャート。
図7】同実行装置が実行する記録処理のフローチャート。
図8】同実行装置が実行する切替時処理のフローチャート。
図9】(a)は要求トルクTor*及び要求トルク緩変化値Torsm*の推移を、(b)は開口度指令値TA*の推移を、それぞれ示すタイムチャート。
図10】第1操作処理でのスロットルバルブの操作に係る処理の変更例における処理の流れを示す制御ブロック図。
【発明を実施するための形態】
【0014】
以下、内燃機関の制御装置の第1実施形態を、図1図9を参照して詳細に説明する。
図1に、本実施形態の制御装置70、及び同制御装置70が制御対象とする車両VC1に搭載された内燃機関10の構成を示す。内燃機関10の吸気通路12には、上流側から順にスロットルバルブ14及び燃料噴射弁16が設けられており、吸気通路12に吸入された空気や燃料噴射弁16から噴射された燃料は、吸気バルブ18の開弁に伴って、シリンダ20及びピストン22によって区画される燃焼室24に流入する。燃焼室24内において、燃料と空気との混合気は、点火装置26の火花放電に伴って燃焼に供され、燃焼によって生じたエネルギは、ピストン22を介してクランク軸28の回転エネルギに変換される。燃焼に供された混合気は、排気バルブ30の開弁に伴って、排気として排気通路32に排出される。排気通路32には、排気を浄化する後処理装置としての触媒34が設けられている。
【0015】
制御装置70は、内燃機関10の状態を示す制御量であるトルクや排気成分比率等を制御すべく、スロットルバルブ14、燃料噴射弁16及び点火装置26等の内燃機関10の操作部を操作する。なお、図1には、スロットルバルブ14、燃料噴射弁16、及び点火装置26のそれぞれの操作信号MS1~MS3が記載されている。
【0016】
制御装置70は、内燃機関10の制御量の制御のために、内燃機関10の状態を検出する各種センサの検出値を取得する。内燃機関10の状態を検出するセンサには、吸入空気量Gaを検出するエアフローメータ80、吸気温THAを検出する吸気温センサ81、吸気圧Pmを検出する吸気圧センサ82、スロットルバルブ14の開口度であるスロットル開口度TAを検出するスロットルセンサ83、クランク軸28の回転角θcを検出するクランク角センサ84が含まれる。また、上記センサには、燃焼室24でのノッキングの発生状況に応じたノック信号Knkを出力するノックセンサ85、燃焼室24で燃焼された混合気の空燃比AFを検出する空燃比センサ86も含まれる。また、制御装置70は、アクセルペダル87の踏み込み量であるアクセル操作量PAを検出するアクセルペダルセンサ88や、車両VC1の前後方向の加速度Gxを検出する加速度センサ89、車速Vを検出する車速センサ90などの車両VC1の状態を検出するセンサの検出値も参照する。
【0017】
さらに、車両VC1には、手動アクセル走行と自動アクセル走行との走行モードの切り替えや、自動アクセル走行時の設定速度を変更するための操作パネル92が設置されている。手動アクセル走行は、運転者のアクセルペダル87の操作に応じて車両VC1の加減速を行う走行モードであり、自動アクセル走行は、アクセルペダル87の操作に基づかずに、車速Vを設定速度に維持すべく車両VC1の加減速を自動で行う走行モードである。制御装置70は、内燃機関10の制御量の制御に際して、手動アクセル走行、自動アクセル走行のいずれが車両VC1の走行モードとして選択されているかを示すモード変数MVの値を参照してもいる。なお、手動アクセル走行から自動アクセル走行への切り替えは、既定のオートクルーズ許可条件を満たした状態で操作パネル92において設定速度の設定、及びオートクルーズの開始操作を行うことで許可される。オートクルーズ許可条件には、自動車専用道路を走行中であること、車速Vが既定の範囲内の速度であること、などが含まれる。一方、自動アクセル走行から手動アクセル走行への切り替えは、運転者がブレーキペダルを踏むことや、操作パネル92においてオートクルーズの解除操作を行うことで実施される。
【0018】
制御装置70は、内燃機関10の制御に係る処理を実行する実行装置としてのCPU72と、周辺回路78と、を備えている。周辺回路78には、内部の動作を規定するクロック信号を生成する回路や電源回路、リセット回路等が含まれる。また、制御装置70は、車両VC1の走行中に記憶したデータ等の書き換えが不能な読込専用メモリ74と、車両VC1の走行中に記憶したデータ等を電気的に書き換え可能な不揮発性メモリ76と、を記憶装置として備えている。これらCPU72、読込専用メモリ74、不揮発性メモリ76、及び周辺回路78は、ローカルネットワーク79を介して通信可能とされている。
【0019】
読込専用メモリ74には、内燃機関10の制御用の制御プログラム74aが記憶されている。制御プログラム74aには、内燃機関10の各操作部の操作用のプログラムである第1操作プログラム74bと第2操作プログラム74cとの2つのプログラムが含まれている。また、読込専用メモリ74には、第1操作プログラム74bによる内燃機関10の各操作部の操作に用いられる複数の適合済みデータDSが記憶されている。一方、不揮発性メモリ76には、内燃機関10の状態を含む車両VC1の状態を示す状態変数と操作量との関係を規定するデータであり、第2操作プログラム74cによる内燃機関10の各操作部の操作に用いられる関係規定データDRが記憶されている。そして、読込専用メモリ74には、関係規定データDRを更新するための強化学習処理用のプログラムである学習プログラム74dが記憶されている。さらに、読込専用メモリ74には、状態変数の値の時系列データDTSを不揮発性メモリ76に記録するためのプログラムである記録処理プログラム74eが記憶されている。
【0020】
適合済みデータDSには、内燃機関10の各操作部の操作量の演算に用いられる各種のマップデータが含まれる。マップデータは、入力変数の離散的な値と、入力変数のそれぞれの値に対する出力変数の値と、の組データである。マップデータには、要求トルク演算用のマップデータDS1、開口度演算用のマップデータDS2、基本点火時期演算用のマップデータDS3、限界遅角点火時期演算用のマップデータDS4等が含まれる。要求トルク演算用のマップデータDS1は、アクセル操作量PAと車速Vとを入力変数とするとともに内燃機関10のトルクの要求値である要求トルクTor*を出力変数とするマップデータである。開口度演算用のマップデータDS2は、内燃機関10のトルクを入力変数とするとともに、そのトルクの発生に必要なスロットル開口度TAの値を出力変数とするマップデータである。基本点火時期演算用のマップデータDS3は、機関回転数NE及び吸気量KLを入力変数とするとともに基本点火時期Abseを出力変数とするマップデータである。基本点火時期Abseは、内燃機関10のトルクが最大となる点火時期である最適点火時期と、ノッキングを抑制し得る点火時期の進角限界であるトレースノック点火時期と、の2つの時期のうち、より遅角側の時期である。限界遅角点火時期演算用のマップデータDS4は、機関回転数NEと吸気量KLとを入力変数とするとともに限界遅角点火時期Akmfを出力変数とするマップデータである。限界遅角点火時期Akmfは、燃焼室24での混合気の燃焼が悪化しない点火時期の遅角限界である。
【0021】
また、適合済みデータDSには、吸気量演算用のモデルデータDS5が含まれる。モデルデータDS5は、燃焼室24に流入する吸気量KLの演算に用いられる内燃機関10の吸気挙動の物理モデルのデータであり、吸入空気量Ga、吸気温THA、吸気圧Pm、スロットル開口度TA、機関回転数NE等の入力に応じて吸気量KLを出力するものとなっている。
【0022】
これらマップデータDS1~DS4及びモデルデータDS5は、これらを用いて演算される操作量が、内燃機関10の排気性状、燃料消費率、運転者の快適性などの要件を満たす値となるように予め適合されている。そして、マップデータDS1~DS4及びモデルデータDS5は、車両VC1の出荷前に読込専用メモリ74に予め書き込まれており、整備施設などに設置された専用の設備を用いてのみ更新可能とされている。すなわち、適合済みデータDSは、車両VC1の走行中には更新されないデータとなっている。
【0023】
図2に、本実施形態に係る制御装置70が実行する内燃機関10の各操作部の操作に係る処理の手順を示す。図2に示す処理は、読込専用メモリ74に記憶された制御プログラム74aをCPU72が既定の制御周期毎に繰り返し実行することにより実現される。なお、以下では、先頭に「S」が付与された数字によって各処理のステップ番号を示す。本実施形態では、図2の処理を通じて、車両VC1が手動アクセル走行を行っているか、自動アクセル走行を行っているかにより、第1操作処理により操作部の操作を実行するか、第2操作処理により操作部の操作を実行するかを切り替える切替処理が行われる。
【0024】
図2に示す一連の処理が開始されると、CPU72はまずステップS200において、モード変数MVの値を取得する。続いてCPU72は、ステップS210において、モード変数MVの値が示す車両VC1の走行モードが自動アクセル走行であるか否かを判定する。
【0025】
このときの車両VC1の走行モードが自動アクセル走行でない場合(S210:NO)、すなわち手動アクセル走行である場合には、CPU72は、ステップS220において、第2操作プログラム74cの実行を通じて内燃機関10の各操作部を操作する第2操作処理を実行する。また、CPU72は、続くステップS230において、学習プログラム74dの実行を通じて関係規定データDRを更新するための強化学習処理を実行する。さらに、CPU72は、続くステップS240において、記録処理プログラム74eの実行を通じて記録処理を実行する。そして、CPU72は、次のステップS250においてフラグFLをクリアした後、図2に示す一連の処理を一旦終了する。なお、フラグFLは、第2操作処理から第1操作処理への切り替えに際して、後述する切り替え時処理が完了しているか否かを示すフラグである。
【0026】
一方、車両VC1の走行モードが自動アクセル走行である場合(S210:YES)には、CPU72はステップS260において、上記フラグFLがセットされているか否かを判定する。そして、CPU72は、フラグFLがセットされている場合(S260:YES)にはステップS270に処理を進め、そのステップS270において、第1操作プログラム74bの実行を通じて内燃機関10の各操作部を操作する第1操作処理を実行した後、図2に示す一連の処理を一旦終了する。これに対してCPU72は、フラグFLがクリアされている場合(S260:NO)にはステップS280に処理を進め、そのステップS280において後述の切替時処理を実行する。また、この場合のCPU72は、続くステップS290においてフラグFLをセットした後、図2に示す一連の処理を一旦終了する。
【0027】
図2に示す一連の処理では、手動アクセル走行中は、第2操作処理による内燃機関10の操作部の操作、強化学習処理による関係規定データDRの更新、及び記録処理による時系列データDTSの記録が行われる。また、このときのフラグFLは、クリアされた状態に保持される。車両VC1の走行モードが手動アクセル走行から自動アクセル走行に切り替わると、その切り替え後の最初の制御周期には、切替時処理が実行されるとともに、フラグFLがセットされる。その後、自動アクセル走行が続く間は、第1操作処理による内燃機関10の操作部の操作が行われるが、その間、フラグFLはセットされた状態に保持される。よって、切替時処理は、手動アクセル走行から自動アクセル走行への切り替え時に実行される処理となっている。
【0028】
続いて、第1操作処理における内燃機関10の各操作部の操作について説明する。第1操作処理では、読込専用メモリ74に予め記憶された適合済みデータDSを用いてそれぞれ演算された操作量に基づき、内燃機関10の各操作部の操作が行われる。ここでは、内燃機関10の操作部のうちのスロットルバルブ14、燃料噴射弁16、及び点火装置26についての第1操作処理における操作について説明する。
【0029】
図3に、第1操作処理におけるスロットルバルブ14の操作に係るCPU72の処理手順を示す。図3に示されるように、第1操作処理におけるスロットルバルブ14の操作に際してはまず、アクセル操作量PA及び車速Vを入力としたマップデータDS1の出力が、要求トルクTor*の値として演算される。なお、本実施形態の場合、第1操作処理は、自動アクセル走行モードにおいて実行される。そのため、ここでのアクセル操作量PAには、運転者の実際のアクセルペダルの操作量ではなく、車速Vを設定速度に保持するために必要な車両VC1の加減速の要求量をアクセルペダルの操作量に換算した仮想的なアクセル操作量PAが用いられる。
【0030】
続いて、要求トルクTor*に緩変化処理を施した値が要求トルク緩変化値Torsm*として演算される。緩変化処理は、要求トルクTor*を入力とし、その要求トルクTor*に対して遅れを有して追従する値を要求トルク緩変化値Torsm*の値として出力するフィルタ処理である。本実施形態では、要求トルクTor*の修正移動平均値を要求トルク緩変化値Torsm*の値として出力するフィルタ処理を緩変化処理として採用している。具体的には、式(1)の関係を満たすように要求トルク緩変化値Torsm*の値を更新することで、その演算を行っている。なお、式(1)における「n」は、2以上の整数として予め設定された定数である。こうした緩変化処理により、スロットル開口度TAの急激な変化により、機関回転数NEが急変して運転者の快適性が損なわれたり、吸気の応答遅れにより排気性状が悪化したり、することが抑えられる。
【0031】
【数1】
さらに、要求トルク緩変化値Torsm*を入力としたマップデータDS2の出力が、スロットル開口度TAの指令値である開口度指令値TA*の値として演算される。そして、信号出力処理により、開口度指令値TA*へのスロットル開口度TAの変更を指令する指令信号MS1がスロットルバルブ14に出力される。
【0032】
図4に、第1操作処理における燃料噴射弁16の操作に係るCPU72の処理手順を示す。図4に示されるように、第1操作処理における燃料噴射弁16の操作に際してはまず、吸入空気量Ga、吸気温THA、吸気圧Pm、スロットル開口度TA、機関回転数NE等を入力としたモデルデータDS5の出力が吸気量KLの値として演算される。そして、燃焼室24で燃焼する混合気の空燃比の目標値である目標空燃比AF*により吸気量KLを割った商が基本噴射量Qbの値として演算される。
【0033】
また、目標空燃比AF*に対する空燃比AFの検出値の偏差に応じて空燃比フィードバック補正値FAFが演算される。空燃比フィードバック補正値FAFの演算は、PID処理により行われる。すなわち、目標空燃比AF*に対する空燃比AFの検出値の偏差に既定の比例ゲインを乗算した積である比例項、同偏差の時間積分値に既定の積分ゲインを乗算した積である積分項、及び同偏差の時間微分値に既定の微分ゲインを乗算した積である微分項をそれぞれ演算する。そして、それら比例項、積分項、及び微分項を足し合わせた和を空燃比フィードバック補正値FAFの値として演算する。
【0034】
また、第1操作処理による燃料噴射弁16の操作に際しては、空燃比学習値KGの学習処理が行われる。空燃比学習値KGの学習処理は、機関回転数NEや吸気量KLが安定した内燃機関10の定常運転時における空燃比フィードバック補正値FAFの値に基づいて次の(イ)~(ハ)の態様で空燃比学習値KGの値を更新することで行われる。(イ)空燃比フィードバック補正値FAFの絶対値が既定の更新判定値未満の場合には、空燃比学習値KGの値を保持する。(ロ)空燃比フィードバック補正値FAFが正の値であり、かつその絶対値が既定の更新判定値以上の場合には、更新前の値から既定の更新量を引いた差を更新後の値とするように空燃比学習値KGの値を更新する。(ハ)空燃比フィードバック補正値FAFが負の値であり、かつその絶対値が更新判定値以上の場合には、更新前の値に上記更新量を足した和を更新後の値とするように空燃比学習値KGの値を更新する。
【0035】
さらに、基本噴射量Qb、空燃比フィードバック補正値FAF、及び空燃比学習値KGを足し合わせた和が噴射量指令値Qiの値として演算される。そして、信号出力処理により、噴射量指令値Qiの演算値に応じた量の燃料噴射を指令する指令信号MS2が燃料噴射弁16に出力される。
【0036】
図5に、第1操作処理における点火装置26の操作に係るCPU72の処理手順を示す。第1操作処理における点火装置26の操作に際してはまず、機関回転数NE及び吸気量KLを入力としたマップデータDS3の出力が基本点火時期Abseの値として演算される。また、機関回転数NE及び吸気量KLを入力としたマップデータDS4の出力が限界遅角点火時期Akmfの値として演算される。そして、基本点火時期Abseから限界遅角点火時期Akmfを引いた差が限界遅角量Akmaxの値として演算される。
【0037】
また、第1操作処理における点火装置26の操作に際しては、ノック信号Knkに基づくノック制御量Akcsの演算処理が行われる。ノック制御量Akcsの演算は、下記(ニ)、(ホ)の態様でノック制御量Akcsの値を更新することで行われる。(ニ)ノック信号Knkがノッキングの発生を示す値である場合には、更新前の値に既定のノック遅角量を加えた和を更新後の値とするようにノック制御量Akcsの値を更新する。(ホ)ノック信号Knkがノッキングの発生がないことを示す値である場合には、更新前の値から既定のノック進角量を引いた差を更新後の値とするようにノック制御量Akcsの値を更新する。なお、ノック遅角量には正の値が、ノック進角量にはノック遅角量よりも大きい値が、それぞれ設定されている。
【0038】
そして、限界遅角量Akmaxにノック制御量Akcsを加えた和が点火時期遅角量Aknkの値として演算され、さらに基本点火時期Abseから点火時期遅角量Aknkを引いた差が点火時期指令値Aopの値として演算される。そして、信号出力処理により、点火時期指令値Aopの演算値に対応した時期の点火の実行を指令する指令信号MS3が点火装置26に出力される。
【0039】
続いて、第2操作処理における内燃機関10の各操作部の操作について説明する。第2操作処理では、不揮発性メモリ76に記憶された関係規定データDRと車両VC1の状態とにより定まる操作量に応じて内燃機関10の各操作部の操作が行われる。上述のように、CPU72は、第2操作処理と並行して、強化学習処理を実行する。強化学習処理は、CPU72が読込専用メモリ74に記憶された学習プログラム74dを読み込んで実行することで実現される。
【0040】
なお、本実施形態における関係規定データDRは、行動価値関数Q、及び方策πを定めるデータとされている。行動価値関数Qは、状態s及び行動aの各独立変数に応じた期待収益の値を示すテーブル形式の関数である。本実施形態では、状態sを、機関回転数NE、吸気量KL、吸入空気量Ga、吸気温THA、吸気圧Pm、空燃比AF、アクセル操作量PA、及び車速Vの8つの変数としている。また、本実施形態では、行動aを、内燃機関10の操作部の操作量である開口度指令値TA*、噴射量指令値Qi、及び点火時期指令値Aopの3つの変数としている。すなわち、状態sは8次元のベクトルであり、行動aは3次元のベクトルである。また、本実施形態に係る行動価値関数Q(s,a)は、テーブル形式の関数とされている。
【0041】
図6に、第2操作処理、及び強化学習処理の両処理に係るCPU72の処理手順を示す。CPU72は、図2のステップS220における第2操作処理の実行毎に、図6に示す一連の処理を実行する。なお、本実施形態では、図6のS510~S530が第2操作処理に、図6のS540~S590が強化学習処理に、それぞれ該当する。
【0042】
図6に示す一連の処理が開始されると、まずS500において、「t」の値が「0」にリセットされる。続いてステップS510において、車両VC1の最新の状態sが読み込まれ、その読み込まれた状態sの各変数の値が状態s[t]の各変数の値として代入される。次に、ステップS520において、関係規定データDRに規定された方策π[t]に従って、行動a[t]が選択される。ここでの行動a[t]は、状態s[t]に対して選択された行動aであることを意味する。また、方策π[t]は、状態s[t]において、行動価値関数Q(s[t],a)を最大化する行動aを、すなわちグリーディな行動を選択する確率を最大としつつも、それ以外の行動aの選択確率も「0」としないものとなっている。このようにグリーディな行動を採用しない場合があることで、最適な行動を探るための探索を可能としている。こうした方策πは、εグリーディ行動選択手法や、ソフトマックス行動選択手法によって実現できる。そして、続くステップS530において、行動a[t]として選択された開口度指令値TA*、噴射量指令値Qi、及び点火時期指令値Aopに応じて、スロットルバルブ14、燃料噴射弁16、及び点火装置26のそれぞれに操作信号MS1~MS3が出力される。
【0043】
その後、ステップS540及びステップS550において、報酬r[t]が算出される。報酬r[t]の算出に際しては、まずステップS540において、上記行動a[t]に応じた操作部の操作後の最新の状態sが読み込まれ、その読み込まれた状態sの各変数の値が状態s[t+1]の各変数の値として設定される。そして、ステップS550において、状態s[t+1]に基づき、行動a[t]による報酬r[t]が算出される。報酬r[t]は、目標空燃比AF*に対する空燃比AFの偏差の積算値等から求められた内燃機関10の排気特性に関する報酬、噴射量指令値Qiの積算値等から求められた内燃機関10の燃料消費率に関する報酬、加速度Gxの積算値等から求められた運転者の快適性に関する報酬など、観点の異なる複数の報酬の和として算出される。
【0044】
続いてステップS560において、行動価値関数Qのうち、状態s[t]、行動a[t]の場合の行動価値関数Q(s[t],a[t])の値を更新する更新量を算出するための誤差δ[t]が算出される。本実施形態では、方策オフ型TD法を用いて誤差δ[t]を算出している。すなわち、割引率γを用いて、誤差δ[t]を、行動価値関数Q(s[t+1],A)のうちの最大値に割引率γを乗算した値、及び報酬r[t]の和から行動価値関数Q(s[t],a[t])を減算した値とする。なお、「A」は、行動aの集合を意味する。次に、ステップS570において、誤差δ[t]に学習率αを乗算した積を行動価値関数Q(s[t],a[t])に加算することによって、行動価値関数Q(s[t],a[t])が更新される。すなわち、関係規定データDRによって規定されている行動価値関数Q(s,a)のうち、独立変数が状態s[t]及び行動a[t]となるものの値を、「α・δ[t]」だけ変化させる。これらステップS560及びステップS570の処理により、報酬r[t]の期待収益を増加させるように関係規定データDRが更新される。これは、行動価値関数Q(s[t],a[t])が更新されることによって、行動価値関数Q(s[t],a[t])が実際の期待収益をより高精度に表現する値に更新されるためである。
【0045】
続くステップS580では、各独立変数について行動価値関数Qの値が収束したか否かが判定される。収束していないと判定された場合(NO)には、ステップS590において、「t」の値が「1」加増された後、ステップS510に処理が戻される。これに対して、行動価値関数Qの値が収束したと判定された場合(S580:YES)には、図6に示す一連の処理が一旦終了される。
【0046】
続いて、図7を参照して、図2に示す一連の処理のステップS240においてCPU72が実行する記録処理について説明する。記録処理は、第2操作処理による操作部の操作中に第1操作処理での操作量の演算に使用される状態変数の値を取得するとともに、取得した同状態変数の値の時系列データを記憶装置である不揮発性メモリ76に記録する処理である。
【0047】
図7に示す一連の処理においてCPU72はまずステップS700において、要求トルクTor*、第2操作処理による噴射量指令値Qiの演算値、吸気量KL、及び第1操作処理での燃料噴射弁16の操作に際して演算された空燃比学習値KGのそれぞれの値を取得する。なお、以下の説明では、第2操作処理による噴射量指令値Qiの演算値を「Qi2」と記載する。
【0048】
続いて、CPU72はステップS710において、吸気量KLを目標空燃比AF*で除算した商に空燃比学習値KGを加えた和を、仮想噴射量vQi1の値として演算する。上述のように第1噴射処理では、基本噴射量Qb、空燃比フィードバック補正値FAF、及び空燃比学習値KGを足し合わせた和を噴射量指令値Qiの値として演算している。仮想噴射量vQi1の値は、こうした第1操作処理における噴射量指令値Qiの演算値から空燃比フィードバック補正値FAFを引いた差、すなわち空燃比フィードバック補正値FAFを0とした場合の第1操作処理における噴射量指令値Qiの演算値を示す。
【0049】
続くステップS720においてCPU72は、Qi2をvQi1で割った商に目標空燃比AF*を掛けた積を仮想空燃比vAFの値として演算する。上述のように第2操作処理では、強化学習による操作量の適合が行われており、その強化学習の報酬rには、目標空燃比AF*に対する空燃比AFの偏差の積算値等から求められた内燃機関10の排気特性に関する報酬が含まれている。こうした強化学習による操作量の適合が十分に進んでいれば、第2操作処理による噴射量指令値Qiの演算値であるQi2は、空燃比AFを目標空燃比AF*とする値となっている筈である。一方、空燃比AFは、燃焼室24で燃焼する混合気の空気の質量を燃料の質量で割った商である。よって、Qi2が空燃比AFを目標空燃比AF*とする噴射量指令値Qiであるとすれば、所定の値Qxを噴射量指令値Qiの値として燃料噴射弁16を操作したときの空燃比AFは、Qi2をQxで割った商に目標空燃比AF*を乗算した積(=AF*×Qi2/Qx)となる。よって、仮想空燃比vAFは、第2操作処理により燃料噴射弁16を操作している現状において、仮想噴射量vQi1を噴射量指令値Qiとして燃料噴射弁16を操作すると仮定した場合の空燃比AFの想定値を表すことになる。
【0050】
続いてCPU72は、ステップS730において、不揮発性メモリ76に記録されている要求トルクTor*及び仮想空燃比vAFの時系列データDTSをそれぞれ更新した後、図7に示す一連の処理を終了する。なお、本実施形態では、n回前の制御周期から今回の制御周期までのそれぞれの周期で取得したn個の要求トルクTor*の値からなるデータを、要求トルクTor*の時系列データとして記録している。また、本実施形態では、m回前の制御周期から今回の制御周期までのそれぞれの周期で演算されたm個の仮想空燃比vAFの値からなるデータを、仮想空燃比vAFの時系列データとして記録している。なお、「m」は2以上の整数である。
【0051】
続いて、図8を参照して切替時処理の詳細を説明する。上述のように切替時処理は、手動アクセル走行から自動アクセル走行への切り替え時に実行される処理となっている。
図8に示す一連の処理が開始されると、CPU72はまずステップS800において、不揮発性メモリ76に記録された要求トルクTor*、及び仮想空燃比vAFの時系列データを取得する。そして、CPU72は、続くステップS810において、取得した要求トルクTor*の時系列データに基づき、要求トルク緩変化値Torsm*を演算する。本実施形態では、要求トルクTor*の時系列データに含まれるn個の要求トルクTor*の値の平均値を要求トルク緩変化値Torsm*の値として演算している。さらにCPU72はステップS820において、演算した要求トルク緩変化値Torsm*に基づいて開口度指令値TA*を演算する。具体的には、このときのCPU72は、要求トルク緩変化値Torsm*を入力値としたマップデータDS2の出力値を開口度指令値TA*の値として演算している。
【0052】
また、CPU72は次のステップS830において、仮想空燃比vAFの時系列データから空燃比フィードバック補正値FAFを演算する。本実施形態では、下記の態様で、ここでの空燃比フィードバック補正値FAFの演算を行っている。すなわち、ここでの空燃比フィードバック補正値FAFの演算に際してはまず、時系列データに含まれる各仮想空燃比vAFの移動平均値が求められる。続いて、現在の吸気量KLをその移動平均値で割った商が、空燃比AFを目標空燃比AF*とするために必要な噴射量指令値Qiの値、「Qf」として演算される。また、現在の吸気量KLを目標空燃比AF*で割った商が基本噴射量Qbの値として演算される。そして、基本噴射量Qbと空燃比学習値KGとの和を「Qf」から引いた差が空燃比フィードバック補正値FAFの値として演算される。すなわち、ここでは、仮想空燃比vAFの時系列データから求められた「Qf」が空燃比AFを目標空燃比AF*とする噴射量指令値Qiの値であるとして、空燃比フィードバック補正値FAFの値を演算している。そして、CPU72は、続くステップS840において、基本噴射量Qb、空燃比フィードバック補正値FAF、及び空燃比学習値KGの和を噴射量指令値Qiの値として演算する。
【0053】
続いて、CPU72は、ステップS850において、点火時期指令値Aopを含む内燃機関10の他の操作部の操作量を演算する。ここでの操作量の演算は、第1操作処理と同じ態様で行われる。そして、CPU72は続くステップS860において、演算した各操作量に応じて内燃機関10の各操作部の操作を実行した後、図8に示す一連の処理を終了する。
【0054】
こうした切替時処理では、次の2点を除いては、第1操作処理と同じ態様で内燃機関10の操作部の操作が実行される。すなわち、開口度指令値TA*の演算に用いる要求トルク緩変化値Torsm*を要求トルクTor*の時系列データに基づき演算すること、及び噴射量指令値Qiの演算に用いる空燃比フィードバック補正値FAFを仮想空燃比vAFの時系列データに基づき演算すること、の2点が第1操作処理と切替時処理との相違点である。
【0055】
本実施形態の作用及び効果について説明する。
本実施形態における制御装置70は、第1操作処理と第2操作処理との2つの操作処理からいずれかの処理を選択して内燃機関10の操作部の操作を行う。第1操作処理では、読込専用メモリ74に予め記憶された適合済みデータDSを用いて演算した操作量により操作部を操作する。こうした第1操作処理での操作量の演算に用いる適合済みデータDSは、車両VC1の出荷前に予め適合を済ませておく必要がある。一方、第2操作処理では、不揮発性メモリ76に記憶された関係規定データDRと車両VC1の状態とにより定まる操作量にて操作部を操作する。そして、第2操作処理の実行中は、同第2操作処理による操作部の操作の結果として変化する車両VC1の状態から報酬rが算出されるとともに、その報酬rの期待収益が増加するように関係規定データDRが更新される。すなわち、第2操作処理による内燃機関10の操作部の操作時には、強化学習による操作量の適合が進められる。このように車両VC1の走行中に強化学習による操作量の適合を行えば、車両出荷前の熟練者による操作量の適合に係る工数を低減できる。しかしながら、車両走行中の強化学習による操作量の適合は、制御装置70の演算負荷の増大を伴うものとなっている。このように車両走行中の強化学習による操作量の適合には、熟練者による操作量の適合に係る工数を低減できるというメリットがある一方で、制御装置70の演算負荷を増加させるというデメリットが存在する。また、強化学習による操作量の適合の完了にはある程度の時間を要するため、適合が完了するまでは内燃機関10の制御性が悪化する虞もある。
【0056】
本実施形態の制御装置70が適用される内燃機関10が搭載された車両VC1は、運転者のアクセルペダル操作に応じて車両VC1の加減速を行う手動アクセル走行と、アクセルペダル操作に基づかずに車両VC1の加減速を自動で行う自動アクセル走行と、を行うものとなっている。手動アクセル走行時と自動アクセル走行時とでは、車両VC1が取り得る状態に違いがあるため、操作量の適合もそれぞれ個別に行う必要がある。なお、車両VC1での自動アクセル走行は、自動車専用道路の走行中に運転者が自動アクセル走行を選択した場合に限り実施される。そのため、自動アクセル走行は、手動アクセル走行に比べて低い頻度でしか実施されない可能性が高く、自動アクセル走行時の操作量の適合を強化学習で行うとすると、その適合が未完了の状態が長く続く虞がある。
【0057】
そこで本実施形態では、想定される実施頻度の高い手動アクセル走行については、車両走行中の強化学習により操作量の適合を行う一方で、想定される実施頻度の低い自動アクセル走行については従来手法により操作量の適合を行うようにしている。こうした本実施形態では、自動アクセル走行については従来手法により操作量を適合する必要があるが、手動アクセル走行、自動アクセル走行の双方について従来手法により操作量を適合する場合に比べてば、熟練者の適合に係る工数は少なくて済む。
【0058】
ところで、上述のように、第1操作処理によるスロットルバルブ14の開口度指令値TA*の演算に際しては、要求トルクTor*を入力とするとともにその要求トルクTor*の変化に対して遅れを有して追従する値を要求トルク緩変化値Torsm*として出力する緩変化処理が行われる。そして、要求トルク緩変化値Torsm*を入力としたマップデータDS2の出力が開口度指令値TA*の値として演算されている。なお、以下の説明では、第1操作処理による開口度指令値TA*の演算値を「TA*[1]」と記載する一方、第2操作処理による開口度指令値TA*の演算値を「TA*[2]」と記載する。
【0059】
図9(a)には要求トルクTor*が急減したときの要求トルクTor*が二点鎖線で、そのときの要求トルク緩変化値Torsm*の推移が実線で、それぞれ示されている。また、図9(b)にはそのときの演算値TA*[1]の推移が実線で示されている。このように、演算値TA*[1]は、要求トルクTor*の変化に対して遅れを有して変化する値として演算されている。第1操作処理では、緩変化処理により、吸気の応答遅れによる内燃機関10の排気性状の悪化や機関回転数NEの急変による運転者の快適性の低下を抑制している。
【0060】
一方、上述のように第2操作処理では、車両VC1の状態sを入力とした関係規定データDRの出力として内燃機関10の各操作部の操作量が演算されている。また、第2操作処理の操作量の適合は、内燃機関10の排気性状や運転者の快適性の観点から算出された報酬rに基づく強化学習により行われている。こうした強化学習による適合が適切になされれば、第2操作処理による開口度指令値TA*の演算値TA*[2]も、第1操作処理の演算値TA*[1]と同様に、要求トルクTor*の変化に対して遅れを有して変化する値となるように演算される。なお、以下の説明では、要求トルクTor*の変更に応じて開口度指令値TA*の値が変化し始めた時点から、変更後の要求トルクTor*に応じた値に開口度指令値TA*が収束する時点までの開口度指令値TA*が変化している期間を過渡期間と記載する。
【0061】
ここで、図9に示される過渡期間中の時刻t1に、第2操作処理から第1操作処理への操作部の操作の切り替えを実施するとともに、その切り替えと同時に第1操作処理による開口度指令値TA*の演算も開始する場合を考える。図9には、この場合の要求トルク緩変化値Torsm*及び開口度指令値TA*の推移がそれぞれ点線で示されている。なお、この場合には、時刻t1以前は第2操作処理の演算値TA*[2]が、時刻t1以降は第1操作処理の演算値TA*[1]が、それぞれスロットルバルブ14の操作に用いられる。この場合には、緩変化処理も時刻t1に開始されるため、演算値TA*[1]には、時刻t1以前の要求トルクTor*の推移は反映されなくなる。そのため、第2操作処理から第1操作処理への切り替え前後で開口度指令値TA*に段差が生じてしまい、内燃機関10の制御性が悪化する。
【0062】
これに対して本実施形態では、CPU72は、記録処理において、第2操作処理による内燃機関10の操作部の操作中の要求トルクTor*の値を取得するとともに、その取得した要求トルクTor*の値の時系列データを不揮発性メモリ76に記録している。そして、CPU72は、第2操作処理から第1操作処理への切り替えに際して実行される切替時処理において、記録した要求トルクTor*の時系列データから要求トルク緩変化値Torsm*を演算している。このときの要求トルク緩変化値Torsm*は、第1操作処理への切り替えがなされる前の第2操作処理による操作中の要求トルクTor*に対して遅れを有して追従する値となる。そしてCPU72は、切替時処理において、要求トルクTor*の時系列データから演算した要求トルク緩変化値Torsm*に基づいて開口度指令値TA*を演算している。そのため、第2操作処理から第1操作処理への切り替え前後で開口度指令値TA*に段差が生じにくくなる。
【0063】
さらに、第1操作処理では、空燃比フィードバック補正値FAFによる噴射量指令値Qiの補正、すなわち空燃比フィードバック補正が行われている。そして、こうした空燃比フィードバック補正により、燃料噴射弁16の噴射特性や内燃機関10の吸気特性等の個体差や経時変化による目標空燃比AF*に対する空燃比AFのずれを補償している。こうした空燃比フィードバック補正による目標空燃比AF*への空燃比AFの収束にはある程度の時間を要する。そのため、第2操作処理から第1操作処理への切り替えと共に、空燃比フィードバック補正値FAFが「0」の状態から空燃比フィードバック補正を開始すれば、一時的に空燃比AFが目標空燃比AF*から乖離して内燃機関10の排気性状が悪化する虞がある。
【0064】
これに対して本実施形態では、第2操作処理による内燃機関10の操作部の操作中に、CPU72は記録処理において、第1操作処理での空燃比フィードバック補正値FAFの演算に使用する空燃比AFの仮想値である仮想空燃比vAFの値を取得するとともに、その時系列データを不揮発性メモリ76に記録している。こうして時系列データを記録する仮想空燃比vAFの値からは、空燃比AFを目標空燃比AF*とする空燃比フィードバック補正値FAFの値を求められる。そこで、CPU72は、第2操作処理から第1操作処理への切り替えに際して実行される切替時処理において、記録した仮想空燃比vAFの時系列データから空燃比フィードバック補正値FAFを演算するとともに、その空燃比フィードバック補正値FAFに応じて噴射量指令値Qiを演算して燃料噴射弁16を操作している。そのため、第1操作処理による操作の開始時から、空燃比AFを目標空燃比AF*とする値が空燃比フィードバック補正値FAFの値として設定されることになり、第1操作処理による燃料噴射弁16の操作の開始直後の目標空燃比AF*からの空燃比AFの乖離が抑えられる。
【0065】
以上の本実施形態によれば、以下の効果を奏することができる。
(1)上記実施形態では、想定される実施の頻度が高い手動アクセル走行における内燃機関10の操作部の操作量の適合は車両走行中の強化学習により行っている。一方、想定される実施の頻度が低く、車両走行中の強化学習の実施機会が限られると考えられる自動アクセル走行における操作部の適合については従来手法で行っている。よって、手動アクセル走行、自動アクセル走行の双方における操作量の適合を各々に適した手法で実施でき、かつ熟練者の適合に係る工数を低減できる。
【0066】
(2)手動アクセル走行時の操作量の適合が、車両走行中の強化学習を通じて行われる。そのため、手動アクセル走行時における内燃機関10の操作部の操作量の適合結果に内燃機関10の個体差や経時変化が反映され、そうした個体差や経時変化に起因した内燃機関10の制御性の悪化が抑えられる。
【0067】
(3)上記実施形態におけるCPU72は、記録処理において、第2操作処理による内燃機関10の操作部の操作中に、第1操作処理での開口度指令値TA*の演算に使用される要求トルクTor*の値を取得するとともに、取得した要求トルクTor*の値の時系列データを不揮発性メモリ76に記録している。この記録した要求トルクTor*の時系列データを用いることで、第2操作処理による操作を終了して第1操作処理を開始する際の開口度指令値TA*を、第1操作処理の開始前の要求トルクTor*の変化を反映した値として演算できる。そのため、第2操作処理から第1操作処理への切り替え前後の開口度指令値TA*の値に段差が生じにくくなる。
【0068】
(4)上記実施形態におけるCPU72は、記録処理において、第2操作処理による内燃機関10の操作部の操作中に、第1操作処理での空燃比フィードバック補正値FAFの演算に用いられる空燃比AFの仮想値である仮想空燃比vAFを取得するとともに、取得した仮想空燃比vAFの値の時系列データを不揮発性メモリ76に記録している。この記録した仮想空燃比vAFの時系列データを用いることで、第2操作処理による操作を終了して第1操作処理を開始する際の空燃比AFを目標空燃比AF*とする空燃比フィードバック補正値FAFの値を求められる。そのため、第2操作処理から第1操作処理への切り替え直後に目標空燃比AF*からの空燃比AFの乖離が生じにくくなる。
【0069】
本実施形態は、以下のように変更して実施することができる。本実施形態及び以下の変更例は、技術的に矛盾しない範囲で互いに組み合わせて実施することができる。
・自動アクセル走行、手動アクセル走行について
上記実施形態における自動アクセル走行は、車速Vを設定速度に維持すべく、車両VC1の加減速を自動で行う走行モードとしていたが、走行中の道路や周辺の車両や歩行者などを検知してその検知結果に基づき車両VC1の加減速を自動で行う走行モードを自動アクセル走行として行うようにしてもよい。また、自動アクセル走行において、車両VC1の加減速に加えて車両VC1の操舵や制動の少なくとも一方を自動で行うようにしてもよい。また、手動アクセル走行において、車両VC1の加減速は運転者のアクセルペダル操作に応じて手動で行う一方で、車両VC1の操舵、制動の少なくとも一方は自動で行うようにしてもよい。
【0070】
・内燃機関の操作部について
スロットルバルブ14、燃料噴射弁16、及び点火装置26以外の操作部を、第1操作処理と第2操作処理との切り替えの対象とする内燃機関10の操作部としてもよい。例えば排気の一部を吸気中に再循環する排気再循環機構を備えるとともに排気の再循環量を調整するEGRバルブが同排気再循環機構に設けられた内燃機関の場合、EGRバルブを第1操作処理と第2操作処理との切替対象とする内燃機関の操作部としてもよい。また、吸気バルブ18や排気バルブ30の動弁特性を可変とする可変動弁機構を備える内燃機関の場合には、同可変動弁機構を第1操作処理と第2操作処理との切替対象とする内燃機関の操作部としてもよい。
【0071】
・切替処理について
上記実施形態では、自動アクセル走行中に第1操作処理を、手動アクセル走行中に第2操作処理をそれぞれ実行していた。主に自動アクセル走行を行い、限られた状況でのみ手動アクセル走行を行うように運用される車両などでは、車両走行中の強化学習による操作量の適合が、自動アクセル走行には適しているが、手動アクセル走行には不適となる場合がある。そうした場合、自動アクセル走行中に第2操作処理を、手動アクセル走行中に第1操作処理をそれぞれ実行するようにしてもよい。
【0072】
また、上記以外の車両VC1の状態に応じて操作処理の切り替えを行うようにしてもよい。内燃機関10の運転領域に、例えば高負荷高回転領域など、使用頻度の低い領域が存在する場合がある。使用頻度の低い運転領域では、他の運転領域に比べて、車両走行中の強化学習による操作量の適合が遅れる。そのため、使用頻度の低い運転領域では第1操作処理により、使用頻度が高い運転領域では第2操作処理により、それぞれ内燃機関10の操作部を操作することが考えられる。
【0073】
さらに、切替処理による第1操作処理、第2操作処理の切り替えの対象とする操作部を内燃機関の操作部の中の一部の操作部に限定し、残りの操作部については手動・自動のいずれのアクセル操作走行においても、第1又は第2のいずれかの操作処理で操作するようにしてもよい。
【0074】
・状態sについて
上記実施形態では、機関回転数NE、吸気量KL、吸入空気量Ga、吸気温THA、吸気圧Pm、空燃比AF、アクセル操作量PA、及び車速Vの8つの変数を状態sとしていたが、それらのうちの一つ以上を状態sから割愛したり、内燃機関10や車両VC1の状態を示すそれら以外の変数を状態sに加えたりしてもよい。
【0075】
・報酬rについて
状態sに基づく報酬rの算出を、上記実施形態とは異なる態様で行うようにしてもよい。例えば窒素酸化物や微粒子物質などの排気の有害成分の排出量を取得するとともにその排出量に基づき内燃機関10の排気特性に関する報酬を算出したり、車室の振動や騒音レベルを測定するとともにその測定結果に基づいて快適性に関する報酬を算出したり、してもよい。
【0076】
・行動価値関数Qについて
上記実施形態では、行動価値関数Qをテーブル形式の関数としていたが、これに限らない。例えば関数近似器を行動価値関数Qとして用いるようにしてもよい。また、行動価値関数Qを用いる代わりに、状態s及び行動aを独立変数とするとともに行動aを取る確率を従属変数とする関数近似器にて方策πを表現し、報酬rに応じてその方策πを更新するようにしてもよい。
【0077】
・関係規定データDRの更新について
上記実施形態では、方策オフ型TD法により関係規定データDRを更新していたが、例えばSARSA法のような方策オン型TD法により同更新を行うようにしてもよい。また、方策オン型の更新手法として、適格度トレース法を用いるようにしてもよい。さらに、モンテカルロ法などの上記以外の方法により、関係規定データDRの更新を行うことも可能である。
【0078】
・フィードバック補正処理について
上記実施形態における第1操作処理での燃料噴射弁16の噴射量指令値Qiの演算は、空燃比AFに応じたフィードバック補正処理を通じて行われていた。そして、記録処理において、そのフィードバック補正処理に用いる状態変数である空燃比AFの時系列データ、厳密には同空燃比AFの仮想値である仮想空燃比vAFの時系列データを記録していた。第1操作処理で演算する操作量の中に、噴射量指令値Qiの他にもフィードバック補正処理を通じて演算される操作量が存在する場合、そのフィードバック補正処理に用いられる状態変数も、記録処理での時系列データの記録の対象とする状態変数に含めるようにするとよい。
【0079】
ちなみに、ここでのフィードバック補正処理とは、次の処理である。すなわち、フィードバック補正処理とは、車両VC1の状態変数の一つを制御量として、同制御量の目標値と検出値との偏差に応じてフィードバック補正値を演算するとともに、適合済みデータDSを用いて演算された操作量の値を、そのフィードバック補正値により補正する処理である。
【0080】
・緩変化処理について
上記実施形態における第1操作処理でのスロットルバルブ14の開口度指令値TA*の演算は、緩変化処理を通じて行われていた。そして、記録処理において、緩変化処理の対象となる状態変数である要求トルクTor*の時系列データを記録していた。第1操作処理で演算する操作量の中に、開口度指令値TA*の他にも緩変化処理を通じて演算される操作量が存在する場合、その緩変化処理の対象となる状態変数を記録処理での時系列データの記録の対象とする状態変数に含めるようにするとよい。
【0081】
ちなみに、ここでの緩変化処理とは、次の処理である。緩変化処理での操作量の演算は、予め記憶装置に記憶されたデータであって、車両の状態変数に含まれる変数である状態変数を入力とするとともに操作量を出力とする写像を規定する適合済みのデータを用いて行われる。そして、緩変化処理は、次の2つの処理A、Bのいずれか一方の処理となっている。処理Aは、状態変数の検出値を入力とするとともに同検出値に対して遅れを有して変化する値を上記写像の入力値として出力する処理である。これに対して、処理Bは、上記写像の出力値を入力とするとともに同出力値に対して遅れを有して変化する値を操作量の演算値として出力する処理である。なお、上記実施形態でのスロットルバルブ14の開口度指令値TA*の演算に際しては、上記処理Aが緩変化処理として行われるが、上記処理Bを緩変化処理として行うことも可能である。
【0082】
図10には、処理Bを緩変化処理として行って開口度指令値TA*を演算する場合の第1操作処理におけるスロットルバルブ14の操作に係るCPU72の処理手順を示す。図10に示されるように、この場合の第1操作処理におけるスロットルバルブ14の操作に際してはまず、アクセル操作量PA及び車速Vを入力としたマップデータDS1の出力が、要求トルクTor*の値として演算される。続いて、要求トルクTor*を入力としたマップデータDS2の出力が開口度指令値TA*の値として演算される。さらに、開口度指令値TA*に緩変化処理を施した値が開口度緩変化指令値TAsm*として演算される。そして、信号出力処理により、開口度緩変化指令値TAsm*へのスロットル開口度TAの変更を指令する指令信号MS1がスロットルバルブ14に出力される。
【0083】
こうした場合にも、要求トルクTor*の時系列データを用いることで、第1操作処理の開始時の開口度指令値TA*を、直近の要求トルクTor*の変化に対して遅れを有して変化する値として演算できる。すなわち、要求トルクTor*の時系列データ、及び要求トルクTor*の現在値から同要求トルクTor*の緩変化値を求める。そして、その緩変化値を入力としたマップデータDS2の出力を開口度指令値TA*として演算して、その開口度指令値TA*に応じてスロットルバルブ14を操作する。
【0084】
・記録処理について
上記実施形態では、記録処理において、第1操作処理での開口度指令値TA*及び噴射量指令値Qiの両操作量の演算にそれぞれ用いる要求トルクTor*、仮想空燃比vAFの2つの状態変数の値の時系列データを記録していた。第1操作処理での他の操作量の演算に用いる状態変数の値の時系列データを記録処理において記録するようにしてもよい。また、記録処理において、第1操作処理での操作量の演算に使用する全ての状態変数の時系列データを記録するようにしてもよい。
【符号の説明】
【0085】
10…内燃機関
12…吸気通路
14…スロットルバルブ
16…燃料噴射弁
18…吸気バルブ
20…シリンダ
22…ピストン
24…燃焼室
26…点火装置
28…クランク軸
30…排気バルブ
32…排気通路
34…触媒
70…制御装置
72…CPU
74…読込専用メモリ
74a…制御プログラム
74b…第1操作プログラム
74c…第2操作プログラム
76…不揮発性メモリ
78…周辺回路
79…ローカルネットワーク
80…エアフローメータ
82…スロットルセンサ
84…クランク角センサ
86…空燃比センサ
87…アクセルペダル
88…アクセルセンサ
90…加速度センサ
DR…関係規定データ
DS…適合済みデータ
DTS…時系列データ
VC1…車両
図1
図2
図3
図4
図5
図6
図7
図8
図9
図10