JP2017118184A - 電子制御装置 - Google Patents
電子制御装置 Download PDFInfo
- Publication number
- JP2017118184A JP2017118184A JP2015248699A JP2015248699A JP2017118184A JP 2017118184 A JP2017118184 A JP 2017118184A JP 2015248699 A JP2015248699 A JP 2015248699A JP 2015248699 A JP2015248699 A JP 2015248699A JP 2017118184 A JP2017118184 A JP 2017118184A
- Authority
- JP
- Japan
- Prior art keywords
- data
- noise
- unit
- electronic control
- control device
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Landscapes
- Dc Digital Transmission (AREA)
Abstract
【課題】各データフィールドの送受信中に発生するノイズによるビット化けの影響を回避することができる電子制御装置を提供する。【解決手段】通信ラインを介して他の機器とデータの送受信を行う電子制御装置は、前記通信ラインを介してデータの送受信を行う通信機能部と、前記通信機能部とは別のデータ取得部であって、前記通信ラインを伝送する電気信号をサンプリングするデータ取得部と、前記データ取得部で取得したデータにおいて現在設定されている通信速度から規定される電気信号の第1の変化よりも速い電気信号の第2の変化が発生した場合に、ノイズが発生したと判定するノイズ発生判定部と、前記ノイズ発生判定部でノイズが発生したと判定した場合に、前記通信機能部を介して取得したデータを補正するデータ補正部とを備える。【選択図】図2
Description
本発明は、電子制御装置に関する。
機器を制御する電子制御装置には通信機能が搭載されており、通信ラインで相互接続された複数の電子制御装置間のデータ送受信には、様々な通信プロトコルに準じたデジタル通信が用いられる。これらのデジタル通信では、通信ラインの電圧レベルを高低の2値("0"、"1")で変化させ、パルス状の電気信号として伝送することでデータの送受信が実現されている。
電気信号の伝送には信号線が用いられるが、電子制御装置間に信号線を這いまわす際に十分な空間が確保できることは少ない。結果として、ノイズ源となる機器近傍に信号線を這いまわすことになり、通信ラインへのノイズの混入が問題となる。
この問題に対しては、信号線に撚対線やシールド線を採用する、電子制御装置の入力にフィルタ回路を設置するなどのハードウェアでの対策が施される。しかし、機器が発するノイズは多種多様なため、それ単体ではノイズ対策として十分ではない場合がある。
そのため、上記ハードウェアでのノイズ対策と併せて、電子制御装置が検知した電気信号に対し、ソフトウェアでの対策を実施することでノイズの影響を低減させる方策が検討されている。中でも、単線でのシリアル通信においては、ノイズの影響を顕著に受ける。したがって、ロバスト性の高い通信を実施するためには、ノイズ対策が必要不可欠となる。
電子制御装置が検知した電気信号に対し、ソフトウェアでの対策を実施する具体的な方法の一例としては、特許文献1がある。特許文献1では、通信プロトコルに準じて伝送されるパルス状の電気信号中のインターバル(データの送受信に寄与しない無駄時間)の区間の電圧レベルが2値("0"、"1")と異なる電圧レベルに設定され、これにより、ノイズによるビット化けの影響を回避する。
しかしながら、特許文献1に記載されている技術は、各データフィールドに対応する電気信号の開始ビットを誤って特定すること、又は特定のフィールドの電気信号を誤ってインターバル信号として誤認識することの回避に限定されている。したがって、各データフィールドの送受信中に発生するノイズによる影響を回避できないという課題があった。
そこで、本発明は、上記の課題を解決するためになされるものであり、各データフィールドの送受信中に発生するノイズによるビット化けの影響を回避することができる電子制御装置を提供する。
例えば、上記課題を解決するために、特許請求の範囲に記載の構成を採用する。本願は上記課題を解決する手段を複数含んでいるが、その一例をあげるならば、通信ラインを介して他の機器とデータの送受信を行う電子制御装置であって、前記通信ラインを介してデータの送受信を行う通信機能部と、前記通信機能部とは別のデータ取得部であって、前記通信ラインを伝送する電気信号をサンプリングするデータ取得部と、前記データ取得部で取得したデータにおいて現在設定されている通信速度から規定される電気信号の第1の変化よりも速い電気信号の第2の変化が発生した場合に、ノイズが発生したと判定するノイズ発生判定部と、前記ノイズ発生判定部でノイズが発生したと判定した場合に、前記通信機能部を介して取得したデータを補正するデータ補正部と、を備える電子制御装置が提供される。
本発明によれば、各データフィールドの送受信中に発生するノイズによるビット化けの影響を回避することができる。本発明に関連する更なる特徴は、本明細書の記述、添付図面から明らかになるものである。また、上記した以外の、課題、構成及び効果は、以下の実施例の説明により明らかにされる。
以下、添付図面を参照して本発明の実施例について説明する。添付図面は本発明の原理に則った具体的な実施例を示しているが、これらは本発明の理解のためのものであり、決して本発明を限定的に解釈するために用いられるものではない。
以下、本発明の一実施例を説明する。なお、以下に示す実施例では車載通信システムに用いられるLIN(Local Interconnect Network)に適用した例を挙げて説明するが、これに限定されない。
まず、LINについて説明する。LINは、車載通信システムにおいてセンサやアクチュエータなどの制御に採用されており、安価でシンプルなネットワークシステムを実現できる。LINでは、マスタ・スレーブ方式が採用されており、スレーブノードはマスタノードの指示に従って通信を行う。具体的には、マスタノードから送信される送信要求「ヘッダ」に対して、スレーブノードがデータである「レスポンス」を送信することで各種情報のやり取りを行う。これらの実現にはマスタノードのみが持っているマスタタスクと、マスタノードとスレーブノードの双方が持っているスレーブタスクが、それぞれの役割を担っている。マスタタスクは、予め決められたタイミングで通信ラインにヘッダを送信する。スレーブタスクは、ヘッダに含まれる情報からレスポンスを送信するか否かを判定し、判定結果に応じてレスポンスを送信する。LINでは、このヘッダとレスポンスのセットを「フレーム」と呼び、フレームの単位で情報がやり取りされる。
図1はLINフレーム構造を示している。ヘッダは、"0"(ドミナント)が13ビット以上続く「Break」から始まり、「Synch」、「Protected ID(PID)」の3つのフィールドによって構成される。レスポンスは、「データ」、「チェックサム」の2つのフィールドによって構成される。これらフィールド間には各フィールドの送信タイミングが重複しないよう「レスポンススペース」、「インターバイトスペース」と呼ばれる時間が含まれることを許容しており、これらのスペースでは"1"(リセッシブ)となる。
LINでは、UARTの通信方式が採用されており、UARTの通信方式では、各フィールドの始まりは"0"(ドミナント)であるスタートビットから開始され、フィールドの終わりは"1"(リセッシブ)であるストップビットで終了する。UARTの通信方式では、受信側はスタートビットの立下りで通信開始を判断し、現在設定されている通信速度に従い通信ラインをサンプリングしていく調歩同期方式が採用されている。通常、データのサンプリングは各データビットの中央を狙って実施し、最後にストップビットであるはずの位置でサンプリングを行い、"1"(リセッシブ)であれば正常終了する。
LINでは、データを正確に受信できたかどうかを確認するため、レスポンスを受信したノードは、受信したデータフィールドから計算したチェックサムと、受信したチェックサムフィールドが一致するかどうかを検査し、双方が一致した場合はデータを正確に受信できたと判断する。一方、これらが不一致の場合は、ノードは、通信ライン上で何らかの要因でデータに誤りが生じていると判断し、データを破棄する。
図2は、本発明のLINへの適用時の電子制御装置100の構成図である。車載通信システムは、通信ライン300に接続された複数のノードで構成されており、それぞれのノードが通信ライン300を介してLINプロトコルに準じて通信する。上記ノードは、マスタノードである電子制御装置100と、複数のスレーブノード200とを含む。
電子制御装置100は、制御部110と、通信機能部120とを備える。制御部110は、図示しない制御装置として一般に具備されるCPU(Central Processing Unit)、ROM、RAM、及び記憶部等を備えている。CPUは、ROM、RAM、又は記憶部に格納されたプログラムに基づいて、種々の処理を実行する。
制御部110は、上述のプログラムに基づき、マスタタスク処理部111及びスレーブタスク処理部112として動作する。マスタタスク処理部111は、予め決められたタイミングで通信機能部120を介して通信ライン300にヘッダを出力する。スレーブタスク処理部112は、通信ライン300に出力されたヘッダを解釈して、自身に関連したProtected IDフィールドが含まれる場合は、図示しないセンサやアクチュエータなどの制御データを、レスポンス内のデータフィールドとして、通信機能部120を介して通信ライン300に出力する。
通信機能部120は、通信ライン300を介してLINプロトコルに準じた通信を実現させる。制御部110は、通信機能部120を介して通信ライン300の電圧レベルを高低の2値("0"、"1")で変化させ、ヘッダ及びレスポンスを通信ライン300に出力する。また、制御部110は、通信機能部120に備えられたレベル判定部121によって通信ライン300に出力された電気信号の電圧レベルを判定させることで、通信ライン300上に出力されたパルス状の電気信号をデジタル値として認識する。
レベル判定部121は、通信ライン300の電気信号の電圧レベルをサンプリングし、電圧レベルが"高"であるか、"低"であるかを判定する。この場合、例えば、"高"は12[V]であり、"低"が0[V]である。レベル判定部121は、"高"であるか又は"低"であるかの判定結果に応じて、"高"である場合は"1"(リセッシブ)、"低"である場合は"0"(ドミナント)として、"0"/"1"の符号列を制御部110へ出力する。制御部110は、この"0"/"1"の符号列をUARTの通信方式に則り、調歩同期方式にてサンプリングすることでデータとして認識する。
スレーブノード200は、制御部210と、通信機能部220とを備える。制御部210は、図示しない制御装置として一般に具備されるCPU(Central Processing Unit)、ROM、RAM、及び記憶部等を備えている。CPUは、ROM、RAM、又は記憶部に格納されたプログラムに基づいて、種々の処理を実行する。
制御部210は、上述のプログラムに基づき、スレーブタスク処理部212として動作する。スレーブタスク処理部212は、通信ライン300に出力されたヘッダを解釈して、自身に関連したProtected IDフィールドが含まれる場合は、図示しないセンサやアクチュエータなどの制御データを、レスポンス内のデータフィールドとして、通信機能部220を介して通信ライン300に出力する。
通信機能部220は、通信ライン300を介してLINプロトコルに準じた通信を実現させる。制御部210は、通信機能部220を介して通信ライン300の電圧レベルを高低の2値("0"、"1")で変化させ、レスポンスを通信ライン300に出力する。また、制御部210は、通信機能部220に備えられたレベル判定部221によって通信ライン300に出力された信号の電圧レベルを判定することで、通信ライン300上に出力されたパルス状の電気信号をデジタル値として認識する。
レベル判定部221は、通信ライン300の電気信号の電圧レベルをサンプリングし、電圧レベルが"高"であるか、"低"であるかを判定する。この場合、例えば、"高"は12[V]であり、"低"が0[V]である。レベル判定部221は、"高"であるか又は"低"であるかの判定結果に応じて、"高"である場合は"1"(リセッシブ)、"低"である場合は"0"(ドミナント)として、"0"/"1"の符号列を制御部210へ出力する。制御部210は、この"0"/"1"の符号列をUARTの通信方式に則り、調歩同期方式にてサンプリングすることでデータとして認識する。
次に、本発明の特徴部分であるデータ取得部130、ノイズ発生判定部113、データ補正部114、及び設定切替部115について説明する。ここでは、マスタノードである電子制御装置100について説明するが、図2に示すように、スレーブノード200もまた同様の構成を備えている。
データ取得部130は、通信ライン300を伝送するパルス状の電子信号を通信機能部120よりも高速にサンプリングするものである。ここでは、データ取得部130として、ADコンバータを用いた場合を説明するが、これに限定されない。例えば、データ取得部130は、デジタル入力によるサンプリングを行ってもよい。
ここでは、現在設定されている通信速度が例えば19.2kbit/secであるとする。この場合、データ取得部130は、1ビット送信に要する時間が52μsとなるため、サンプリング定理などを鑑み、2μs毎のサンプリングを実施する。サンプリング間隔については、ノイズの発生を検知するために、より高速にサンプリングするのが好ましいが、AD変換が必要な他のデータとの兼ね合い(データ数・データ更新の間隔など)で調整すればよい。データ取得部130は、データフィールドをサンプリングし、取得したデータをノイズ発生判定部113へ送る。
ノイズ発生判定部113は、現在設定されている通信速度から規定される電気信号の第1の変化("0"⇔"1")よりも速い電気信号の第2の変化("0"⇔"1")がデータ取得部130で取得したデータに発生した場合は、ノイズが発生したと判定する。ここでは、ノイズ発生判定部113として、カウンタとタイマを用いた場合を説明するが、これに限定されない。カウンタとタイマを用いることにより、簡易な構成でノイズの発生、ノイズの発生箇所の特定が可能となる。
本実施例では、データ取得部130としてADコンバータを用いた場合を説明しているため、データ取得部130で取得したデータの電圧レベルが"高"であるか又は"低"であるかの判定を、LINプロトコルに準じ、ノイズ発生判定部113によって行う。この場合も、例えば、"高"は12[V]であり、"低"が0[V]である。ノイズ発生判定部113は、"高"であるか又は"低"であるかの判定結果に応じて、"高"である場合は"1"(リセッシブ)、"低"である場合は"0"(ドミナント)として、"0"/"1"の符号列を扱えるようにする。ノイズ発生判定部113は、この"0"⇔"1"の変化が1ビット送信に要する時間よりも速い間隔で発生した場合、ノイズが発生したと判定する。
図3は、ノイズが発生していない状態の通信ライン300に伝送する電気信号の一例を示している。縦軸に通信ライン300における電圧レベルを示し、横軸に時間を示す。図3は、LINフレーム中のデータフィールドとその前後の信号を示しており、分かりやすいようにデータ設定は「10101010」としている。ノイズが発生していない状態の場合、通信ライン300に伝送する電気信号は1ビット送信に要する時間毎に"0"⇔"1"が変化する。
一方、図4は、ノイズが発生した状態の通信ライン300に伝送する電気信号の一例を示している。上記のように、通常、電気信号の"0"⇔"1"の変化は1ビット送信に要する時間よりも速く実施されることはないため、1ビット送信に要する時間よりも速い電気信号の"0"⇔"1"の変化を検知した場合はノイズが発生したと見なせる。
図5は、ノイズ発生判定部113におけるノイズの発生を検知する手法を示す図である。ノイズ発生判定部113は、例えば、計時用タイマ及びノイズ検知用タイマを備える。図5に示すように、ノイズ検知用タイマは、スタートビットの立下りからカウントアップを開始し、電気信号の"0"⇔"1"の変化が発生した時点で、タイマをクリアする。ノイズ発生判定部113におけるノイズの発生の検知は、このノイズ検知用タイマを設けることで実現できる。ノイズ検知用タイマは、ストップビットの立ち上がりでタイマクリア及びカウントアップを停止する。
図5に示すように、ノイズが発生しない場合(501)、ノイズ検知用タイマは1ビット送信に要する時間に達する。一方、ノイズが発生した場合(502)、ノイズ検知用タイマは1ビット送信に要する時間に達しないため(1ビット送信に要する時間に達する前にクリアされるため)、ノイズが発生した事を検知できる。
また、図5に示すように、計時用タイマは、スタートビットの立下りからカウントアップを開始し、1ビット送信に要する時間を計時する。計時用タイマとノイズ検知用タイマを併用することで、ノイズ発生判定部113は、ノイズが発生したタイミングも特定することができる(計時用タイマは、ストップビットの立ち上がりでタイマクリア及びカウントアップを停止する)。
具体的には、ノイズ検知用タイマがクリアされるのは、ノイズの発生又は1ビット送信完了時である。したがって、ノイズ発生判定部113は、ノイズ検知用タイマが0で計時用タイマが0の場合を1ビット送信完了とみなし、ノイズ検知用タイマが0で計時用タイマが0以外の場合はノイズ発生とみなす。ノイズが発生したタイミングの特定は、ノイズ検知用タイマが0になる直前の値から判断でき、図5の場合、20μs時〜32μs時までがノイズが発生したタイミングと特定できる。
また、ノイズによる影響を回避するようにデータを補正するためには、データフィールドの何ビット目にノイズが発生したかも重要な情報となる。したがって、図5のように、ノイズ発生判定部113は、例えば、ビット特定用カウンタを備える。ノイズ発生判定部113は、ビット特定用カウンタを用いて、何ビット目でノイズが発生したかを判断できる。計時用タイマ、ノイズ検知用タイマ、及び、ビット特定用カウンタを併用することで、ノイズ発生判定部113は、データフィールドの何ビット目のどのタイミングでノイズが発生したかを判断する。ビット特定用カウンタは、スタートビットの立下りからカウントアップを開始し、ストップビットの立ち上がりでカウンタクリア及びカントアップを停止する。
さらに、ノイズによる影響を回避するようにデータを補正するためには、データフィールドの何バイト目にノイズが発生したかも重要な情報となる。図6は、ノイズ発生がデータフィールドの何バイト目で発生したかを検知する手法を示す図である。ノイズ発生判定部113は、例えば、バイト特定用カウンタを備える。ノイズ発生判定部113は、バイト特定用カウンタを用いて、データフィールドの何バイト目でノイズが発生したかを判断する。バイト特定用カウンタは、データ1のスタートビットの立下りからカウントアップを開始し、データNのストップビットの立ち上がりでカウンタクリア及びカントアップを停止する。なお、ノイズ発生判定部113は、上記で取得した情報(何バイト目、何ビット目、何μs〜何μsのタイミングでノイズが発生したかの情報)をデータ補正部114に送る。
なお、カウンタとタイマの組み合わせは上記の例に限定されない。また、カウンタ及びタイマ以外の別の構成によってノイズの発生、ノイズの発生箇所を特定してもよい。
データ補正部114は、制御部110が通信機能部120経由で認識したデータを、ノイズによる影響を回避するように補正する。具体的には、ノイズ発生判定部113から(1)ノイズ発生の有無、(2)ノイズの発生バイト、(3)ノイズの発生ビット、(4)ノイズの発生タイミングの情報を受け取り、図7の動作に従いデータ補正の要否の判定及びデータ補正を実施する。図7は、データ補正部114における動作フローを示す図である。
(ステップS10)
データ補正部114は、ノイズ発生判定部113から受け取った(1)ノイズ発生の有無の情報から、データフィールドにノイズが発生したか否かの判定を行う。ノイズの発生があった場合はS11に進む。一方、ノイズの発生が無かった場合はデータ補正を実施する必要はないため、データ補正部114での処理を終了させる。
データ補正部114は、ノイズ発生判定部113から受け取った(1)ノイズ発生の有無の情報から、データフィールドにノイズが発生したか否かの判定を行う。ノイズの発生があった場合はS11に進む。一方、ノイズの発生が無かった場合はデータ補正を実施する必要はないため、データ補正部114での処理を終了させる。
(ステップS11)
データ補正部114は、ノイズ発生判定部113から受け取った(4)ノイズの発生タイミングの情報から、ノイズの発生箇所が制御部110の調歩同期方式のサンプリングタイミングと重なっているか否かの判定を行う。調歩同期方式のサンプリングは、各データビットの中央を狙って実施しているため、データ補正部114は、各データビットの中央付近でノイズが発生していた場合、ノイズ発生がサンプリングタイミングに重なったと判定する。
データ補正部114は、ノイズ発生判定部113から受け取った(4)ノイズの発生タイミングの情報から、ノイズの発生箇所が制御部110の調歩同期方式のサンプリングタイミングと重なっているか否かの判定を行う。調歩同期方式のサンプリングは、各データビットの中央を狙って実施しているため、データ補正部114は、各データビットの中央付近でノイズが発生していた場合、ノイズ発生がサンプリングタイミングに重なったと判定する。
図8は、ノイズ発生と調歩同期方式のサンプリングタイミングが重畳したか否かを判定する手法を示す図である。上記の重なりの判定は、図8に示すようにデータビットの中央(26μs)から任意のバンド(図では22μs〜30μs)を設けて判定する。例えば、図8の2ビット目に発生したノイズは、図5と同様に20μs〜32μs時において発生している。したがって、データ補正部114は、ノイズ発生箇所がサンプリングタイミングに重なったと判定する。本実施例では、バンド幅で重なりを判定したが、これに限定されない。また、任意のバンドの位置は、上記の例では、データビットの中央に設定したが、これに限定されず、サンプリングのタイミングに応じてデータビット内の任意の位置に任意の幅で設定することができる。
最終的にノイズの発生箇所が調歩同期方式のサンプリングタイミングと重なったと判定した場合はS12に進む。一方、ノイズの発生箇所が調歩同期方式のサンプリングタイミングと重なっていないと判定した場合はデータ補正を実施する必要はないため、データ補正部114での処理を終了させる。このようにサンプリングタイミングとノイズの発生箇所の重なりを判定することにより、データ補正が必要かどうかを判断することができ、これにより、必要な場合のみデータの補正を実行することができる。
(ステップS13)
データ補正部114は、制御部110が通信機能部120経由で認識したデータに対し、ノイズの影響を含んでいる箇所((2)ノイズの発生バイト、(3)ノイズの発生ビットから特定)のビット認識を反転("0"⇒"1"もしくは"1"⇒"0")させる。これにより、ノイズによる影響を回避した正しいデータに補正することができる。
データ補正部114は、制御部110が通信機能部120経由で認識したデータに対し、ノイズの影響を含んでいる箇所((2)ノイズの発生バイト、(3)ノイズの発生ビットから特定)のビット認識を反転("0"⇒"1"もしくは"1"⇒"0")させる。これにより、ノイズによる影響を回避した正しいデータに補正することができる。
以後、ノードが、レスポンス受信毎に図7に示す処理を実行する。
レスポンスを受け取った後、最終的にデータの信頼性を確保するため、LINプロトコルに準じ、電子制御装置100の制御部110がチェックサムの比較を実施する。図9は、チェックサムの比較の動作フローを示す。
(ステップS20)
制御部110は、データ補正部114でデータの補正を実施したか否かの判定を行う。データの補正が実施された場合は、ステップS21に進む。一方、データの補正が実施されなかった場合は、S24へ進む。
制御部110は、データ補正部114でデータの補正を実施したか否かの判定を行う。データの補正が実施された場合は、ステップS21に進む。一方、データの補正が実施されなかった場合は、S24へ進む。
(ステップS21)
制御部110は、データ補正部114で補正したデータから、LINプロトコルに準じたサムの計算を実施する。
制御部110は、データ補正部114で補正したデータから、LINプロトコルに準じたサムの計算を実施する。
(ステップS22)
制御部110は、S21で計算したサムとレスポンス内のチェックサムフィールドとを比較し、値が一致するか否かの判定を行う。一致した場合は、S23に進む。一方、不一致の場合は、データの補正が正しく行われなかった可能性があるため、S24に進む。
制御部110は、S21で計算したサムとレスポンス内のチェックサムフィールドとを比較し、値が一致するか否かの判定を行う。一致した場合は、S23に進む。一方、不一致の場合は、データの補正が正しく行われなかった可能性があるため、S24に進む。
(ステップS23)
制御部110は、データ補正部114で補正したデータを"正"として扱い、制御部110内で参照できる状態にする。
制御部110は、データ補正部114で補正したデータを"正"として扱い、制御部110内で参照できる状態にする。
(ステップS24)
制御部110は、データ補正部114で補正を実施しなかったデータから、LINプロトコルに準じたサムの計算を実施する。
制御部110は、データ補正部114で補正を実施しなかったデータから、LINプロトコルに準じたサムの計算を実施する。
(ステップS25)
制御部110は、S24で計算したサムとレスポンス内のチェックサムフィールドとを比較し、値が一致するか否かの判定を行う。一致した場合は、S26に進む。一方、不一致の場合は、データが正しく受信できなかったと判断し、S27に進む。
制御部110は、S24で計算したサムとレスポンス内のチェックサムフィールドとを比較し、値が一致するか否かの判定を行う。一致した場合は、S26に進む。一方、不一致の場合は、データが正しく受信できなかったと判断し、S27に進む。
(ステップS26)
制御部110は、データ補正部114で補正を実施しなかったデータを"正"として扱い、制御部110内で参照できる状態にする。
制御部110は、データ補正部114で補正を実施しなかったデータを"正"として扱い、制御部110内で参照できる状態にする。
(ステップS27)
制御部110は"Checksum Error"として異常検知すると共に、受信したデータを破棄する。
制御部110は"Checksum Error"として異常検知すると共に、受信したデータを破棄する。
(ステップS27)
以後、ノードがレスポンス受信毎に図9に示す処理を実行する。
以後、ノードがレスポンス受信毎に図9に示す処理を実行する。
なお、制御部110は、設定切替部115を備えてもよい。設定切替部115は、例えば、データ補正部114によるデータ補正処理を行うか又は行わないかの設定を行うことができる。これにより、データの補正の有効/無効を切り替えることが可能となる。
なお、スレーブノード200に備えられているデータ取得部230、ノイズ発生判定部213、データ補正部214、及び設定切替部215については、電子制御装置100に備えられているデータ取得部130、ノイズ発生判定部113、データ補正部114及び設定切替部115の機能と同様のため、詳細な説明は省略する。
本実施例は、様々な通信プロトコルに適用可能である。データ取得部130,230は、通信速度に応じてサンプリング間隔を適宜設定すればよい。ノイズ発生判定部113,213は、データ取得部130で取得したデータの電圧レベルが"高"であるか又は"低"であるかの判定を様々な通信プロトコルに準じて実施することができる。ノイズ発生判定部113,213は、通信速度に応じてタイマ及びカウンタを適宜設定すればよい。
なお、上記の電子制御装置は、車載通信システムに搭載する例で説明したが、本実施例は、家電製品など他の機器に適用されてもよい。
以上の実施例における電子制御装置は、通信ラインで複数の電子制御装置と相互接続されており、様々な通信プロトコルに準じたデジタル通信を用いてデータの送受信を行う。この電子制御装置は、通信ラインを介してデータの送受信を実現させる通信機能部120,220とは別に、通信ラインを伝送するパルス状の電気信号をサンプリングするデータ取得部130,230と、データ取得部130,230で取得したデータにおいて現在設定されている通信速度から規定される電気信号の変化("0"⇔"1")よりも速い電気信号の変化("0"⇔"1")が発生した場合は、ノイズが発生したと判定するノイズ発生判定部113, 213と、ノイズ発生判定部113, 213でノイズが発生したと判定した場合に電子制御装置が通信機能部120,220経由で認識したデータをノイズによる影響を回避するように補正するデータ補正部114,214を備える。
本実施例によれば、通信ライン300のノイズの発生有無を判定し、ノイズが発生したと判定した場合、電子制御装置100が認識したデータをノイズによる影響を回避するように補正することができる。したがって、ノイズによるビット化けの影響を回避し、ロバスト性の高い通信を実現することができる。
なお、上記の例では、マスタノード及びスレーブノードの両方が、データ取得部130,230、ノイズ発生判定部113, 213、及び、データ補正部114,214を備えているが、これらの構成要素が、マスタノード又はスレーブノードのいずれかに設けられる構成でもよい。この場合、上記の構成要素が設けられたノードは、受信するデータについて、上記で説明したノイズ発生の判定とデータの補正が可能となる。
本発明は上記した実施例に限定されるものではなく、様々な変形例が含まれる。上記実施例は本発明を分かりやすく説明するために詳細に説明したものであり、必ずしも説明した全ての構成を備えるものに限定されるものではない。また、ある実施例の構成の一部を他の実施例の構成に置き換えることもできる。また、ある実施例の構成に他の実施例の構成を加えることもできる。また、各実施例の構成の一部について、他の構成を追加・削除・置換することもできる。
上記の各構成、機能等は、プロセッサがそれぞれの機能を実現するプログラムを解釈し、実行することによりソフトウェアで実現してもよい。各機能を実現するプログラム等の情報は、公知の記録装置あるいは記録媒体に格納することができる。また、上記の各構成、機能等は、それらの一部や全部を、例えば集積回路で設計する等によりハードウェアで実現してもよい。
上述の実施例において、制御線や情報線は説明上必要と考えられるものを示しており、製品上必ずしも全ての制御線や情報線を示しているとは限らない。全ての構成が相互に接続されていてもよい。
100:電子制御装置(マスタノード)、110:制御部(マスタノード)、111:マスタタスク処理部、112:スレーブタスク処理部(マスタノード)、113:ノイズ発生判定部(マスタノード)、114:データ補正部(マスタノード)、115:設定切替部(マスタノード)、120:通信機能部(マスタノード)、121:レベル判定部(マスタノード)、130:データ取得部(マスタノード)、200:スレーブノード、210:制御部(スレーブノード)、212:スレーブタスク処理部(スレーブノード)、213:ノイズ発生判定部(スレーブノード)、214:データ補正部(スレーブノード)、215:設定切替部(スレーブノード)、220:通信機能部(スレーブノード)、221:レベル判定部(スレーブノード)、230:データ取得部(スレーブノード)、300:通信ライン
Claims (5)
- 通信ラインを介して他の機器とデータの送受信を行う電子制御装置であって、
前記通信ラインを介してデータの送受信を行う通信機能部と、
前記通信機能部とは別のデータ取得部であって、前記通信ラインを伝送する電気信号をサンプリングするデータ取得部と、
前記データ取得部で取得したデータにおいて現在設定されている通信速度から規定される電気信号の第1の変化よりも速い電気信号の第2の変化が発生した場合に、ノイズが発生したと判定するノイズ発生判定部と、
前記ノイズ発生判定部でノイズが発生したと判定した場合に、前記通信機能部を介して取得したデータを補正するデータ補正部と、
を備えることを特徴とする電子制御装置。 - 請求項1に記載の電子制御装置において、
前記ノイズ発生判定部は、カウンタ及びタイマを用いて、前記データ取得部で取得した前記データにおける前記ノイズの発生及び発生箇所を特定することを特徴とする電子制御装置。 - 請求項1に記載の電子制御装置において、
前記データ補正部は、
前記ノイズ発生判定部からの判定結果を用いて、前記データ取得部による前記サンプリングのタイミングと前記ノイズの発生箇所とが重なったかを判定し、
前記サンプリングのタイミングと前記ノイズの発生箇所とが重なった場合に、前記通信機能部を介して取得したデータを補正することを特徴とする電子制御装置。 - 請求項1に記載の電子制御装置において、
前記データ補正部は、前記通信機能部を介して取得したデータにおいて前記ノイズを含んでいる箇所のビットを反転させることにより、データを補正することを特徴とする電子制御装置。 - 請求項1に記載の電子制御装置において、
当該電子制御装置は、前記データ補正部によって補正されたデータから計算されたサムとチェックサムとの比較を実行し、一致した場合に、前記データ補正部によって補正されたデータを"正"として扱うことを特徴とする電子制御装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2015248699A JP2017118184A (ja) | 2015-12-21 | 2015-12-21 | 電子制御装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2015248699A JP2017118184A (ja) | 2015-12-21 | 2015-12-21 | 電子制御装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2017118184A true JP2017118184A (ja) | 2017-06-29 |
Family
ID=59230855
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2015248699A Pending JP2017118184A (ja) | 2015-12-21 | 2015-12-21 | 電子制御装置 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP2017118184A (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2021516021A (ja) * | 2018-03-12 | 2021-06-24 | ロベルト・ボッシュ・ゲゼルシャフト・ミト・ベシュレンクテル・ハフツングRobert Bosch Gmbh | シリアルバスシステムの加入者局およびシリアルバスシステムにおけるデータ伝送方法 |
-
2015
- 2015-12-21 JP JP2015248699A patent/JP2017118184A/ja active Pending
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2021516021A (ja) * | 2018-03-12 | 2021-06-24 | ロベルト・ボッシュ・ゲゼルシャフト・ミト・ベシュレンクテル・ハフツングRobert Bosch Gmbh | シリアルバスシステムの加入者局およびシリアルバスシステムにおけるデータ伝送方法 |
JP7028989B2 (ja) | 2018-03-12 | 2022-03-02 | ロベルト・ボッシュ・ゲゼルシャフト・ミト・ベシュレンクテル・ハフツング | シリアルバスシステムの加入者局およびシリアルバスシステムにおけるデータ伝送方法 |
US11595229B2 (en) | 2018-03-12 | 2023-02-28 | Robert Bosch Gmbh | Subscriber station for a serial bus system, and method for data transmission in a serial bus system |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10713106B2 (en) | Communication device, communication method and non-transitory storage medium | |
KR102045254B1 (ko) | 유연한 메시지 크기로 직렬 데이터 전송 시 데이터 전송 안전성을 개선하기 위한 방법 및 장치 | |
US11296965B2 (en) | Abnormality detection in an on-board network system | |
KR101519793B1 (ko) | 차량용 네트워크 시스템 및 이 시스템 내 이종 통신 제어기의 데이터 전송 방법 | |
US10404721B2 (en) | Communication device for detecting transmission of an improper message to a network | |
JP4873663B2 (ja) | 信号を復号するための方法と装置 | |
JP2007324679A (ja) | シリアル通信用ボーレートジェネレータ | |
JP2008518497A (ja) | シリアルデータバスのためのスレーブバスサブスクライバ | |
CN103165169A (zh) | 至 rf 通信装置的自适应等时usb 音频 | |
KR102091565B1 (ko) | 프로토콜 예외 상태를 갖는 데이터 전송 | |
KR101519719B1 (ko) | 게이트웨이의 메시지 처리 방법 | |
US20110026572A1 (en) | Baud rate error detection circuit and baud rate error detection method | |
US20210058495A1 (en) | Communication device, communication system, and protocol switchover method | |
TW201516657A (zh) | 解譯接收自冗餘匯流排的信號之技術 | |
JP2017118184A (ja) | 電子制御装置 | |
JP4930510B2 (ja) | 信号受信装置及び波形整形方法 | |
JP2005277978A (ja) | 識別番号自動設定方法及び識別番号自動設定装置 | |
JP5018396B2 (ja) | 通信装置及び通信システム | |
KR101084060B1 (ko) | Bms 제어기 간의 극성 자동판단에 의한 데이터 전송이 가능한 무극성 rs-485통신장치 | |
CN111756588A (zh) | 通信链路检测方法及相关装置 | |
JP2015091062A (ja) | 通信システムおよびゲートウェイ装置並びに通信方法 | |
JP5396812B2 (ja) | 伝送制御装置および伝送制御方法 | |
JP7120156B2 (ja) | 通信装置 | |
JP2010028185A (ja) | ネットワークノード、ネットワークシステムおよび輻輳検出方法 | |
TWI654862B (zh) | 訊號管理裝置及訊號管理方法 |