[go: up one dir, main page]

JP2018180951A - 回路構成最適化装置及び機械学習装置 - Google Patents

回路構成最適化装置及び機械学習装置 Download PDF

Info

Publication number
JP2018180951A
JP2018180951A JP2017079851A JP2017079851A JP2018180951A JP 2018180951 A JP2018180951 A JP 2018180951A JP 2017079851 A JP2017079851 A JP 2017079851A JP 2017079851 A JP2017079851 A JP 2017079851A JP 2018180951 A JP2018180951 A JP 2018180951A
Authority
JP
Japan
Prior art keywords
circuit configuration
fpga device
fpga
state
learning
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.)
Granted
Application number
JP2017079851A
Other languages
English (en)
Other versions
JP6502998B2 (ja
Inventor
均 和泉
Hitoshi Izumi
均 和泉
健一郎 栗原
Kenichiro Kurihara
健一郎 栗原
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fanuc Corp
Original Assignee
Fanuc Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Fanuc Corp filed Critical Fanuc Corp
Priority to JP2017079851A priority Critical patent/JP6502998B2/ja
Priority to DE102018002781.4A priority patent/DE102018002781B4/de
Priority to US15/947,835 priority patent/US10565343B2/en
Priority to CN201810326636.3A priority patent/CN108736881B/zh
Publication of JP2018180951A publication Critical patent/JP2018180951A/ja
Application granted granted Critical
Publication of JP6502998B2 publication Critical patent/JP6502998B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/177Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
    • H03K19/17748Structural details of configuration resources
    • H03K19/17764Structural details of configuration resources for reliability
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/34Circuit design for reconfigurable circuits, e.g. field programmable gate arrays [FPGA] or programmable logic devices [PLD]
    • G06F30/343Logical level
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/32Circuit design at the digital level
    • G06F30/327Logic synthesis; Behaviour synthesis, e.g. mapping logic, HDL to netlist, high-level language to RTL or netlist
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/34Circuit design for reconfigurable circuits, e.g. field programmable gate arrays [FPGA] or programmable logic devices [PLD]
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/39Circuit design at the physical level
    • G06F30/392Floor-planning or layout, e.g. partitioning or placement
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/39Circuit design at the physical level
    • G06F30/398Design verification or optimisation, e.g. using design rule check [DRC], layout versus schematics [LVS] or finite element methods [FEM]
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/04Architecture, e.g. interconnection topology
    • G06N3/0499Feedforward networks
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/08Learning methods
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/08Learning methods
    • G06N3/092Reinforcement learning
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2119/00Details relating to the type or aim of the analysis or the optimisation
    • G06F2119/06Power analysis or power optimisation
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2119/00Details relating to the type or aim of the analysis or the optimisation
    • G06F2119/08Thermal analysis or thermal optimisation
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Evolutionary Computation (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Computing Systems (AREA)
  • Geometry (AREA)
  • Data Mining & Analysis (AREA)
  • Artificial Intelligence (AREA)
  • Molecular Biology (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • Biophysics (AREA)
  • Biomedical Technology (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Medical Informatics (AREA)
  • Logic Circuits (AREA)
  • Architecture (AREA)
  • Detection And Correction Of Errors (AREA)
  • Numerical Control (AREA)

Abstract

【課題】FPGAデバイスの誤動作が発生する頻度を低減させることが可能な回路構成最適化装置及び機械学習装置を提供すること。
【解決手段】本発明の回路構成最適化装置10は、FPGAデバイスの回路構成を学習する機械学習装置20を備え、該機械学習装置20は、FPGAデバイスの回路構成を示すFPGAデバイスの回路構成データ、及びFPGAデバイスのエラー発生状態を示すFPGAエラー発生状態データを、環境の現在状態を表す状態変数として観測する状態観測部22と、FPGAデバイス動作状態の適否判定結果を示す判定データを取得する判定データ取得部24と、状態変数と判定データとを用いて、FPGAデバイスの回路構成をFPGAエラー発生状態データと関連付けて学習する学習部26と、を備える。
【選択図】図1

Description

本発明は、回路構成最適化装置及び機械学習装置に関する。
製造時に全ての回路が固定される通常の集積回路に対し、出荷後にユーザが所望の回路構成を設定して機能させることができるデバイスであるプログラマブルロジックデバイス(PLD:Programmable Logic Device)がある。このようなデバイスの一種であるFPGA(Field Programmable Gate Array)は、プログラム可能な論理コンポーネントである論理ブロックを組み合わせることにより、単純な論理回路からメモリ要素を含む複雑な回路まで、必要に応じてFPGAを使用している現場で構成して使用することができる。FPGAでは、このような回路をパッケージ上の任意の位置に構築することができる。
FPGAデバイスに対して中性子線が突入すると、該中性子線はパッケージ内のボロンなどと衝突してα線を含む大量のイオンが発生し、このα線が原因となりシリコン内部の電位が反転し、ソフトエラーが発生する。なお、FPGAデバイスのソフトエラーに係る従来技術として、例えば特許文献1,2には、ソフトエラーの発生を検出する技術が開示されている。
特開2006−344223号公報 特開2016−167669号公報
FPGAデバイスにおけるソフトエラーの発生確率は、FPGAデバイスを構成するパッケージ材に含まれるボロンなどの密度(ボロン濃度の高さ)に応じて変化する。図9は、FPGAデバイスの概略構造図を示している。図9に示すように、FPGAデバイス内においてボロンの濃度が高い領域がある場合、当該領域ではソフトエラーが発生する確率が高くなるため、当該領域には回路を配置しないようにするか、または、エラー訂正機能や冗長性を持たせたノイズに強い回路を配置することでソフトエラー対策を行う。
上記したように、FPGAデバイス毎にソフトエラー発生頻度の高いFPGAの論理回路領域は異なるが、ソフトエラー対策を効率よく行うためには、FPGAデバイス上のいずれの位置でソフトエラーが発生し易いのかを把握する必要がある。
そこで本発明の目的は、FPGAデバイスの誤動作が発生する頻度を低減させることが可能な回路構成最適化装置及び機械学習装置を提供することである。
本発明の回路構成最適化装置では、FPGAデバイスにおけるソフトエラーの発生回数をFPGAデバイス上の位置と関連付けて記憶し、記憶したソフトエラーの発生回数と、FPGAデバイスの処理速度、発熱量、消費電力等を含むFPGAデバイスのエラー発生状態に係るデータを収集し、これらを状態データとした機械学習を行うことにより、FPGAデバイスの安定した動作が得られる最適な回路構成を導出できるようにする。
そして、本発明の一態様は、FPGAデバイスの回路構成と配置の最適化を行う回路構成最適化装置であって、前記FPGAデバイスの回路構成を学習する機械学習装置を備え、前記機械学習装置は、前記FPGAデバイスの回路構成を示すFPGAデバイスの回路構成データ、及び前記FPGAデバイスのエラー発生状態を示すFPGAエラー発生状態データを、環境の現在状態を表す状態変数として観測する状態観測部と、前記FPGAデバイス動作状態の適否判定結果を示す判定データを取得する判定データ取得部と、前記状態変数と前記判定データとを用いて、前記FPGAデバイスの回路構成を前記FPGAエラー発生状態データと関連付けて学習する学習部と、を備える回路構成最適化装置である。
本発明の他の態様は、FPGAデバイスの回路構成を学習する機械学習装置であって、前記FPGAデバイスの回路構成を示すFPGAデバイスの回路構成データ、及び前記FPGAデバイスのエラー発生状態を示すFPGAエラー発生状態データを、環境の現在状態を表す状態変数として観測する状態観測部と、前記FPGAデバイス動作状態の適否判定結果を示す判定データを取得する判定データ取得部と、前記状態変数と前記判定データとを用いて、前記FPGAデバイスの回路構成を前記FPGAエラー発生状態データと関連付けて学習する学習部と、を備える機械学習装置である。
本発明により、学習結果に基づいてFPGAデバイスの回路構成を決定することで、FPGAデバイスの誤動作する頻度を低減させ、FPGAデバイスを搭載した装置の稼働率を向上させることができる。
第1の実施形態による回路構成最適化装置の概略的な機能ブロック図である。 回路構成データS1を例示する図である。 回路構成最適化装置の一形態を示す概略的な機能ブロック図である。 機械学習方法の一形態を示す概略的なフローチャートである。 ニューロンを説明する図である。 ニューラルネットワークを説明する図である。 第2の実施形態による回路構成最適化装置の概略的な機能ブロック図である。 回路構成最適化装置を組み込んだシステムの一形態を示す概略的な機能ブロック図である。 回路構成最適化装置を組み込んだシステムの他の形態を示す概略的な機能ブロック図である。 FPGAデバイスの概略構造図である。
以下、本発明の実施形態を図面と共に説明する。
図1は、第1の実施形態による回路構成最適化装置10の概略的な機能ブロック図である。回路構成最適化装置10は、例えば、機械(図示せず)に搭載されたFPGAデバイスを再構成(リコンフィギュア)するためのシステム(図示せず)の一部として実装することができる。回路構成最適化装置10は、FPGAデバイス内に配置される回路の回路構成最適値を、いわゆる機械学習により自ら学習するためのソフトウェア(学習アルゴリズム等)及びハードウェア(コンピュータのCPU等)を含む機械学習装置20を備える。回路構成最適化装置10が備える機械学習装置20が学習する回路構成最適値は、FPGAデバイスのエラー発生状態に係る情報と、FPGAデバイスの回路構成との、相関性を表すモデル構造に相当する。
図1に機能ブロックで示すように、回路構成最適化装置10が備える機械学習装置20は、FPGAデバイスのエラー発生に係る状態に対して設定されたFPGAデバイスの回路構成を示す回路構成データS1と、FPGAデバイスのエラー発生に係る状態を示すFPGAエラー発生状態データS2を含む環境の現在状態を表す状態変数Sとして観測する状態観測部22と、設定されたFPGAデバイスの回路構成の元でのFPGAデバイスの動作状態の適否判定結果を示す判定データDを取得する判定データ取得部24と、状態変数Sと判定データDとを用いて、回路構成データS1にFPGAエラー発生状態データS2を関連付けて学習する学習部26とを備える。
状態観測部22は、例えばコンピュータのCPUの一機能として構成できる。或いは状態観測部22は、例えばコンピュータのCPUを機能させるためのソフトウェアとして構成できる。状態観測部22が観測する状態変数Sのうち、回路構成データS1は、例えば熟練した回路設計者により申告されて回路構成最適化装置10に与えられるFPGAデバイスの回路構成の申告データを用いたり、FPGAデバイスを再構成するシステムから取得したFPGAデバイスの回路構成に係るデータなどを用いたりすることができる。
回路構成データS1は、一例として、FPGAデバイスの各位置に配置される論理回路、及び各論理回路の種類を用いることができる。このようにする場合、FPGAデバイスの各位置に配置される論理回路については、例えば図2に示すように、FPGAデバイス上の領域をm×nのマトリクス状に分割した部分領域を配列として表現し、各配列の要素として論理回路のいずれを配置したのかを当該論理回路の識別子を当て嵌めることにより表現することができる。また、論理回路の種類については、通常の論理回路、面積を縮小した論理回路(全体を小機能化する代わりに面積を縮小することでソフトエラー率を低下させた論理回路)、多重化論理回路(論理回路を多重化することによりソフトエラー率を低下させた論理回路、論理回路の面積が増加する)、エラー訂正回路付論理回路(論理回路にECCなどのエラー訂正回路を負荷することによりソフトエラー率を低下させた論理回路、動作速度が低下し、発熱量及び商品電力が増加する)などの論理回路の構成方法の種類を識別子で表現したものとすれば良い。
また、状態変数Sのうち、FPGAエラー発生状態データS2は、例えばFPGAデバイスのエラー検出手段(図示せず)が検出した値を用いることができる。FPGAエラー発生状態データS2は、一例として、FPGAデバイスの各位置におけるソフトエラーの発生頻度を用いることができる。このようにする場合、例えばFPGAデバイス上の領域をm×nのマトリクス状に分割した部分領域毎に、ソフトエラーの発生履歴を回路構成最適化装置10のメモリ(図示せず)に記憶しておき、該履歴情報に基づいて算出したFPGAデバイスの部分領域毎のソフトエラーの発生頻度を算出し、これを用いるようにすれば良い。FPGAエラー発生状態データS2は、エラー検出手段がFPGAデバイス上でソフトエラーが発生した位置(部分領域)を特定できるのであれば、当該部分領域でのエラー発生頻度を更新し、エラー検出手段がFPGAデバイス上でのいずれの論理回路でソフトエラーが発生したのかを特定できるのであれば、当該ソフトエラーが発生した論理回路が配置されている全ての部分領域におけるエラーの発生頻度を更新するようにすれば良い。ソフトエラーの発生頻度を算出するための履歴情報は、FPGAデバイス上の論理回路の再構成が為される度にメモリ上の退避領域に(1サイクル前のソフトエラーの履歴情報として)バックアップして、新たに履歴情報を記録するようにする。
判定データ取得部24は、例えばコンピュータのCPUの一機能として構成できる。或いは判定データ取得部24は、例えばコンピュータのCPUを機能させるためのソフトウェアとして構成できる。判定データ取得部24が取得する判定データDは、FPGAデバイス上の回路が再構成された後で、例えば上記したFPGAデバイスの部分領域毎の新たに記録された履歴情報(すなわち、FPGAデバイスの再構成後に記憶された履歴情報)に基づいて算出されるエラー発生頻度を用いることができ、また、必要に応じて、FPGAデバイスが搭載された装置内に設けられた熱センサ等により実測されたFPGAデバイスの発熱量、消費電力計などにより実測されたFPGAデバイスの消費電力量、タイマ等により実測されたFPGAデバイスの動作時間などを用いることもできる。判定データDは、状態変数Sの下でのFPGAデバイスを動作させた時の結果を表す指標である。
このように、回路構成最適化装置10が備える機械学習装置20が学習を進める間、環境においては、FPGAエラー発生状態データS2の取得、FPGAデバイス上の論理回路の再構成、センサなどによる判定データDの取得が繰り返し実施される。
学習部26は、例えばコンピュータのCPUの一機能として構成できる。或いは学習部26は、例えばコンピュータのCPUを機能させるためのソフトウェアとして構成できる。学習部26は、機械学習と総称される任意の学習アルゴリズムに従い、FPGAデバイスの回路構成を学習する。学習部26は、FPGAデバイスの回路構成に対して、前述した状態変数Sと判定データDとを含むデータ集合に基づく学習を反復実行することができる。FPGAデバイスの再構成に対する学習サイクルの反復中、状態変数Sのうち、FPGAエラー発生状態データS2は、上記したバックアップされた1サイクル前のソフトエラーの履歴情報に基づいて算出されたソフトエラーの発生頻度とし、発生頻度回路構成データS1は、前回までの学習サイクルで得たFPGAデバイスの回路構成とし、また判定データDは、当該FPGAデバイスの回路構成の元でのFPGAデバイスの動作状態に対する適否判定結果とする。
このような学習サイクルを繰り返すことにより、学習部26は、FPGAデバイスのエラー発生状態(FPGAエラー発生状態データS2)とFPGAデバイスの回路構成との相関性を暗示する特徴を自動的に識別することができる。学習アルゴリズムの開始時にはFPGAエラー発生状態データS2とFPGAデバイスの回路構成との相関性は実質的に未知であるが、学習部26は、学習を進めるに従い徐々に特徴を識別して相関性を解釈する。FPGAエラー発生状態データS2とFPGAデバイスの回路構成との相関性が、ある程度信頼できる水準まで解釈されると、学習部26が反復出力する学習結果は、現在状態(つまりFPGAデバイスのエラー発生状態)に対してどのようなFPGAデバイスの回路構成とするべきかと言う行動の選択(つまり意思決定)を行うために使用できるものとなる。つまり学習部26は、学習アルゴリズムの進行に伴い、FPGAデバイスのエラー発生状態と、当該状態に対してどのようなFPGAデバイスの回路構成とするべきかという行動との、相関性を最適解に徐々に近づけることができる。
上記したように、回路構成最適化装置10が備える機械学習装置20は、状態観測部22が観測した状態変数Sと判定データ取得部24が取得した判定データDとを用いて、学習部26が機械学習アルゴリズムに従い、FPGAデバイスの回路構成を学習するものである。状態変数Sは、回路構成データS1及びFPGAエラー発生状態データS2といった、外乱の影響を受け難いデータで構成され、また判定データDは、FPGAデバイスが搭載された装置内に設けられた熱センサ等により実測されたFPGAデバイスの発熱量、消費電力計などにより実測されたFPGAデバイスの消費電力量、タイマ等により実測されたFPGAデバイスの動作時間、上記したFPGAデバイスの部分領域毎のエラー発生頻度などを取得することにより一義的に求められる。したがって、回路構成最適化装置10が備える機械学習装置20によれば、学習部26の学習結果を用いることで、FPGAデバイスのエラー発生状態に応じた、FPGAデバイスの回路構成を、演算や目算によらずに自動的に、しかも正確に求めることができるようになる。
FPGAデバイスの回路構成を、演算や目算によらずに自動的に求めることができれば、FPGAデバイスのエラー発生状態(FPGAエラー発生状態データS2)を把握するだけで、適切なFPGAデバイスの回路構成を迅速に決定することができる。したがって、FPGAデバイスの回路の再構成を効率よく行うことができる。
回路構成最適化装置10が備える機械学習装置20の一変形例として、状態観測部22は、状態変数Sとして、FPGAデバイスが搭載された装置内に設けられた熱センサ等により実測されたFPGAデバイスの発熱量、消費電力計などにより実測されたFPGAデバイスの消費電力量、タイマ等により実測されたFPGAデバイスの動作時間等を含むFPGA動作状態データS3を更に観測することができる。このようにする場合、該FPGAデバイスの回路構成を、FPGAエラー発生状態データS2に加えて、FPGA動作状態データS3の双方と関連付けて学習することができる。
上記変形例によれば、機械学習装置20は、FPGAデバイスの回路を再構成する際に、該FPGAデバイスの部分領域毎のエラー発生頻度だけでなく、FPGAデバイスの発熱量や消費電力量、動作速度などを考慮に入れたFPGAデバイスの回路構成を学習することができる。このようにすることで、あるエラー発生状態において、当該エラー発生状態に対してエラーの発生頻度を低減させるFPGAデバイスの回路構成が複数考えられる場合に、より発熱量が低い、より消費電力が低い、又はより動作速度の速いFPGAデバイスの回路構成を優先して選択することができるようになる。
回路構成最適化装置10が備える機械学習装置20の他の変形例として、学習部26は、同一の論理回路が構成されたFPGAデバイスを搭載した複数の装置のそれぞれについて得られた状態変数S及び判定データDを用いて、それら装置におけるFPGAデバイスの回路構成を学習することができる。この構成によれば、一定時間で得られる状態変数Sと判定データDとを含むデータ集合の量を増加できるので、より多様なデータ集合を入力として、FPGAデバイスの回路構成の学習の速度や信頼性を向上させることができる。
上記構成を有する機械学習装置20では、学習部26が実行する学習アルゴリズムは特に限定されず、機械学習として公知の学習アルゴリズムを採用できる。図3は、図1に示す回路構成最適化装置10の一形態であって、学習アルゴリズムの一例として強化学習を実行する学習部26を備えた構成を示す。強化学習は、学習対象が存在する環境の現在状態(つまり入力)を観測するとともに現在状態で所定の行動(つまり出力)を実行し、その行動に対し何らかの報酬を与えるというサイクルを試行錯誤的に反復して、報酬の総計が最大化されるような方策(本願の機械学習装置ではFPGAデバイスの回路構成)を最適解として学習する手法である。
図3に示す回路構成最適化装置10が備える機械学習装置20において、学習部26は、状態変数Sに基づいてFPGAデバイスの動作状態の適否判定結果(次の学習サイクルで用いられる判定データDに相当)に関連する報酬Rを求める報酬計算部28と、報酬Rを用いて、FPGAデバイスの回路構成の価値を表す関数Qを更新する価値関数更新部30とを備える。学習部26は、価値関数更新部30が関数Qの更新を繰り返すことによってFPGAデバイスのエラー発生状態に対するFPGAデバイスの回路構成を学習する。
学習部26が実行する強化学習のアルゴリズムの一例を説明する。この例によるアルゴリズムは、Q学習(Q−learning)として知られるものであって、行動主体の状態sと、その状態sで行動主体が選択し得る行動aとを独立変数として、状態sで行動aを選択した場合の行動の価値を表す関数Q(s,a)を学習する手法である。状態sで価値関数Qが最も高くなる行動aを選択することが最適解となる。状態sと行動aとの相関性が未知の状態でQ学習を開始し、任意の状態sで種々の行動aを選択する試行錯誤を繰り返すことで、価値関数Qを反復して更新し、最適解に近付ける。ここで、状態sで行動aを選択した結果として環境(つまり状態s)が変化したときに、その変化に応じた報酬(つまり行動aの重み付け)rが得られるように構成し、より高い報酬rが得られる行動aを選択するように学習を誘導することで、価値関数Qを比較的短時間で最適解に近付けることができる。
価値関数Qの更新式は、一般に下記の数1式のように表すことができる。数1式において、st及びatはそれぞれ時刻tにおける状態及び行動であり、行動atにより状態はst+1に変化する。rt+1は、状態がstからst+1に変化したことで得られる報酬である。maxQの項は、時刻t+1で最大の価値Qになる(と時刻tで考えられている)行動aを行ったときのQを意味する。α及びγはそれぞれ学習係数及び割引率であり、0<α≦1、0<γ≦1で任意設定される。
Figure 2018180951
学習部26がQ学習を実行する場合、状態観測部22が観測した状態変数S及び判定データ取得部24が取得した判定データDは、更新式の状態sに該当し、現在状態(つまりFPGAデバイスのエラー発生状態)に対するFPGAデバイスの回路構成をどのように変更するべきかという行動は、更新式の行動aに該当し、報酬計算部28が求める報酬Rは、更新式の報酬rに該当する。よって価値関数更新部30は、現在状態に対するFPGAデバイスの回路構成の価値を表す関数Qを、報酬Rを用いたQ学習により繰り返し更新する。
報酬計算部28が求める報酬Rは、例えば、FPGAデバイスの回路構成を決定した後に該FPGAデバイスの回路構成に基づいてFPGAデバイスを動作させたときに、該FPGAデバイスの動作状態が「適」と判定される場合(例えば、FPGAデバイスの各部分領域におけるソフトエラー発生頻度が許容できる範囲内の場合、FPGAデバイスの発熱量が許容できる範囲内の場合、FPGAデバイスの消費電力量が許容できる範囲内の場合、FPGAデバイスの動作速度が許容できる範囲内の場合、など)に正(プラス)の報酬Rとし、FPGAデバイスの回路構成を決定した後に該FPGAデバイスの回路構成に基づいてFPGAデバイスを動作させたときに、該FPGAデバイスの動作状態が「否」と判定される場合(例えば、FPGAデバイスの各部分領域におけるソフトエラー発生頻度が許容できる範囲外の場合、FPGAデバイスの発熱量が許容できる範囲外の場合、FPGAデバイスの消費電力量が許容できる範囲外の場合、FPGAデバイスの動作速度が許容できる範囲外の場合、など)に負(マイナス)の報酬Rとすることができる。正負の報酬Rの絶対値は、互いに同一であっても良いし異なっていても良い。また、判定の条件として、判定データDに含まれる複数の値を組み合わせて判定するようにしても良い。更に、FPGAデバイスの各部分領域におけるソフトエラー発生頻度についての報酬を求める際には、報酬計算部28は、各部分領域におけるソフトエラー発生頻度の最大値や上位の所定の部分領域のソフトエラー発生頻度の平均値等の統計地を用いて適否の判定をするようにしても良い。
また、FPGAデバイスの動作状態の適否判定結果を、「適」及び「否」の二通りだけでなく複数段階に設定することができる。例として、FPGAデバイスの発熱量の許容範囲の最大値がTmaxの場合、FPGAデバイスの発熱量Tが、0≦T<Tmax/5のときは報酬R=5を与え、Tmax/5≦T<Tmax/2のときは報酬R=2を与え、Tmax/2≦T≦Tmaxのときは報酬R=1を与えるような構成とすることができる。さらに、学習の初期段階はTmaxを比較的大きく設定し、学習が進行するにつれてTmaxを縮小する構成とすることもできる。
なお、学習部26が学習した結果に基づいてFPGAデバイスの回路構成を決定した際に、該決定した回路構成に基づいてFPGAデバイスを再構成しようとしてもエラーとなる場合がある(論理回路を構成する面積が足りない、配線ができないなど)。このような場合に、再び同じ状態に対するFPGAデバイスの回路構成の決定し直しが行われるが、その前に、報酬計算部28が求める報酬Rを大きな負(マイナス)の報酬Rとして学習を進めておく。このようにすることで、次サイクル以降では同じ状態において当該回路構成が選択されることがなくなる。
価値関数更新部30は、状態変数Sと判定データDと報酬Rとを、関数Qで表される行動価値(例えば数値)と関連付けて整理した行動価値テーブルを持つことができる。この場合、価値関数更新部30が関数Qを更新するという行為は、価値関数更新部30が行動価値テーブルを更新するという行為と同義である。Q学習の開始時には環境の現在状態とFPGAデバイスの回路構成との相関性は未知であるから、行動価値テーブルにおいては、種々の状態変数Sと判定データDと報酬Rとが、無作為に定めた行動価値の値(関数Q)と関連付けた形態で用意されている。なお報酬計算部28は、判定データDがわかればこれ対応する報酬Rを直ちに算出でき、算出した値Rが行動価値テーブルに書き込まれる。
FPGAデバイスの動作状態の適否判定結果に応じた報酬Rを用いてQ学習を進めると、より高い報酬Rが得られる行動を選択する方向へ学習が誘導され、選択した行動を現在状態で実行した結果として変化する環境の状態(つまり状態変数S及び判定データD)に応じて、現在状態で行う行動についての行動価値の値(関数Q)が書き換えられて行動価値テーブルが更新される。この更新を繰り返すことにより、行動価値テーブルに表示される行動価値の値(関数Q)は、適正な行動ほど大きな値となるように書き換えられる。このようにして、未知であった環境の現在状態(FPGAデバイスのエラー発生状態)とそれに対する行動(FPGAデバイスの回路構成の決定)との相関性が徐々に明らかになる。つまり行動価値テーブルの更新により、FPGAデバイスのエラー発生状態と、FPGAデバイスの回路構成との関係が最適解に徐々に近づけられる。
図4を参照して、学習部26が実行する上記したQ学習のフロー(つまり機械学習方法の一形態)をさらに説明する。まずステップSA01で、価値関数更新部30は、その時点での行動価値テーブルを参照しながら、状態観測部22が観測した状態変数Sが示す現在状態で行う行動としてFPGAデバイスの回路構成を無作為に選択する。次に価値関数更新部30は、ステップSA02で、状態観測部22が観測している現在状態の状態変数Sを取り込み、ステップSA03で、判定データ取得部24が取得している現在状態の判定データDを取り込む。次に価値関数更新部30は、ステップSA04で、判定データDに基づき、FPGAデバイスの回路構成が適当であったか否かを判断し、適当であった場合、ステップSA05で、報酬計算部28が求めた正の報酬Rを関数Qの更新式に適用し、次いでステップSA06で、現在状態における状態変数S及び判定データDと報酬Rと行動価値の値(更新後の関数Q)とを用いて行動価値テーブルを更新する。ステップSA04で、FPGAデバイスの回路構成が適当でなかったと判断した場合、ステップSA07で、報酬計算部28が求めた負の報酬Rを関数Qの更新式に適用し、次いでステップSA06で、現在状態における状態変数S及び判定データDと報酬Rと行動価値の値(更新後の関数Q)とを用いて行動価値テーブルを更新する。学習部26は、ステップSA01〜SA07を繰り返すことで行動価値テーブルを反復して更新し、FPGAデバイスの回路構成の学習を進行させる。なお、ステップSA04からステップSA07までの報酬Rを求める処理及び価値関数の更新処理は、判定データDに含まれるそれぞれのデータについて実行される。
前述した強化学習を進める際に、例えばQ学習の代わりに、ニューラルネットワークを用いることができる。図5Aは、ニューロンのモデルを模式的に示す。図5Bは、図5Aに示すニューロンを組み合わせて構成した三層のニューラルネットワークのモデルを模式的に示す。ニューラルネットワークは、例えば、ニューロンのモデルを模した演算装置や記憶装置等によって構成できる。
図5Aに示すニューロンは、複数の入力x(ここでは一例として、入力x1〜入力x3)に対する結果yを出力するものである。各入力x1〜x3には、この入力xに対応する重みw(w1〜w3)が掛けられる。これにより、ニューロンは、次の数2式により表現される出力yを出力する。なお、数2式において、入力x、出力y及び重みwは、すべてベクトルである。また、θはバイアスであり、fkは活性化関数である。
Figure 2018180951
図5Bに示す三層のニューラルネットワークは、左側から複数の入力x(ここでは一例として、入力x1〜入力x3)が入力され、右側から結果y(ここでは一例として、結果y1〜結果y3)が出力される。図示の例では、入力x1、x2、x3のそれぞれに対応の重み(総称してw1で表す)が乗算されて、個々の入力x1、x2、x3がいずれも3つのニューロンN11、N12、N13に入力されている。
図5Bでは、ニューロンN11〜N13の各々の出力を、総称してz1で表す。z1は、入力ベクトルの特徴量を抽出した特徴ベクトルと見なすことができる。図示の例では、特徴ベクトルz1のそれぞれに対応の重み(総称してW2で表す)が乗算されて、個々の特徴ベクトルz1がいずれも2つのニューロンN21、N22に入力されている。特徴ベクトルz1は、重みW1と重みW2との間の特徴を表す。
図5Bでは、ニューロンN21〜N22の各々の出力を、総称してz2で表す。z2は、特徴ベクトルz1の特徴量を抽出した特徴ベクトルと見なすことができる。図示の例では、特徴ベクトルz2のそれぞれに対応の重み(総称してW3で表す)が乗算されて、個々の特徴ベクトルz2がいずれも3つのニューロンN31、N32、N33に入力されている。特徴ベクトルz2は、重みW2と重みW3との間の特徴を表す。最後にニューロンN31〜N33は、それぞれ結果y1〜y3を出力する。
なお、三層以上の層を為すニューラルネットワークを用いた、いわゆるディープラーニングの手法を用いることも可能である。
回路構成最適化装置10が備える機械学習装置20においては、状態変数Sと判定データDとを入力xとして、学習部26が上記したニューラルネットワークに従う多層構造の演算を行うことで、FPGAデバイスの回路構成(結果y)を出力することができる。なおニューラルネットワークの動作モードには、学習モードと価値予測モードとがあり、例えば学習モードで学習データセットを用いて重みWを学習し、学習した重みWを用いて価値予測モードで行動の価値判断を行うことができる。なお価値予測モードでは、検出、分類、推論等を行うこともできる。
上記した回路構成最適化装置10の構成は、コンピュータのCPUが実行する機械学習方法(或いはソフトウェア)として記述できる。この機械学習方法は、FPGAデバイスの回路構成を学習する機械学習方法であって、コンピュータのCPUが、FPGAデバイスの回路構成を示す回路構成データS1、及びFPGAデバイスのエラー発生状態を示すFPGAエラー発生状態データS2を、FPGAデバイスが動作する環境の現在状態を表す状態変数Sとして観測するステップと、FPGAデバイスの動作状態の適否判定結果を示す判定データDを取得するステップと、状態変数Sと判定データDとを用いて、FPGAデバイスの回路構成とFPGAエラー発生状態データS2とを関連付けて学習するステップとを有する。
図6は、第2の実施形態による回路構成最適化装置40を示す。回路構成最適化装置40は、機械学習装置50と、状態観測部22が観測する状態変数Sの回路構成データS1及びFPGAエラー発生状態データS2を状態データS0として取得する状態データ取得部42とを備える。状態データ取得部42が取得する状態データS0は、FPGA動作状態データS3を含むこともできる。状態データ取得部42は、装置が備える各種センサや、前述したエラー検出装置、作業者による適宜のデータ入力等から、状態データS0を取得することができる。
回路構成最適化装置40が有する機械学習装置50は、FPGAデバイスの回路構成を機械学習により自ら学習するためのソフトウェア(学習アルゴリズム等)及びハードウェア(コンピュータのCPU等)に加えて、学習したFPGAデバイスの回路構成をFPGAデバイスの回路構成を再構成するシステム(図示せず)への指令として出力するためのソフトウェア(演算アルゴリズム等)及びハードウェア(コンピュータのCPU等)を含むものである。回路構成最適化装置40が含む機械学習装置50は、1つの共通のCPUが、学習アルゴリズム、演算アルゴリズム等の全てのソフトウェアを実行する構成を有することもできる。
意思決定部52は、例えばコンピュータのCPUの一機能として構成できる。或いは意思決定部52は、例えばコンピュータのCPUを機能させるためのソフトウェアとして構成できる。意思決定部52は、学習部26が学習したFPGAデバイスのエラー発生状態に対するFPGAデバイスの回路構成に基づいてFPGAデバイスの回路の再構成に係る指令値Cを生成し、生成した指令値Cとして出力する。意思決定部52がFPGAデバイスの回路の再構成に係る指令値CをFPGAデバイスの回路構成を再構成するシステムに対して出力した場合、これに応じて、環境の状態(回路構成データS1)が変化する。
状態観測部22は、意思決定部52による環境へのFPGAデバイスの回路の再構成に係る指令値Cを出力した後に変化した回路構成データS1を含む状態変数Sを次の学習サイクルにおいて観測する。学習部26は、変化した状態変数Sを用いて、例えば価値関数Q(すなわち行動価値テーブル)を更新することで、FPGAデバイスの回路構成を学習する。意思決定部52は、学習したFPGAデバイスの回路構成の下で状態変数Sに応じてFPGAデバイスの回路の再構成に係る指令値CをFPGAデバイスの回路構成を再構成するシステムへと出力する。このサイクルを繰り返すことにより、機械学習装置50はFPGAデバイスの回路構成の学習を進め、自身が決定するFPGAデバイスの回路構成の信頼性を徐々に向上させる。
上記構成を有する回路構成最適化装置40が備える機械学習装置50は、前述した機械学習装置20と同等の効果を奏する。特に機械学習装置50は、意思決定部52の出力によって環境の状態を変化させることができる。他方、機械学習装置20では、学習部26の学習結果を環境に反映させるための意思決定部に相当する機能を、外部装置に求めることができる。
図7は、産業機械60を備えた一実施形態によるシステム70を示す。システム70は、少なくとも同一の機械構成を有する複数の産業機械60、60’と、それら産業機械60、60’を互いに接続する有線/無線のネットワーク72とを備え、複数の産業機械60、60’のうち少なくとも1つが、上記した回路構成最適化装置40を備える産業機械60として構成される。またシステム70は、回路構成最適化装置40を備えない産業機械60’を含むことができる。産業機械60、60’は、同じ目的で構成された論理回路が内部に構成されるFPGAデバイスが搭載されると共に、該FPGAデバイスの回路を再構成するための構成を有する。
上記構成を有するシステム70は、複数の産業機械60、60’のうちで回路構成最適化装置40を備える産業機械60が、学習部26の学習結果を用いて、FPGAデバイスのエラー発生状態に応じたFPGAデバイスの回路構成を、演算や目算によらずに自動的に、しかも正確に求めることができる。また、少なくとも1つの産業機械60の回路構成最適化装置40が、他の複数の産業機械60、60’のそれぞれについて得られた状態変数S及び判定データDに基づき、全ての産業機械60、60’に共通するFPGAデバイスの回路構成を学習し、その学習結果を全ての産業機械60、60’が共有するように構成できる。したがってシステム70によれば、より多様なデータ集合(状態変数S及び判定データDを含む)を入力として、FPGAデバイスの回路構成の学習の速度や信頼性を向上させることができる。
図8は、産業機械60’を備えた他の実施形態によるシステム70’を示す。システム70’は、機械学習装置50(又は20)と、同一の機械構成を有する複数の産業機械60’と、それら産業機械60’と機械学習装置50(又は20)とを互いに接続する有線/無線のネットワーク72とを備える。
上記構成を有するシステム70’は、機械学習装置50(又は20)が、複数の産業機械60’のそれぞれについて得られた状態変数S及び判定データDに基づき、全ての産業機械60’に共通するFPGAデバイスのエラー発生状態に応じたFPGAデバイスの回路構成を学習し、その学習結果を用いて、FPGAデバイスのエラー発生状態に応じたFPGAデバイスの回路構成を、演算や目算によらずに自動的に、しかも正確に求めることができる。
システム70’は、機械学習装置50(又は20)が、ネットワーク72に用意されたクラウドサーバ等に存在する構成を有することができる。この構成によれば、複数の産業機械60’のそれぞれが存在する場所や時期に関わらず、必要なときに必要な数の産業機械60’を機械学習装置50(又は20)に接続することができる。
システム70、70’に従事する作業者は、機械学習装置50(又は20)による学習開始後の適当な時期に、機械学習装置50(又は20)によるFPGAデバイスの回路構成の学習の到達度(すなわちFPGAデバイスの回路構成の信頼性)が要求レベルに達したか否かの判断を実行することができる。
以上、本発明の実施の形態について説明したが、本発明は上述した実施の形態の例のみに限定されることなく、適宜の変更を加えることにより様々な態様で実施することができる。
例えば、機械学習装置20,50が実行する学習アルゴリズム、機械学習装置50が実行する演算アルゴリズム、回路構成最適化装置10、40が実行する制御アルゴリズム等は、上述したものに限定されず、様々なアルゴリズムを採用できる。
また、上記した実施形態では回路構成最適化装置10,40の上で機械学習装置20,50がオンラインで機械学習する例を示しているが、FPGAデバイスの運用時に状態データSや判定データDをログデータとして記録しておき、記録したログデータを収集して、収集したログデータから取得した状態データSや判定データDに基づいて機械学習装置20,50が機械学習するようにしても良い。
10,40 回路構成最適化装置
20,50 機械学習装置
22 状態観測部
24 判定データ取得部
26 学習部
28 報酬計算部
30 価値関数更新部
42 状態データ取得部
52 意思決定部
60,60’ 産業機械
70,70’ システム
72 ネットワーク

Claims (8)

  1. FPGAデバイスの回路構成と配置の最適化を行う回路構成最適化装置であって、
    前記FPGAデバイスの回路構成を学習する機械学習装置を備え、
    前記機械学習装置は、
    前記FPGAデバイスの回路構成を示すFPGAデバイスの回路構成データ、及び前記FPGAデバイスのエラー発生状態を示すFPGAエラー発生状態データを、環境の現在状態を表す状態変数として観測する状態観測部と、
    前記FPGAデバイス動作状態の適否判定結果を示す判定データを取得する判定データ取得部と、
    前記状態変数と前記判定データとを用いて、前記FPGAデバイスの回路構成を前記FPGAエラー発生状態データと関連付けて学習する学習部と、
    を備える回路構成最適化装置。
  2. 前記状態観測部は、前記状態変数として、前記FPGAデバイスの発熱量、消費電力及び動作速度の少なくともいずれかを含むFPGAデバイス動作状態データを更に観測し、
    前記学習部は、前記FPGAデバイスの回路構成を前記FPGAエラー発生状態データと前記FPGAデバイス動作状態データの双方と関連付けて学習する、
    請求項1に記載の回路構成最適化装置。
  3. 前記学習部は、
    前記適否判定結果に関連する報酬を求める報酬計算部と、
    前記報酬を用いて、前記FPGAデバイスのエラー発生状態に対する前記FPGAデバイスの回路構成の価値を表す関数を更新する価値関数更新部とを備える、
    請求項1または2に記載の回路構成最適化装置。
  4. 前記学習部は、前記状態変数と前記判定データとを多層構造で演算する、
    請求項1〜3のいずれか1つに記載の回路構成最適化装置。
  5. 前記学習部による学習結果に基づいて、前記FPGAデバイスの回路構成に基づく指令値を出力する意思決定部を更に備える、
    請求項1〜4のいずれか1つに記載の回路構成最適化装置。
  6. 前記学習部は、複数の産業機械のそれぞれについて得られた前記状態変数及び前記判定データを用いて、該複数の産業機械のそれぞれにおける前記FPGAデバイスの回路構成を学習する、
    請求項1〜5のいずれか1つに記載の回路構成最適化装置。
  7. 前記機械学習装置は、クラウドサーバに存在する、
    請求項1〜6のいずれか1つに記載の回路構成最適化装置。
  8. FPGAデバイスの回路構成を学習する機械学習装置であって、
    前記FPGAデバイスの回路構成を示すFPGAデバイスの回路構成データ、及び前記FPGAデバイスのエラー発生状態を示すFPGAエラー発生状態データを、環境の現在状態を表す状態変数として観測する状態観測部と、
    前記FPGAデバイス動作状態の適否判定結果を示す判定データを取得する判定データ取得部と、
    前記状態変数と前記判定データとを用いて、前記FPGAデバイスの回路構成を前記FPGAエラー発生状態データと関連付けて学習する学習部と、
    を備える機械学習装置。
JP2017079851A 2017-04-13 2017-04-13 回路構成最適化装置及び機械学習装置 Expired - Fee Related JP6502998B2 (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP2017079851A JP6502998B2 (ja) 2017-04-13 2017-04-13 回路構成最適化装置及び機械学習装置
DE102018002781.4A DE102018002781B4 (de) 2017-04-13 2018-04-06 Schaltungskonfigurations-Optimierungsvorrichtung und maschinelle Lernvorrichtung
US15/947,835 US10565343B2 (en) 2017-04-13 2018-04-08 Circuit configuration optimization apparatus and machine learning device
CN201810326636.3A CN108736881B (zh) 2017-04-13 2018-04-12 电路结构最优化装置以及机器学习装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2017079851A JP6502998B2 (ja) 2017-04-13 2017-04-13 回路構成最適化装置及び機械学習装置

Publications (2)

Publication Number Publication Date
JP2018180951A true JP2018180951A (ja) 2018-11-15
JP6502998B2 JP6502998B2 (ja) 2019-04-17

Family

ID=63678824

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017079851A Expired - Fee Related JP6502998B2 (ja) 2017-04-13 2017-04-13 回路構成最適化装置及び機械学習装置

Country Status (4)

Country Link
US (1) US10565343B2 (ja)
JP (1) JP6502998B2 (ja)
CN (1) CN108736881B (ja)
DE (1) DE102018002781B4 (ja)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6546213B2 (ja) * 2017-04-13 2019-07-17 ファナック株式会社 回路構成最適化装置及び機械学習装置
US11194947B2 (en) * 2017-09-27 2021-12-07 Intel Corporation Systems and methods for region-based error detection and management in integrated circuits
WO2020188397A1 (ja) * 2019-03-20 2020-09-24 株式会社半導体エネルギー研究所 配線レイアウト設計方法、プログラム、および記録媒体
JP2020181105A (ja) * 2019-04-25 2020-11-05 キヤノン株式会社 投影装置およびその制御方法
CN112965854B (zh) * 2021-04-16 2022-04-29 吉林大学 一种提升卷积神经网络可靠性的方法、系统及设备

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0844581A (ja) * 1994-07-29 1996-02-16 Fujitsu Ltd 自己修復機能付き情報処理装置
JP2005243937A (ja) * 2004-02-26 2005-09-08 Fujitsu Ltd 集積回路装置設計方法、当該方法を実施可能なデータ処理装置及びプログラム
JP2014134842A (ja) * 2013-01-08 2014-07-24 Hitachi Ltd 検証装置及び検証方法
US20150100608A1 (en) * 2013-10-04 2015-04-09 Texas Instruments Incorporated Reconfiguring an asic at runtime
US20150161323A1 (en) * 2013-12-06 2015-06-11 Robert Bosch Gmbh Method for checking a hardware-configurable logic circuit for faults

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7620876B2 (en) 2005-06-08 2009-11-17 Altera Corporation Reducing false positives in configuration error detection for programmable devices
CN103902448A (zh) * 2012-12-28 2014-07-02 中国科学院深圳先进技术研究院 多核处理器软错误压力测试程序生成系统及方法
CN103365731B (zh) * 2013-06-28 2016-07-06 中国科学院计算技术研究所 一种降低处理器软错误率的方法和系统
US9805463B2 (en) * 2013-08-27 2017-10-31 Heartflow, Inc. Systems and methods for predicting location, onset, and/or change of coronary lesions
CN105786453B (zh) * 2014-12-16 2018-11-13 中国科学院沈阳自动化研究所 一种大规模plc安全参数序列保护模块和方法
JP2016167669A (ja) 2015-03-09 2016-09-15 富士通株式会社 プログラマブル論理回路装置及びそのエラー検出方法
JP6055058B1 (ja) * 2015-09-30 2016-12-27 ファナック株式会社 機械学習器及び組み立て・試験器を備えた生産設備
JP6110451B1 (ja) * 2015-09-30 2017-04-05 ファナック株式会社 機械学習装置およびコイル製造装置
JP6714690B2 (ja) 2016-04-26 2020-06-24 株式会社日立製作所 情報処理システム、情報処理システムの運用方法、および機械学習演算器

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0844581A (ja) * 1994-07-29 1996-02-16 Fujitsu Ltd 自己修復機能付き情報処理装置
JP2005243937A (ja) * 2004-02-26 2005-09-08 Fujitsu Ltd 集積回路装置設計方法、当該方法を実施可能なデータ処理装置及びプログラム
JP2014134842A (ja) * 2013-01-08 2014-07-24 Hitachi Ltd 検証装置及び検証方法
US20150100608A1 (en) * 2013-10-04 2015-04-09 Texas Instruments Incorporated Reconfiguring an asic at runtime
US20150161323A1 (en) * 2013-12-06 2015-06-11 Robert Bosch Gmbh Method for checking a hardware-configurable logic circuit for faults

Also Published As

Publication number Publication date
JP6502998B2 (ja) 2019-04-17
DE102018002781B4 (de) 2021-07-22
CN108736881B (zh) 2020-04-17
DE102018002781A1 (de) 2018-10-18
US10565343B2 (en) 2020-02-18
US20180300442A1 (en) 2018-10-18
CN108736881A (zh) 2018-11-02

Similar Documents

Publication Publication Date Title
JP6546213B2 (ja) 回路構成最適化装置及び機械学習装置
US10121107B2 (en) Machine learning device and method for optimizing frequency of tool compensation of machine tool, and machine tool having the machine learning device
JP6502998B2 (ja) 回路構成最適化装置及び機械学習装置
JP6502983B2 (ja) 洗浄工程最適化装置及び機械学習装置
KR102800576B1 (ko) 조립 라인을 위한 동적 훈련
US10949740B2 (en) Machine learning device, numerical controller, machine tool system, manufacturing system, and machine learning method for learning display of operation menu
US10782664B2 (en) Production system that sets determination value of variable relating to abnormality of product
CN117992743A (zh) 一种基于知识图谱的电网故障智能分析与处置方法及系统
JP5157359B2 (ja) 時系列データ解析装置、時系列データ解析システム、時系列データ解析装置の制御方法、プログラム、および記録媒体
JP6659652B2 (ja) 加工条件調整装置及び機械学習装置
JP6542833B2 (ja) 制御装置及び機械学習装置
JP6174649B2 (ja) ファンモータの予防保全機能を備えたモータ駆動装置
TW201837732A (zh) 金屬線放電加工機之控制裝置及機器學習裝置
US9952574B2 (en) Machine learning device, motor control system, and machine learning method for learning cleaning interval of fan motor
JP2018004473A (ja) 軸受の予測寿命を学習する機械学習装置、寿命予測装置および機械学習方法
CN106483931A (zh) 具备菜单的数值控制装置
JP6564426B2 (ja) 部品供給装置及び機械学習装置
JP6703020B2 (ja) 制御装置及び機械学習装置
JP2019082882A (ja) 試験装置及び機械学習装置
JP2018025932A (ja) センサと機械学習部を備えた作業管理システム
JP2018181217A (ja) 加減速制御装置
WO2020175084A1 (ja) 運営評価装置、運営評価方法、およびプログラム
JP2019016039A (ja) プロセスの異常状態診断方法および異常状態診断装置
CN110340884B (zh) 测定动作参数调整装置、机器学习装置以及系统
US20220326661A1 (en) Control device, method, program, and system

Legal Events

Date Code Title Description
A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20180809

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20181126

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20181211

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190208

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20190226

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20190322

R150 Certificate of patent or registration of utility model

Ref document number: 6502998

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

LAPS Cancellation because of no payment of annual fees