(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公表特許公報(A)
(11)【公表番号】
(43)【公表日】2024-02-28
(54)【発明の名称】人工ニューラルネットワークにおけるアナログニューラルメモリのための精密なデータチューニング方法及び装置
(51)【国際特許分類】
G06N 3/065 20230101AFI20240220BHJP
G06N 3/049 20230101ALI20240220BHJP
G11C 16/04 20060101ALI20240220BHJP
G11C 11/54 20060101ALI20240220BHJP
G06G 7/60 20060101ALI20240220BHJP
G11C 16/34 20060101ALI20240220BHJP
【FI】
G06N3/065
G06N3/049
G11C16/04 120
G11C11/54
G06G7/60
G11C16/34 140
【審査請求】有
【予備審査請求】未請求
(21)【出願番号】P 2023551164
(86)(22)【出願日】2021-05-19
(85)【翻訳文提出日】2023-10-19
(86)【国際出願番号】 US2021033122
(87)【国際公開番号】W WO2022182378
(87)【国際公開日】2022-09-01
(32)【優先日】2021-02-25
(33)【優先権主張国・地域又は機関】US
(81)【指定国・地域】
(71)【出願人】
【識別番号】500147506
【氏名又は名称】シリコン ストーリッジ テクノロージー インコーポレイテッド
【氏名又は名称原語表記】SILICON STORAGE TECHNOLOGY, INC.
(74)【代理人】
【識別番号】110000626
【氏名又は名称】弁理士法人英知国際特許商標事務所
(72)【発明者】
【氏名】トラン、ヒュー バン
(72)【発明者】
【氏名】レムケ、スティーブン
(72)【発明者】
【氏名】ドー、ナン
(72)【発明者】
【氏名】レイテン、マーク
【テーマコード(参考)】
5B225
【Fターム(参考)】
5B225BA02
5B225BA03
5B225CA01
5B225DB08
5B225EA01
5B225FA01
(57)【要約】
人工ニューラルネットワークにおけるベクトルマトリックス乗算(VMM)アレイ内の不揮発性メモリセルの浮遊ゲートに、正確な量の電荷を精密かつ迅速に堆積させるための精密プログラミングアルゴリズム及び装置の多数の実施形態が開示される。それにより、選択されたセルは、N個の異なる値のうちの1つを保持するために、極めて高い精度でプログラムすることができる。
【選択図】
図35B
【特許請求の範囲】
【請求項1】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、重み値wは、式w=(w+)-(w-)に従って、前記アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+及びw-は、非ゼロのオフセット値を含む、ニューラルネットワーク。
【請求項2】
前記非ゼロのオフセット値は、正の値である、請求項1に記載のニューラルネットワーク。
【請求項3】
前記非ゼロのオフセット値は、負の値である、請求項1に記載のニューラルネットワーク。
【請求項4】
wに対して0の値が所望されるとき、前記非ゼロのオフセット値に等しい値は、w+及びw-に対して記憶される、請求項1に記載のニューラルネットワーク。
【請求項5】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項1に記載のニューラルネットワーク。
【請求項6】
前記所定のスレッショルドは、5nAである、請求項5に記載のニューラルネットワーク。
【請求項7】
前記所定のスレッショルドは、10nAである、請求項5に記載のニューラルネットワーク。
【請求項8】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項1に記載のニューラルネットワーク。
【請求項9】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項1に記載のニューラルネットワーク。
【請求項10】
前記第1の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってw-にチューニングされる、請求項1に記載のニューラルネットワーク。
【請求項11】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、前記アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+及びw-値の記憶は、前記アレイ内の全ての列の間でほぼ均等に分散される、ニューラルネットワーク。
【請求項12】
前記非ゼロのオフセット値は、正の値である、請求項11に記載のニューラルネットワーク。
【請求項13】
前記非ゼロのオフセット値は、負の値である、請求項11に記載のニューラルネットワーク。
【請求項14】
0の値がwに対して所望されるとき、前記非ゼロのオフセット値に等しい値は、w+及びw-に対して記憶される、請求項11に記載のニューラルネットワーク。
【請求項15】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項11に記載のニューラルネットワーク。
【請求項16】
前記所定のスレッショルドは、5nAである、請求項15に記載のニューラルネットワーク。
【請求項17】
前記所定のスレッショルドは、10nAである、請求項15に記載のニューラルネットワーク。
【請求項18】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項11に記載のニューラルネットワーク。
【請求項19】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項11に記載のニューラルネットワーク。
【請求項20】
前記第1の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされる、請求項11に記載のニューラルネットワーク。
【請求項21】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルの差動対においてゼロ値をプログラミングし、検証し、及び読み出す方法であって、前記方法は、
前記差動対における第1のセルw+を第1の電流値にプログラムするステップと、
第1の電圧にバイアス電圧を加えたものに等しい電圧を前記第1のセルの制御ゲート端子に印加することによって、前記第1のセルを検証するステップと、
前記差動対における第2のセルw-を前記第1の電流値にプログラムするステップと、
前記第1の電圧に前記バイアス電圧を加えたものに等しい電圧を前記第2のセルの制御ゲート端子に印加することによって、前記第2のセルを検証するステップと、
前記第1の電圧に等しい電圧を前記第1のセルの前記制御ゲート端子に印加することによって、前記第1のセルを読み出すステップと、
前記第1の電圧に等しい電圧を前記第2のセルの前記制御ゲート端子に印加することによって、前記第2のセルを読み出すステップと、
式w=(w+)-(w-)に従って値wを計算するステップと、を含む、方法。
【請求項22】
前記第1のセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされ、前記第2のセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされる、請求項21に記載の方法。
【請求項23】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルの差動対においてゼロ値をプログラミングし、検証し、及び読み出す方法であって、前記方法は、
前記差動対における第1のセルw+を第1の電流値にプログラムするステップと、
第1の電圧にバイアス電圧を加えたものに等しい電圧を前記第1のセルの制御ゲート端子に印加することによって、前記第1のセルを検証するステップと、
前記差動対における第2のセルw-を前記第1の電流値にプログラムするステップと、
前記第1の電圧に前記バイアス電圧を加えたものに等しい電圧を前記第2のセルの制御ゲート端子に印加することによって、前記第2のセルを検証するステップと、
前記第1の電圧に等しい電圧を前記第1のセルの前記制御ゲート端子に印加することによって、前記第1のセルを読み出すステップと、
前記第1の電圧に等しい電圧を前記第2のセルの前記制御ゲート端子に印加することによって、前記第2のセルを読み出すステップと、
式w=(w+)-(w-)に従って値wを計算するステップと、を含む、方法。
【請求項24】
前記第1の電流値は、正の値である、請求項23に記載の方法。
【請求項25】
前記第2の電流値は、負の値である、請求項23に記載の方法。
【請求項26】
前記第1のセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2のセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってw-にチューニングされる、請求項23に記載の方法。
【請求項27】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、前記アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、差動対w+及びw-として記憶され、w+は、前記アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対として記憶され、w-は、前記アレイ内の第3の不揮発性メモリセル及び第4の不揮発性メモリセルの差動対として記憶され、w+及びw-値の記憶は、バイアス値によってオフセットされる、ニューラルネットワーク。
【請求項28】
全ての前記メモリセルの電流範囲は、ほぼ、バイアス値を表すメモリセル電流値分だけ低減される、請求項27に記載のニューラルネットワーク。
【請求項29】
前記メモリセルは、いくつかの電流レベルを有する、請求項27に記載のニューラルネットワーク。
【請求項30】
バイアス値は、いくつかのメモリセルレベルにわたって共有される、請求項28に記載のニューラルネットワーク。
【請求項31】
前記バイアス値は、正の値である、請求項27に記載のニューラルネットワーク。
【請求項32】
前記バイアス値は、負の値である、請求項27に記載のニューラルネットワーク。
【請求項33】
0の値がwに対して所望されるとき、前記バイアス値に等しい値は、w+及びw-に対して記憶される、請求項27に記載のニューラルネットワーク。
【請求項34】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項27に記載のニューラルネットワーク。
【請求項35】
前記所定のスレッショルドは、5nAである、請求項34に記載のニューラルネットワーク。
【請求項36】
前記所定のスレッショルドは、10nAである、請求項34に記載のニューラルネットワーク。
【請求項37】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項27に記載のニューラルネットワーク。
【請求項38】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項27に記載のニューラルネットワーク。
【請求項39】
前記第1及び第3の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされ、前記第2及び第4の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされる、請求項27に記載のニューラルネットワーク。
【請求項40】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、前記アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+に対する値は、非ゼロ値の第1の範囲から選択され、w-に対する値は、非ゼロ値の第2の範囲から選択され、前記第1の範囲及び前記第2の範囲は重複しない、ニューラルネットワーク。
【請求項41】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項40に記載のニューラルネットワーク。
【請求項42】
前記所定のスレッショルドは、5nAである、請求項41に記載のニューラルネットワーク。
【請求項43】
前記所定のスレッショルドは、10nAである、請求項41に記載のニューラルネットワーク。
【請求項44】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項40に記載のニューラルネットワーク。
【請求項45】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項40に記載のニューラルネットワーク。
【請求項46】
前記第1の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってw-にチューニングされる、請求項40に記載のニューラルネットワーク。
【請求項47】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを読み出す方法であって、前記方法は、
前記アレイ内の選択されたセル内に記憶された重みを読み出すステップを含み、前記読み出すステップは、
前記選択されたセルの制御ゲート端子にゼロの電圧バイアスを印加するステップと、
前記選択されたセルからの電流出力を含むニューロン出力電流を検知するステップと、を含む、方法。
【請求項48】
前記読み出すステップは、
前記選択されたセルのワード線端子に電圧を印加するステップを更に含む、請求項47に記載の方法。
【請求項49】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを動作させる方法であって、前記方法は、
前記不揮発性メモリセルの制御ゲートに第1のバイアス電圧を印加することによって、前記不揮発性メモリセルを読み出すステップと、
スタンバイ動作、ディープパワーダウン動作、又はテスト動作のうちの1つ以上の間に、前記不揮発性メモリセルの前記制御ゲートに第2のバイアス電圧を印加するステップと、を含む、方法。
【請求項50】
前記アレイ内のバックグラウンドデータパターン又はゼロの重み又は非ユーザセルを変調するステップを更に含む、請求項49に記載の方法。
【発明の詳細な説明】
【技術分野】
【0001】
(優先権の主張)
本出願は、2020年1月3日に出願された「Precise Data Tuning Method and Apparatus for Analog Neuromorphic Memory in an Artificial Neural Network」という名称の米国特許仮出願第62/957,013号の優先権を主張するものである、2020年3月25日に出願された「Precise Data Tuning Method and Apparatus for Analog Neuromorphic Memory in an Artificial Neural Network」という名称の米国特許出願第16/829,757号の一部継続出願である、2021年2月25日に出願された「Precise Data Tuning Method and Apparatus for Analog Neural Memory in an Artificial Neural Network」という名称の米国特許出願第17/185,725号の優先権を主張するものである。
【0002】
(発明の分野)
人工ニューラルネットワーク内のベクトルマトリックス乗算(vector-by-matrix multiplication、VMM)アレイ内の不揮発性メモリセルの浮遊ゲートに正確な量の電荷を精密かつ迅速に堆積させるための精密チューニング方法及び装置について、多数の実施形態が開示される。
【背景技術】
【0003】
人工ニューラルネットワークは、生物学的ニューラルネットワーク(動物の中枢神経系、特に脳)を模倣しており、多数の入力に依存し得、かつ、一般的に未知である関数を推定する又は近似するために使用される。人工ニューラルネットワークは、概して、お互いの間でメッセージを交換する相互接続した「ニューロン」の層を含む。
【0004】
図1は人工ニューラルネットワークを示しており、図中、円は、入力又はニューロンの層を表す。接続(シナプスと呼ばれる)は、矢印によって表され、経験に基づいてチューニングされ得る数値の重みを有する。これにより、人工ニューラルネットワークは入力に適応し、学習可能になる。典型的には、人工ニューラルネットワークは、複数の入力の層を含む。典型的には、1つ以上のニューロンの中間層、及びニューラルネットワークの出力を提供するニューロンの出力層が存在する。各レベルでニューロンは、シナプスから受信したデータに基づいて個々に又は集合的に決定を行う。
【0005】
高性能情報処理用の人工ニューラルネットワークの開発における主要な課題のうちの1つは、適切なハードウェア技術の欠如である。実際には、実用人工ニューラルネットワークは、非常に多数のシナプスに依拠しており、これによりニューロン間の高い接続性、すなわち、非常に高度な計算処理の並列化が可能となる。原理的には、このような複雑性は、デジタルスーパーコンピュータ又は専用グラフィックプロセッシングユニットクラスタによって実現が可能である。しかしながら、高コストに加え、これらのアプローチはまた、生物学的ネットワークが主として低精度のアナログ計算を実施するのではるかに少ないエネルギーしか消費しないのと比較して、エネルギー効率が劣っていることに悩まされている。人工ニューラルネットワークにはCMOSアナログ回路が使用されてきたが、ほとんどのCMOS実装シナプスは、多数のニューロン及びシナプスを前提とすると、嵩高過ぎていた。
【0006】
出願人は以前に、参照により組み込まれる米国特許公開第2017/0337466号として公開された米国特許出願第15/594,439号において、シナプスとして1つ以上の不揮発性メモリアレイを利用する人工(アナログ)ニューラルネットワークを開示した。不揮発性メモリアレイは、アナログニューロモーフィックメモリとして動作する。本明細書で使用される場合、ニューロモーフィックという用語は、神経システムのモデルを実装する回路を意味する。アナログニューロモーフィックメモリは、第1の複数の入力を受信して、それから第1の複数の出力を生成するように構成されている第1の複数のシナプス、及び第1の複数の出力を受信するように構成された第1の複数のニューロンを含む。第1の複数のシナプスは複数のメモリセルを含み、メモリセルの各々は、半導体基板内に形成された、間にチャネル領域が延在する離間したソース領域及びドレイン領域と、チャネル領域の第1の部分の上方に絶縁されて配設される浮遊ゲートと、チャネル領域の第2の部分の上方に絶縁されて配設される非浮遊ゲートと、を含む。複数のメモリセルの各々は、浮遊ゲートの多くの電子に対応する重み値を記憶するように構成されている。複数のメモリセルは、第1の複数の入力に、記憶された重み値を乗算して第1の複数の出力を生成するように構成される。この様式で配置されるメモリセルのアレイは、ベクトルマトリックス乗算(VMM)アレイと称され得る。
【0007】
VMMアレイに使用される各不揮発性メモリセルは、浮遊ゲート内に電荷、すなわち電子の数、を非常に具体的かつ精密な量で保持するように消去及びプログラムされなければならない。例えば、各浮遊ゲートはN個の異なる値のうちの1つを保持しなければならず、ここで、Nは、各セルによって示され得る異なる重みの数である。Nの例としては、16、32、64、128及び256が挙げられる。1つの課題は、異なるNの値に必要な精度及び粒度で選択されたセルをプログラムする能力である。例えば、選択されたセルが64個の異なる値のうちの1つを含み得る場合、極めて高い精度がプログラム動作で必要とされる。
【0008】
必要とされるのは、アナログニューロモーフィックメモリにおいてVMMアレイと共に使用するのに適した、改善されたプログラミングシステム及び方法である。
【発明の概要】
【0009】
アナログニューロモーフィックメモリシステム内のVMMアレイ内の不揮発性メモリセルの浮遊ゲートに正確な量の電荷を精密かつ迅速に堆積させるための精密チューニングアルゴリズム及び装置について、多数の実施形態が開示される。それにより、選択されたセルは、N個の異なる値のうちの1つを保持するために、極めて高い精度でプログラムすることができる。
【0010】
一実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、重み値wは、式w=(w+)-(w-)に従って、アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+及びw-は、非ゼロのオフセット値を含む。
【0011】
別の実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを備え、アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、ここで、w+及びw-値の記憶は、アレイ内の全ての列の間でほぼ均等に分散される。
【0012】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルの差動対においてゼロ値をプログラミングし、検証し、及び読み出す方法は、差動対の第1のセルw+を第1の電流値にプログラムするステップと、第1の電圧にバイアス電圧を加えたものに等しい電圧を第1のセルの制御ゲート端子に印加することによって第1のセルを検証するステップと、差動対の第2のセルw-を第1の電流値にプログラムするステップと、第1の電圧にバイアス電圧を加えたものに等しい電圧を第2のセルの制御ゲート端子に印加することによって第2のセルを検証するステップと、第1の電圧に等しい電圧を第1のセルの制御ゲート端子に印加することによって第1のセルを読み出すステップと、第1の電圧に等しい電圧を第2のセルの制御ゲート端子に印加することによって第2のセルを読み出すステップと、式w=(w+)-(w-)に従って値wを計算するステップとを含む。
【0013】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルの差動対においてゼロ値をプログラミングし、検証し、及び読み出す方法は、差動対の第1のセルw+を第1の電流値にプログラムするステップと、第1の電圧にバイアス電圧を加えたものに等しい電圧を第1のセルの制御ゲート端子に印加することによって第1のセルを検証するステップと、差動対の第2のセルw-を第1の電流値にプログラムするステップと、第1の電圧にバイアス電圧を加えたものに等しい電圧を第2のセルの制御ゲート端子に印加することによって第2のセルを検証するステップと、第1の電圧に等しい電圧を第1のセルの制御ゲート端子に印加することによって第1のセルを読み出すステップと、第1の電圧に等しい電圧を第2のセルの制御ゲート端子に印加することによって第2のセルを読み出すステップと、式w=(w+)-(w-)に従って値wを計算するステップとを含む。
【0014】
別の実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを備え、アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従う差動対w+及びw-として記憶され、w+は、アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対として記憶され、w-は、アレイ内の第3の不揮発性メモリセル及び第4の不揮発性メモリセルの差動対として記憶され、w+及びw-の記憶は、バイアス値によってオフセットされる。
【0015】
別の実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを備え、アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+に対する値は、非ゼロ値の第1の範囲から選択され、w-に対する値は、非ゼロ値の第2の範囲から選択され、第1の範囲及び第2の範囲は、重複しない。
【0016】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを読み出す方法は、アレイ内の選択されたセル内に記憶された重みを読み出すステップを含み、読み出すステップは、選択されたセルの制御ゲート端子にゼロ電圧バイアスを印加するステップと、選択されたセルから出力される電流を含むニューロン出力電流を検知するステップとを含む。
【0017】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを動作させる方法は、前記不揮発性メモリセルの制御ゲートに第1のバイアス電圧を印加することによって、前記不揮発性メモリセルを読み出すステップと、スタンバイ動作、ディープパワーダウン動作、又はテスト動作のうちの1つ以上の間に、不揮発性メモリセルの制御ゲートに第1のバイアス電圧を印加すること、及び不揮発性メモリセルの制御ゲートに第2のバイアス電圧を印加することによって、不揮発性メモリセルを読み出すステップを含む。
【0018】
【0019】
【0020】
【0021】
【0022】
【0023】
【0024】
【0025】
【0026】
【0027】
【0028】
【0029】
【0030】
【0031】
【0032】
【0033】
【0034】
【0035】
【0036】
【0037】
【0038】
【0039】
【0040】
【0041】
【0042】
【0043】
【0044】
【0045】
【0046】
【0047】
【0048】
【0049】
【0050】
【0051】
【0052】
【0053】
【0054】
【0055】
【0056】
【0057】
【0058】
【0059】
【0060】
【0061】
【0062】
【0063】
【0064】
【0065】
【0066】
【0067】
【0068】
【0069】
【0070】
【0071】
【図面の簡単な説明】
【0072】
【
図1】先行技術の人工ニューラルネットワークを示す図である。
【
図2】先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図3】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図4】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図5】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図6】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図7】先行技術の積層ゲートフラッシュメモリセルを示す。
【
図8】1つ以上のVMMアレイを利用する例示的な人工ニューラルネットワークの様々なレベルを示す図である。
【
図9】VMMアレイ及び他の回路を備えるVMMシステムを示すブロック図である。
【
図10】1つ以上のVMMシステムを利用する例示的な人工ニューラルネットワークを示すブロック図である。
【
図25】先行技術の長・短期メモリシステムを示す。
【
図26】長・短期メモリシステムで使用する例示的なセルを示す。
【
図29】先行技術のゲート付き回帰型ユニットシステムを示す。
【
図30】ゲート付き回帰型ユニットシステムでの使用のための例示的なセルを示す。
【
図36A】セルに記憶された値に対する温度の影響を示す。
【
図36B】VMMシステムの動作中のデータドリフトによって生じた問題を示す。
【
図36C】データドリフトを補償するためのブロックを示す。
【発明を実施するための形態】
【0073】
本発明の人工ニューラルネットワークは、CMOS技術及び不揮発性メモリアレイの組み合わせを利用する。
不揮発性メモリセル
【0074】
デジタル不揮発性メモリは、周知である。例えば、参照により本明細書に組み込まれる、米国特許第5,029,130号(「’130号特許」)は、フラッシュメモリセルの一種である、スプリットゲート不揮発性メモリセルのアレイを開示する。このようなメモリセル210を
図2に示す。各メモリセル210は、半導体基板12内に形成されたソース領域14及びドレイン領域16を含み、ソース領域14とドレイン領域16との間にはチャネル領域18がある。浮遊ゲート20は、チャネル領域18の第1の部分の上方に絶縁されて形成され(並びに、チャネル領域18の第1の部分の導電性を制御して)、ソース領域14の一部分の上方にかけて形成される。ワード線端子22(典型的には、ワード線に結合される)は、チャネル領域18の第2の部分の上方に絶縁されて配設される、(並びに、チャネル領域18の第2の部分の導電性を制御する)第1の部分と、浮遊ゲート20の上方で上に延在する第2の部分と、を有する。浮遊ゲート20及びワード線端子22は、ゲート酸化物によって基板12から絶縁される。ビット線端子24はドレイン領域16に結合される。
【0075】
ワード線端子22に高圧正電圧を加えることによって、メモリセル210に対して消去が行われ(電子が浮遊ゲートから除去される)、これによって、浮遊ゲート20の電子は、浮遊ゲート20からワード線端子22までそれらの間にある絶縁体の中をファウラーノルドハイム(Fowler-Nordheim)トンネリングを介して通過する。
【0076】
メモリセル210は、ワード線端子22に正電圧、及びソース領域14に正電圧を加えることによってプログラムされる(電子が浮遊ゲートに印加される)。電子電流は、ソース領域14(ソース線端子)からドレイン領域16に向かって流れる。電子は加速し、ワード線端子22と浮遊ゲート20との間の間隙に達すると、発熱する。熱せられた電子の一部は、浮遊ゲート20からの静電引力に起因して、浮遊ゲート20にゲート酸化物を介して注入される。
【0077】
メモリセル210は、ドレイン領域16及びワード線端子22に正の読み出し電圧を加える(ワード線端子の下方のチャネル領域18の部分をオンにする)ことによって、読み出される。浮遊ゲート20が正に帯電する(すなわち、電子を消去する)と、浮遊ゲート20の下方のチャネル領域18の部分も同様にオンになり、電流はチャネル領域18を流れ、これは、消去された状態つまり「1」の状態として検知される。浮遊ゲート20が負に帯電する(すなわち、電子でプログラムされる)と、浮遊ゲート20の下方のチャネル領域の部分はほとんど又は完全にオフになり、電流はチャネル領域18を流れず(又はほとんど流れず)、これは、プログラムされた状態つまり「0」の状態として検知される。
【0078】
表1は、読み出し、消去、及びプログラム動作を実行するためのメモリセル110の端子に印加され得る典型的な電圧範囲を示す。
表1:
図2のフラッシュメモリセル210の動作
【表1】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。
【0079】
図3は、制御ゲート(control gate、CG)端子28を追加した、
図2のメモリセル210と同様のメモリセル310を示す。制御ゲート端子28は、プログラミング中に高電圧(例えば、10V)、消去中に低又は負電圧(例えば、0v/-8V)、読み出し中に低又は中程度電圧(例えば、0v/2.5V)でバイアスされる。他の端子は、
図2の端子と同様にバイアスされる。
【0080】
図4は、ソース領域14と、ドレイン領域16と、チャネル領域18の第1の部分の上方にある浮遊ゲート20と、チャネル領域18の第2の部分の上方にある選択ゲート22(典型的には、ワード線、WL、に結合される)と、浮遊ゲート20の上方にある制御ゲート28と、ソース領域14の上方にある消去ゲート30と、を備える、4ゲートメモリセル410を示す。この構成は、あらゆる目的のため参照により本明細書に組み込まれる、米国特許第6,747,310号に記載されている。ここで、全てのゲートは、浮遊ゲート20を除いて、非浮遊ゲートであり、つまり、それらは電圧源に電気的に接続される又は接続可能である。プログラミングは、熱せられた電子がチャネル領域18から浮遊ゲート20にその電子自体を注入することによって実行される。消去は、電子が浮遊ゲート20から消去ゲート30へトンネリングすることによって実行される。
【0081】
表2は、読み出し、消去、及びプログラム動作を実行するためのメモリセル410の端子に印加され得る典型的な電圧範囲を示す。
表2:
図4のフラッシュメモリセル410の動作
【表2】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。
【0082】
図5は、メモリセル510が消去ゲートEG端子を含まないことを除いて、
図4のメモリセル410と同様のメモリセル510を示す。消去は、基板18を高電圧にバイアスし、制御ゲートCG端子28を低電圧又は負電圧にバイアスすることによって実行される。代替的に、ワード線端子22を正電圧にバイアスし、制御ゲート端子28を負電圧にバイアスすることによって、消去が実行される。プログラミング及び読み出しは、
図4のものと同様である。
【0083】
図6は、別の種類のフラッシュメモリセルである、3ゲートメモリセル610を示す。メモリセル610は、メモリセル610が別個の制御ゲート端子を有しないことを除いて、
図4のメモリセル410と同一である。(消去ゲート端子の使用を通じて消去が起こる)消去動作及び読み出し動作は、制御ゲートバイアスが印加されないことを除いて、
図4のものと同様である。プログラミング動作もまた、制御ゲートバイアスなしで行われるため、結果として、プログラム動作中は、制御ゲートバイアスの不足を補償するため、より高い電圧がソース線端子に印加されなければならない。
【0084】
表3は、読み出し、消去、及びプログラム動作を実行するためのメモリセル610の端子に印加され得る典型的な電圧範囲を示す。
表3:
図6のフラッシュメモリセル610の動作
【表3】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。
【0085】
図7は、別の種類のフラッシュメモリセルである、積層ゲートメモリセル710を示す。メモリセル710は、浮遊ゲート20がチャネル領域18全体の上方にわたって延在し、制御ゲート端子22(ワード線に結合される)が絶縁層(図示せず)によって分離されて浮遊ゲート20の上方に延在することを除いて、
図2のメモリセル210と同様である。消去、プログラミング、及び読み出し動作は、メモリセル210について前述したものと同様の方法で動作する。
【0086】
表4は、読み出し、消去、及びプログラム動作を実行するためのメモリセル710及び基板12の端子に印加され得る典型的な電圧範囲を示す。
表4:
図7のフラッシュメモリセル710の動作
【表4】
【0087】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。任意選択的に、メモリセル210、310、410、510、610、又は710の行及び列を含むアレイでは、ソース線は、メモリセルの1行又はメモリセルの隣接する2行に結合され得る。すなわち、ソース線端子は、メモリセルの隣接する行によって共有され得る。
【0088】
上記の人工ニューラルネットワークにおける不揮発性メモリセルの種類のうちの1つを含むメモリアレイを利用するために、2つの修正が行われる。第一に、以下に更に説明されるように、アレイ内の他のメモリセルのメモリ状態に悪影響を与えずに各メモリセルを個々にプログラム、消去、及び読み出しできるように線を構成する。第二に、メモリセルの連続的(アナログ)プログラミングを提供する。
【0089】
具体的には、アレイ内の各メモリセルのメモリ状態(すなわち、浮遊ゲートの電荷)を、完全に消去された状態から完全にプログラムされた状態へ、独立して、かつ他のメモリセルの乱れが最小で、連続的に変えることができる。別の実施形態では、アレイ内の各メモリセルのメモリ状態(すなわち、浮遊ゲートの電荷)を、完全にプログラムされた状態から完全に消去された状態へ、及び逆もまた同様に、独立して、かつ他のメモリセルの乱れが最小で、連続的に変えることができる。これはつまり、セル記憶がアナログであるか、又は多数の不連続値(16個又は64個の異なる値など)のうちの1つを最低限記憶することができることを意味し、これにより、メモリアレイ内の全てのセルが非常に精密に、かつ個々にチューニング可能となり、また、メモリアレイが、記憶、及びニューラルネットワークのシナプシスの重みへの微細チューニング調整に対して、理想的なものになる。
【0090】
本明細書に記載される方法及び手段は、限定することなく、SONOS(silicon-oxide-nitride-oxide-silicon,charge trap in nitride)(ケイ素-酸化物-窒化物-酸化物-ケイ素、窒化物中の電荷トラップ)、MONOS(metal-oxide-nitride-oxide-silicon,metal charge trap in nitride)(金属-酸化物-窒化物-酸化物-ケイ素、窒化物中の金属電荷トラップ)、ReRAM(resistive ram)(抵抗変化型メモリ)、PCM(phase change memory)(相変化メモリ)、MRAM(magnetic ram)(磁気抵抗メモリ)、FeRAM(ferroelectric ram)(強誘電体メモリ)、OTP(bi-level or multi-level one time programmable)(バイレベル又はマルチレベルの1回のみのプログラムが可能)及びCeRAM(correlated electron ram)(強相関電子メモリ)などの他の不揮発性メモリ技術に適用することができる。本明細書に記載される方法及び手段は、限定することなく、SRAM、DRAM、及び他の揮発性シナプスセルなどのニューラルネットワークに使用される揮発性メモリ技術に適用することができる。
不揮発性メモリセルアレイを使用するニューラルネットワーク
【0091】
図8は、本実施形態の不揮発性メモリアレイを利用するニューラルネットワークの非限定例を概念的に例解する。この例は、顔認識アプリケーション用に不揮発性メモリアレイニューラルネットワークを使用するが、不揮発性メモリアレイベースのニューラルネットワークを使用して他の適切なアプリケーションを実装することも可能である。
【0092】
S0は入力層であり、この例では、5ビット精度の32×32ピクセルRGB画像である(すなわち、各色R、G、及びBにつき1つずつで3つの32×32ピクセルアレイであり、各ピクセルは5ビット精度である)。入力層S0から層C1に行くシナプスCB1は、一部のインスタンスには異なる重みのセットを適用し、他のインスタンスには共有の重みを適用し、入力画像を3×3ピクセルの重なり合うフィルタ(カーネル)でスキャンし、1ピクセル(又はモデルによっては2ピクセル以上)ずつフィルタをシフトする。具体的には、画像の3×3部分における9ピクセルの値(すなわち、フィルタ又はカーネルと称される)は、シナプスCB1に提供され、そこで、これらの9個の入力値に適切な重みを乗算し、その乗算の出力を合計後、単一の出力値が決定され、特徴マップC1の層のうちの1つのピクセルを生成するためにCB1の第1のシナプスによって与えられる。3×3フィルタは次に、入力層S0内で右側に1ピクセルだけシフトされ(すなわち、3ピクセルの列を右側に追加し、左側で3ピクセルの列をドロップする)、これにより、この新しく位置づけられたフィルタの9ピクセル値はシナプスCB1に提供され、そこでそれらに上記と同じ重みを乗算し、関連するシナプスによって第2の単一の出力値を決定する。このプロセスを、3×3フィルタが入力層S0の32×32ピクセル画像全体にわたって3色全て及び全てのビット(精度値)についてスキャンするまで続ける。プロセスは次に、層C1の特徴マップ全てが計算されるまで、異なる重みのセットを使用して繰り返されて、C1の異なる特徴マップを生成する。
【0093】
本例では、層C1において、各々30×30ピクセルを有する16個の特徴マップが存在する。各ピクセルは、入力とカーネルとの乗算から抽出された新しい特徴ピクセルであり、したがって、各特徴マップは、二次元アレイであり、したがってこの例では、層C1は、二次元アレイの16層を構成する(本明細書で言及される層及びアレイは、必ずしも物理的関係ではなく論理的な関係であり、すなわち、アレイは必ずしも物理的な二次元アレイに配向されないことに留意されたい)。層C1内の16個の特徴マップの各々は、フィルタスキャンに適用される異なるシナプス重みのセット16個のうちの1つによって生成される。C1特徴マップは全て、境界同定など、同じ画像特徴の異なる態様を対象とすることができる。例えば、第1のマップ(この第1のマップを生成するために使用される全てのスキャンに共有される第1の重みセットを使用して生成される)は、円形エッジを識別することができ、第2のマップ(第1の重みセットと異なる第2の重みセットを使用して生成される)は、長方形エッジ又はある特定の特徴のアスペクト比などを識別することができる。
【0094】
層C1から層S1へ行く前には、各特徴マップ内の重なり合わずに連続する2×2領域からの値をプールする活性化関数P1(プーリング)が適用される。プーリング関数の目的は、近隣の位置を平均すること(又はmax関数を使用することも可能である)、例えばエッジ位置の依存性を低減すること、及び次の段階に行く前にデータサイズを低減することである。層S1において、16個の15×15特徴マップ(すなわち、各々15×15ピクセルの異なるアレイ16個)が存在する。層S1から層C2に行くシナプスCB2は、S1内のマップを4×4フィルタにより1ピクセルのフィルタシフトでスキャンする。層C2において、22個の12×12特徴マップが存在する。層C2から層S2へ行く前には、各特徴マップ内の重なり合わずに連続する2×2領域からの値をプールする活性化関数P2(プーリング)が適用される。層S2において、22個の6×6特徴マップが存在する。層S2から層C3へ行くシナプスCB3では活性化関数(プーリング)が適用され、ここで層C3内の全てのニューロンは、CB3のそれぞれのシナプスを介して層S2内の全てのマップに接続する。層C3において、64個のニューロンが存在する。層C3から出力層S3へと行くシナプスCB4は、C3をS3に完全に接続する、すなわち、層C3内の全てのニューロンは、層S3内の全てのニューロンに接続される。S3における出力は、10個のニューロンを含み、ここで出力が最も高いニューロンが、クラスを決定する。この出力は、例えば、元の画像の内容の同定又は分類(クラス分け)を示すことができる。
【0095】
シナプスの各層は、不揮発性メモリセルのアレイ又はアレイの一部を使用して実装される。
【0096】
図9は、その目的のために使用可能なシステムのブロック図である。VMMシステム32は、不揮発性メモリセルを含み、ある層と次の層との間のシナプス(
図6のCB1、CB2、CB3、及びCB4など)として利用される。具体的には、VMMシステム32は、行及び列に配置された不揮発性メモリセルを備えるVMMアレイ33、消去ゲート及びワード線ゲートデコーダ34、制御ゲートデコーダ35、ビット線デコーダ36、並びにソース線デコーダ37を備え、それらのデコーダは、不揮発性メモリセルアレイ33に対するそれぞれの入力をデコードする。VMMアレイ33への入力は、消去ゲート及びワード線ゲートデコーダ34から、又は制御ゲートデコーダ35から行うことができる。この例におけるソース線デコーダ37はまた、VMMアレイ33の出力をデコードする。代替的に、ビット線デコーダ36が、VMMアレイ33の出力をデコードすることができる。
【0097】
VMMアレイ33は、2つの目的を果たす。第一に、VMMアレイ33は、VMMシステム32によって使用される重みを記憶する。第二に、VMMアレイ33は、効果的に、入力に、VMMアレイ33に記憶された重みを乗算し、それらを出力線(ソース線又はビット線)ごとに合計して出力を生成し、これは、次の層への入力又は最後の層への入力になる。乗算及び加算の関数を実行することによって、VMMアレイ33は、別個の乗算及び加算の論理回路の必要性をなくし、また、その場でのメモリ計算により電力効率も良い。
【0098】
VMMアレイ33の出力は、VMMアレイ33の出力を合計してその畳み込み用の単一の値を作成する、差動加算器(加算オペアンプ又は加算電流ミラーなど)38に供給される。差動加算器38は、正の重み入力及び負の重み入力両方の総和を実行して単一の値を出力するように配置される。
【0099】
差動加算器38の合計された出力値は、次に出力を整流する活性化関数回路39に供給される。活性化関数回路39は、シグモイド関数、tanh関数、ReLU関数、又は任意の他の非線形関数を提供し得る。活性化関数回路39の整流された出力値は、次の層(例えば
図8のC1)の特徴マップの要素になり、次いで、次のシナプスに適用されて次の特徴マップ層又は最後の層を生成する。したがって、この例では、VMMアレイ33は、複数のシナプスを構成し(ニューロンの前の層から、又は画像データベースなどの入力層から、入力を受信する)、加算器38及び活性化関数回路39は、複数のニューロンを構成する。
【0100】
図9のVMMシステム32への入力(WLx、EGx、CGx、及び任意選択的にBLx及びSLx)は、アナログレベル、バイナリレベル、デジタルパルス(この場合、パルスを適切な入力アナログレベルに変換するためにパルス-アナログ変換器PACが必要とされ得る)又はデジタルビット(この場合、デジタルビットを適切な入力アナログレベルに変換するためにDACが提供される)であり得、出力は、アナログレベル、バイナリレベル、デジタルパルス、又はデジタルビットであり得る(この場合、出力アナログレベルをデジタルビットに変換するために出力ADCが提供される)。
【0101】
図10は、図中でVMMシステム32a、32b、32c、32d及び32eとして標示されたVMMシステム32の多数の層の使用を示すブロック図である。
図10に示されるように、入力(Inputxで示される)は、デジタル-アナログ変換器31によってデジタルからアナログに変換され、入力VMMシステム32aに提供される。変換されたアナログ入力は、電圧又は電流であり得る。第1の層の入力D/A変換は、入力VMMシステム32aのマトリックス乗算器の適切なアナログレベルに入力Inputxをマッピングする関数又はLUT(ルックアップテーブル)を使用することによって行うことができる。入力変換はまた、外部アナログ入力を入力VMMシステム32aへのマッピングされたアナログ入力に変換するために、アナログ-アナログ(analog to analog、A/A)変換器によって行うこともできる。入力変換はまた、外部デジタル入力を入力VMMシステム32aへのマッピングされたデジタルパルスに変換するために、デジタル-デジタルパルス(digital-to-digital pules、D/P)変換器によって行うこともできる。
【0102】
入力VMMシステム32aによって生成された出力は、次に、次のVMMシステム(隠しレベル1)32bへの入力として提供され、次に入力VMMシステム(隠しレベル2)32cへの入力として提供される出力を生成する、などとなる。VMMシステム32の様々な層は、畳み込みニューラルネットワーク(convolutional neural network、CNN)のシナプス及びニューロンの各層として機能する。各VMMシステム32a、32b、32c、32d及び32eは、対応の不揮発性メモリアレイを備える、スタンドアローンの物理的システムとすることができるか、又は複数のVMMシステムは、同じ物理的不揮発性メモリアレイの異なる部分を利用することができるか、又は複数のVMMシステムは、同じ物理的不揮発性メモリアレイの重なり合う部分を利用することができる。各VMMシステム32a、32b、32c、32d、及び32eはまた、そのアレイ又はニューロンの様々な部分に対して時間多重化され得る。
図10に示される例は、5つの層(32a、32b、32c、32d、32e)、すなわち、1つの入力層(32a)、2つの隠れ層(32b、32c)、及び2つの全接続層(32d、32e)を含む。当業者であれば、これは単なる例示であり、代わりにシステムが2つを超える隠れ層及び2つを超える完全接続層を含み得ることを理解するであろう。
VMMアレイ
【0103】
図11は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1100を示す。VMMアレイ1100は、不揮発性メモリセルのメモリアレイ1101と、不揮発性基準メモリセルの基準アレイ1102(アレイの頂部に位置する)と、を含む。代替的に、別の基準アレイが底部に位置することができる。
【0104】
VMMアレイ1100では、制御ゲート線1103などの制御ゲート線が垂直方向に延びており(したがって、行方向の基準アレイ1102が、制御ゲート線1103に直交する)、消去ゲート線1104などの消去ゲート線が水平方向に延びている。ここで、VMMアレイ1100への入力は、制御ゲート線(CG0、CG1、CG2、CG3)に提供され、VMMアレイ1100の出力は、ソース線(SL0、SL1)に現れる。一実施形態では、偶数行のみが使用され、別の実施形態では、奇数行のみが使用される。各ソース線(それぞれSL0、SL1)の電流は、その特定のソース線に接続されたメモリセルからの全ての電流の合計関数を実行する。
【0105】
ニューラルネットワークについて本明細書に記載されているように、VMMアレイ1100の不揮発性メモリセル、すなわちVMMアレイ1100のフラッシュメモリは、サブスレッショルド領域で動作するように構成されることが好ましい。
【0106】
本明細書に記載される不揮発性基準メモリセル及び不揮発性メモリセルは、以下のように弱い反転でバイアスされる:
Ids=Io*e(Vg-Vth)/nVt=w*Io*e(Vg)/nVt
式中、w=e(-Vth)/nVtであり、
式中、Idsはドレイン-ソース間電流であり、Vgはメモリセルのゲート電圧であり、Vthはメモリセルのスレッショルド電圧であり、Vtは熱電圧=k*T/qであり、kはボルツマン定数、Tはケルビン温度、qは電子電荷であり、nは傾斜係数=1+(Cdep/Cox)であり、Cdep=空乏層の容量、及びCoxはゲート酸化物層の容量であり、Ioは、スレッショルド電圧に等しいゲート電圧におけるメモリセル電流であり、Ioは(Wt/L)*u*Cox*(n-1)*Vt2に比例し、式中、uはキャリア移動度であり、Wt及びLはそれぞれ、メモリセルの幅及び長さである。
【0107】
メモリセル(基準メモリセル又は周辺メモリセルなど)又はトランジスタを使用して入力電流Idsを入力電圧Vgに変換するI-Vログ変換器を使用した場合、Vgは以下のとおりである:
Vg=n*Vt*log[Ids/wp*Io]
式中、wpは、基準又は周辺メモリセルのwである。
【0108】
メモリセル(基準メモリセル又は周辺メモリセルなど)又はトランジスタを使用して入力電流Idsを入力電圧Vgに変換するI-Vログ変換器を使用した場合、Vgは以下のとおりである:
Vg=n*Vt*log[Ids/wp*Io]
【0109】
式中、wpは、基準又は周辺メモリセルのwである。
【0110】
ベクトルマトリックス乗算器VMMアレイとして使用されるメモリアレイについて、出力電流は以下である:
Iout=wa*Io*e(Vg)/nVt、すなわち
Iout=(wa/wp)*Iin=W*Iin
W=e(Vthp-Vtha)/nVt
Iin=wp*Io*e(Vg)/nVt
式中、wa=メモリアレイの各メモリセルのwである。
【0111】
ワード線又は制御ゲートは、入力電圧のためのメモリセルの入力として使用することができる。
【0112】
代替的に、本明細書に記載されたVMMアレイの不揮発性メモリセルは、線形領域で動作するように構成することができる。
Ids=ベータ*(Vgs-Vth)*Vds、 ベータ=u*Cox*Wt/L、
W α (Vgs-Vth)
すなわち、直線領域における重みWは(Vgs-Vth)に比例する。
【0113】
ワード線又は制御ゲート又はビット線又はソース線は、線形領域内で動作するメモリセルの入力として使用することができる。ビット線又はソース線は、メモリセルの出力として使用することができる。
【0114】
I-V線形変換器用に、線形領域で動作するメモリセル(基準メモリセル又は周辺メモリセルなど)若しくはトランジスタ、又は抵抗器を使用して、入出力電流を入出力電圧に線形変換することができる。
【0115】
代替的に、本明細書に記載されたVMMアレイのメモリセルは、飽和領域で動作するように構成することができる。
Ids=1/2
*ベータ*(Vgs-Vth)2、 ベータ=u*Cox*Wt/L
W α (Vgs-Vth)2、すなわち、重みWは(Vgs-Vth)2に比例する。
【0116】
ワード線、制御ゲート、又は消去ゲートは、飽和領域内で動作するメモリセルの入力として使用することができる。ビット線又はソース線は、出力ニューロンの出力として使用することができる。
【0117】
代替的に、本明細書に記載されるVMMアレイのメモリセルは、全ての領域又はそれらの組み合わせ(サブスレッショルド、線形、又は飽和)で使用することができる。
【0118】
図9のVMMアレイ33のための他の実施形態は、参照により本明細書に組み込まれる米国特許出願第15/826,345号に記載されている。上記出願に記載されているように、ソース線又はビット線は、ニューロン出力(電流和出力)として使用することができる。
【0119】
図12は、
図2に示されるメモリセル210に特に適したニューロンVMMアレイ1200を示し、入力層と次の層との間のシナプスとして利用される。VMMアレイ1200は、不揮発性メモリセルのメモリアレイ1203と、第1の不揮発性基準メモリセルの基準アレイ1201と、第2の不揮発性基準メモリセルの基準アレイ1202と、を含む。アレイの列方向に配置された基準アレイ1201及び1202は、端子BLR0、BLR1、BLR2、及びBLR3に流入する電流入力を電圧入力WL0、WL1、WL2、及びWL3に変換するように機能する。実際には、第1及び第2の不揮発性基準メモリセルは、電流入力が流入する状態で、マルチプレクサ1214(一部のみ示す)を通してダイオード接続される。基準セルは、目標基準レベルにチューニング(例えば、プログラム)される。目標基準レベルは、基準ミニアレイマトリックス(図示せず)によって提供される。
【0120】
メモリアレイ1203は、2つの目的を果たす。第一に、メモリアレイ1003は、VMMアレイ1200により使用される重みを、それぞれのメモリセルに記憶する。第二に、メモリアレイ1203は、メモリアレイ1203に記憶された重みを、入力(すなわち、端子BLR0、BLR1、BLR2、及びBLR3に提供された電流入力であり、これを基準アレイ1201及び1202が入力電圧に変換して、ワード線WL0、WL1、WL2、及びWL3に供給する)に有効に乗算して、次いで、全ての結果(メモリセル電流)を加算して、それぞれのビット線(BL0~BLN)の出力を生成し、この出力は次の層への入力又は最後の層への入力となる。乗算及び加算の関数を実行することで、メモリアレイ1203は、別個の乗算及び加算の論理回路の必要性をなくし、また、電力効率も良い。ここで、電圧入力はワード線WL0、WL1、WL2、及びWL3に提供され、出力は、読み出し(推論)動作中にそれぞれのビット線BL0~BLNに現れる。ビット線BL0~BLNの各々の電流は、その特定のビット線に接続された全ての不揮発性メモリセルからの電流の合計関数を実行する。
【0121】
表5は、VMMアレイ1200の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示し、FLTは、浮遊、すなわち電圧が印加されないことを示す。行は、読み出し、消去、及びプログラムの動作を示す。
表5:
図12のVMMアレイ1200の動作
【表5】
【0122】
図13は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1300を示す。VMMアレイ1300は、不揮発性メモリセルのメモリアレイ1303と、第1の不揮発性基準メモリセルの基準アレイ1301と、第2の不揮発性基準メモリセルの基準アレイ1302と、を含む。基準アレイ1301及び1302は、VMMアレイ1300の行方向に延びる。VMMアレイは、VMMアレイ1300においてワード線が垂直方向に延びることを除いて、VMM1000と同様である。ここで、入力はワード線(WLA0、WLB0、WLA1、WLB2、WLA2、WLB2、WLA3、WLB3)に提供され、出力は、読み出し動作中にソース線(SL0、SL1)に現れる。各ソース線の電流は、その特定のソース線に接続されたメモリセルからの全ての電流の合計関数を実行する。
【0123】
表6は、VMMアレイ1300の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示す。行は、読み出し、消去、及びプログラムの動作を示す。
表6:
図13のVMMアレイ1300の動作
【表6】
【0124】
図14は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1400を示す。VMMアレイ1400は、不揮発性メモリセルのメモリアレイ1403と、第1の不揮発性基準メモリセルの基準アレイ1401と、第2の不揮発性基準メモリセルの基準アレイ1402と、を含む。基準アレイ1401及び1402は、端子BLR0、BLR1、BLR2、及びBLR3に流入する電流入力を電圧入力CG0、CG1、CG2、及びCG3に変換するように機能する。実際には、第1及び第2の不揮発性基準メモリセルは、電流入力がBLR0、BLR1、BLR2、及びBLR3を通って流入する状態で、マルチプレクサ1412(一部のみ示す)を通してダイオード接続される。マルチプレクサ1412は、読み出し動作中に第1及び第2の不揮発性基準メモリセルの各々のビット線(BLR0など)の一定電圧を確実にするために、対応のマルチプレクサ1405及びカスコーディングトランジスタ1404をそれぞれ含む。基準セルは、目標基準レベルにチューニングされる。
【0125】
メモリアレイ1403は、2つの目的を果たす。第一に、メモリアレイ1203は、VMMアレイ1400によって使用される重みを記憶する。第二に、メモリアレイ1403は、メモリアレイに記憶された重みを、入力(端子BLR0、BLR1、BLR2、及びBLR3に提供された電流入力であり、基準アレイ1401及び1402がこれらの電流入力を入力電圧に変換して、制御ゲート(CG0、CG1、CG2、及びCG3)に供給する)に有効に乗算して、次いで、全ての結果(セル電流)を加算して出力を生成し、この出力はBL0~BLNに現れ、次の層への入力又は最後の層への入力となる。メモリアレイが乗算及び加算の関数を実行することで、別個の乗算及び加算の論理回路の必要性がなくなり、また、電力効率も良い。ここで、入力は制御ゲート線(CG0、CG1、CG2、及びCG3)に提供され、出力は、読み出し動作中にビット線(BL0~BLN)に現れる。各ビット線の電流は、その特定のビット線に接続されたメモリセルからの全ての電流の合計関数を実行する。
【0126】
VMMアレイ1400は、メモリアレイ1403内の不揮発性メモリセルの一方向チューニングを実装する。すなわち、各不揮発性メモリセルは消去され、次いで、浮遊ゲートの所望の電荷に達するまで部分的にプログラムされる。これは、例えば、以下に記載される精密プログラミング技術を使用して実行することができる。過度に多くの電荷が浮遊ゲートに加えられる場合(その結果、誤った値がセルに記憶される)、セルは消去されなければならず、一連の部分的なプログラミング動作をやり直さなければならない。示されるように、同じ消去ゲート(EG0又はEG1など)を共有する2つの行は、一緒に消去される必要があり(ページ消去として知られる)、その後、各セルは、浮遊ゲートの所望の電荷に達するまで部分的にプログラムされる。
【0127】
表7は、VMMアレイ1400の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルの制御ゲート、選択セルと同じセクタ内の非選択セルの制御ゲート、選択セルとは異なるセクタ内の非選択セルの制御ゲート、選択セルの消去ゲート、非選択セルの消去ゲート、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示す。行は、読み出し、消去、及びプログラムの動作を示す。
表7:
図14のVMMアレイ1400の動作
【表7】
【0128】
図15は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1500を示す。VMMアレイ1500は、不揮発性メモリセルのメモリアレイ1503と、基準アレイ1501又は第1の不揮発性基準メモリセルと、第2の不揮発性基準メモリセルの基準アレイ1502と、を備える。EG線EGR0、EG0、EG1、及びEGR1は垂直に延び、CG線CG0、CG1、CG2、及びCG3並びにSL線WL0、WL1、WL2、及びWL3は水平に延びる。VMMアレイ1500は、VMMアレイ1500が双方向チューニングを実装することを除いてVMMアレイ1400と同様であり、各個々のセルは、個別のEG線の使用により、浮遊ゲートの所望の電荷量に達するために、完全に消去され、部分的にプログラムされ、必要に応じて部分的に消去することができる。示されるように、基準アレイ1501及び1502は、端子BLR0、BLR1、BLR2及びBLR3における入力電流を制御ゲート電圧CG0、CG1、CG2及びCG3に変換し(マルチプレクサ1514を介したダイオード接続された基準セルの作用を通じて)、これらの電圧は行方向でメモリセルに印加される。電流出力(ニューロン)は、ビット線BL0~BLN中にあり、各ビット線は、その特定のビット線に接続された不揮発性メモリセルからの全ての電流を合計する。
【0129】
表8は、VMMアレイ1500の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルの制御ゲート、選択セルと同じセクタ内の非選択セルの制御ゲート、選択セルとは異なるセクタ内の非選択セルの制御ゲート、選択セルの消去ゲート、非選択セルの消去ゲート、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示す。行は、読み出し、消去、及びプログラムの動作を示す。
表8:
図15のVMMアレイ1500の動作
【表8】
【0130】
図16は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1600を示す。VMMアレイ1600では、入力INPUT
0....、INPUT
Nは、ビット線BL
0、...BL
Nでそれぞれ受信され、出力OUTPUT
1、OUTPUT
2、OUTPUT
3、及びOUTPUT
4は、ソース線SL
0、SL
1、SL
2、及びSL
3にそれぞれ生成される。
【0131】
図17は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1700を示す。この例では、入力INPUT
0、INPUT
1、INPUT
2、及びINPUT
3は、ソース線SL
0、SL
1、SL
2、及びSL
3でそれぞれ受信され、出力OUTPUT
0、...OUTPUT
Nは、ビット線BL
0、...、BL
Nに生成される。
【0132】
図18は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1800を示す。この例では、入力INPUT
0、...、INPUT
Mは、ワード線WL
0、...、WL
Mでそれぞれ受信され、出力OUTPUT
0、...OUTPUT
Nは、ビット線BL
0、...、BL
Nに生成される。
【0133】
図19は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1900を示す。この例では、入力INPUT
0、...、INPUT
Mは、ワード線WL
0、...、WL
Mでそれぞれ受信され、出力OUTPUT
0、...OUTPUT
Nは、ビット線BL
0、...、BL
Nに生成される。
【0134】
図20は、
図4に示されるメモリセル410に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2000を示す。この例では、入力INPUT
0、...、INPUT
nがそれぞれ垂直制御ゲート線CG
0、...、CG
Nに受信され、出力OUTPUT
1及びOUTPUT
2がソース線SL
0及びSL
1に生成される。
【0135】
図21は、
図4に示されるメモリセル410に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2100を示す。この例では、入力INPUT
0、...、INPUT
Nは、ビット線BL
0、...、BL
Nにそれぞれ結合されているビット線制御ゲート2901-1、2901-2、...、2901-(N-1)及び2901-Nのゲートにそれぞれ受信される。例示的な出力OUTPUT
1及びOUTPUT
2が、ソース線SL
0及びSL
1に生成される。
【0136】
図22は、
図3に示されるメモリセル310、
図5に示されるメモリセル510、及び
図7に示されるメモリセル710に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2200を示す。この例では、入力INPUT
0、...、INPUT
Mは、ワード線WL
0、...、WL
Mに受信され、出力OUTPUT
0、...、OUTPUT
Nは、ビット線BL
0、...、BL
Nにそれぞれ生成される。
【0137】
図23は、
図3に示されるメモリセル310、
図5に示されるメモリセル510、及び
図7に示されるメモリセル710に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2300を示す。この例では、入力INPUT
0、...、INPUT
Mは、制御ゲート線CG
0、...、CG
Mに受信される。出力OUTPUT
0、...、OUTPUT
Nは、垂直ソース線SL
0、...、SL
Nにそれぞれ生成され、各ソース線SL
iは、列i内の全てのメモリセルのソース線に結合されている。
【0138】
図24は、
図3に示されるメモリセル310、
図5に示されるメモリセル510、及び
図7に示されるメモリセル710に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2400を示す。この例では、入力INPUT
0、...、INPUT
Mは、制御ゲート線CG
0、...、CG
Mに受信される。出力OUTPUT
0、...、OUTPUT
Nは、垂直ビット線BL
0、...、BL
Nにそれぞれ生成され、各ビット線BL
iは、列i内の全てのメモリセルのビット線に結合されている。
長・短期メモリ
【0139】
先行技術は、長・短期メモリ(long short-term memory、LSTM)として知られる概念を含む。LSTMは、人工ニューラルネットワークで使用されることが多い。LSTMは、人工ニューラルネットワークが、所定の任意の期間にわたって情報を覚え、後続の動作においてその情報を使用することを可能にする。従来のLSTMは、セル、入力ゲート、出力ゲート、及び忘却ゲートを含む。3つのゲートは、セル内及びセル外への情報の流れ、及び情報がLSTM内で記憶される期間を調節する。VMMは、LSTMにおいて特に有用である。
【0140】
図25は、例示的なLSTM2500を示す。この例におけるLSTM2500は、セル2501、2502、2503、及び2504を含む。セル2501は、入力ベクトルx
0を受け取り、出力ベクトルh
0及びセル状態ベクトルc
0を生成する。セル2502は、入力ベクトルx
1と、セル2501からの出力ベクトル(隠れ状態)h
0と、セル2501からのセル状態c
0と、を受け取り、出力ベクトルh
1と、セル状態ベクトルc
1と、を生成する。セル2503は、入力ベクトルx
2と、セル2502からの出力ベクトル(隠れ状態)h
1と、セル2502からのセル状態c
1と、を受け取り、出力ベクトルh
2と、セル状態ベクトルc
2と、を生成する。セル2504は、入力ベクトルx
3と、セル2503からの出力ベクトル(隠れ状態)h
2と、セル2503からのセル状態c
2と、を受け取り、出力ベクトルh
3を生成する。追加のセルも使用可能であり、4つのセルを有するLSTMは、単なる例である。
【0141】
図26は、
図25のセル2501、2502、2503、及び2504に使用可能なLSTMセル2600の例示的な実装を示す。LSTMセル2600は、入力ベクトルx(t)と、先行するセルからのセル状態ベクトルc(t-1)と、先行するセルからの出力ベクトルh(t-1)と、を受け取り、セル状態ベクトルc(t)及び出力ベクトルh(t)を生成する。
【0142】
LSTMセル2600は、シグモイド関数デバイス2601、2602、及び2603を含み、各々が0~1の数を適用して、入力ベクトルの各成分が出力ベクトルに寄与する程度を制御する。LSTMセル2600はまた、入力ベクトルに双曲線正接関数を適用するためのtanhデバイス2604及び2605と、2つのベクトルを乗算するための乗算器デバイス2606、2607、及び2608と、2つのベクトルを加算するための加算器デバイス2609と、を含む。出力ベクトルh(t)は、システム内の次のLSTMセルに提供することができるか、又は他の目的でアクセスすることができる。
【0143】
図27は、LSTMセル2600の一実装の一例であるLSTMセル2700を示す。読者の便宜のために、LSTMセル2600からの同じ採番方法が、LSTMセル2700で使用される。シグモイド関数デバイス2601、2602、及び2603、並びにtanhデバイス2604は各々、複数のVMMアレイ2701及び活性化回路ブロック2702を含む。したがって、VMMアレイは、特定のニューラルネットワークシステムで使用されるLSTMセルにおいて特に有用であることが分かる。
【0144】
LSTMセル2700の代替例(及びLSTMセル2600の一実装の別の例)を
図28に示す。
図28では、シグモイド関数デバイス2601、2602及び2603、並びにtanhデバイス2604は、同じ物理ハードウェア(VMMアレイ2801及び活性化関数ブロック2802)を、時分割多重化された方式で共有し得る。LSTMセル2800はまた、2つのベクトルを乗算するための乗算器デバイス2803と、2つのベクトルを加算するための加算器デバイス2808と、(活性化回路ブロック2802を含む)tanhデバイス2605と、値i(t)を、i(t)がシグモイド関数ブロック2802から出力されるときに記憶するためのレジスタ2807と、値f(t)
*c(t-1)を、その値がマルチプレクサ2810を介して乗算器デバイス2803から出力されるときに記憶するためのレジスタ2804と、値i(t)
*u(t)を、その値がマルチプレクサ2810を介して乗算器デバイス2803から出力されるときに記憶するためのレジスタ2805と、値o(t)
*c~(t)を、その値がマルチプレクサ2810を介して乗算器デバイス2803から出力されるときに記憶するためのレジスタ2806と、マルチプレクサ2809と、を含む。
【0145】
LSTMセル2700がVMMアレイ2701とそれぞれの活性化関数ブロック2702との複数のセットを含むのに対し、LSTMセル2800は、LSTMセル2800の実施形態において複数の層を表すために使用される、VMMアレイ2801及び活性化関数ブロック2802の1つのセットのみを含む。LSTMセル2800は、LSTMセル2700と比較して、VMM及び活性化関数ブロックのために必要とするスペースは1/4で済むので、LSTMセル2800は、LSTM2700よりも必要とするスペースが少ない。
【0146】
LSTMユニットは典型的には複数のVMMアレイを含み、これらは各々、加算器及び活性化回路ブロック及び高電圧生成ブロックなどの、VMMアレイの外側の特定の回路ブロックによって提供される機能を必要とすることを更に理解することができる。各VMMアレイのための別個の回路ブロックを提供することは、半導体デバイス内にかなりの量のスペースを必要とし、幾分非効率的であろう。したがって、以下に記載される実施形態では、VMMアレイ自体の外側に必要とされる回路の最小化を試みる。
ゲート付き回帰型ユニット
【0147】
アナログVMM実装は、ゲート付き回帰型ユニット(gated recurrent unit、GRU)に利用することができる。GRUは、反復(recurrent)人工ニューラルネットワーク内のゲート機構である。GRUは、GRUセルが一般にLSTMセルよりも少ない構成要素を含むことを除いて、LSTMに類似している。
【0148】
図29は、例示的なGRU2900を示す。この例におけるGRU2900は、セル2901、2902、2903、及び2904を含む。セル2901は、入力ベクトルx
0を受け取り、出力ベクトルh
0を生成する。セル2902は、入力ベクトルx
1と、セル2901からの出力ベクトルh
0と、を受け取り、出力ベクトルh
1を生成する。セル2903は、入力ベクトルx
2と、セル2902からの出力ベクトル(隠れ状態)h
1と、を受け取り、出力ベクトルh
2を生成する。セル2904は、入力ベクトルx
3と、セル2903からの出力ベクトル(隠れ状態)h
2と、を受け取り、出力ベクトルh
3を生成する。追加のセルも使用可能であり、4つのセルを有するGRUは、単なる例である。
【0149】
図30は、
図29のセル2901、2902、2903、及び2904に使用することができるGRUセル3000の例示的な実装を示す。GRUセル3000は、入力ベクトルx(t)と、先行するGRUセルからの出力ベクトルh(t-1)と、を受け取り、出力ベクトルh(t)を生成する。GRUセル3000は、シグモイド関数デバイス3001及び3002を含み、それらの各々が、出力ベクトルh(t-1)及び入力ベクトルx(t)からの成分に0~1の数を適用する。GRUセル3000はまた、入力ベクトルに双曲線正接関数を適用するためのtanhデバイス3003と、2つのベクトルを乗算するための複数の乗算器デバイス3004、3005、及び3006と、2つのベクトルを加算するための加算器デバイス3007と、1から入力を減算して出力を生成するための相補デバイス3008と、を含む。
【0150】
図31は、GRUセル3000の一実装の一例であるGRUセル3100を示す。読者の便宜のために、GRUセル3000からの同じ採番方法が、GRUセル3100で使用される。
図31から分かるように、シグモイド関数デバイス3001及び3002、並びにtanhデバイス3003は各々、複数のVMMアレイ3101及び活性化関数ブロック3102を含む。したがって、VMMアレイは、特定のニューラルネットワークシステムで使用されるGRUセルにおいて特に使用されることが分かる。
【0151】
GRUセル3100の代替例(及びGRUセル3000の一実装の別の例)を
図32に示す。
図32において、GRUセル3200は、VMMアレイ3201及び活性化関数ブロック3202を利用しており、シグモイド関数として構成された場合には、0~1の数を適用して、入力ベクトルの各成分が出力ベクトルに寄与する程度を制御する。
図32では、シグモイド関数デバイス3001及び3002、並びにtanhデバイス3003は、同じ物理ハードウェア(VMMアレイ3201及び活性化関数ブロック3202)を、時分割多重化された方式で共有する。GRUセル3200はまた、2つのベクトルを乗算するための乗算器デバイス3203と、2つのベクトルを加算するための加算器デバイス3205と、1から入力を減算して、出力を生成するための相補デバイス3209と、マルチプレクサ3204と、値h(t-1)
*r(t)を、その値がマルチプレクサ3204を介して乗算器デバイス3203から出力されるときに保持するためのレジスタ3206と、値h(t-1)
*z(t)を、その値がマルチプレクサ3204を介して乗算器デバイス3203から出力されるときに保持するためのレジスタ3207と、値h^(t)
*(1-z((t))を、その値がマルチプレクサ3204を介して乗算器デバイス3203から出力されるときに保持するためのレジスタ3208と、を備える。
【0152】
GRUセル3100がVMMアレイ3101及び活性化関数ブロック3102の複数のセットを含むのに対し、GRUセル3200は、GRUセル3200の実施形態において複数の層を表すために使用される、VMMアレイ3201及び活性化関数ブロック3202の1つのセットのみを含む。GRUセル3200は、GRUセル3100と比較して、VMM及び活性化関数ブロックのために必要とするスペースは1/3で済むので、GRUセル3200は、GRUセル3100よりも必要とするスペースが少ない。
【0153】
GRUを利用するシステムは、典型的には複数のVMMアレイを含み、これらの各々は、加算器及び活性化回路ブロック及び高電圧生成ブロックなどの、VMMアレイの外側の特定の回路ブロックによって提供される機能を必要とすることを更に理解することができる。各VMMアレイのための別個の回路ブロックを提供することは、半導体デバイス内にかなりの量のスペースを必要とし、幾分非効率的であろう。したがって、以下に記載される実施形態では、VMMアレイ自体の外側に必要とされる回路の最小化を試みる。
【0154】
VMMアレイへの入力は、アナログレベル、バイナリレベル、タイミングパルス、又はデジタルビットであり得、出力は、アナログレベル、バイナリレベル、タイミングパルス、又はデジタルビット(この場合、出力アナログレベルの電流又は電圧をデジタルビットに変換するために出力ADCが必要とされる)であり得る。
【0155】
VMMアレイ内の各メモリセルに関して、各重みwは、単一のメモリセルによって、又は差分セルによって、又は2つのブレンドメモリセル(2つ以上のセルの平均)によって実装することができる。差分セルの場合では、重みwを差分重み(w=w+-w-)として実装するために、2つのメモリセルが必要とされる。2つのブレンドメモリセルの場合は、2つのセルの平均として重みwを実装するために2つのメモリセルが必要とされる。
VMM内のセルの精密なチューニングのための実施形態
【0156】
図33は、VMMシステム3300のブロック図を示す。VMMシステム3300は、VMMアレイ3301、行デコーダ3302、高電圧デコーダ3303、列デコーダ3304、ビット線ドライバ3305、入力回路3306、出力回路3307、制御論理3308、及びバイアス生成器3309を備える。VMMシステム3300は、チャージポンプ3311、チャージポンプレギュレータ3312、及び高電圧レベル生成器3313を含む、高電圧生成ブロック3310を更に備える。VMMシステム3300は、アルゴリズムコントローラ3314、アナログ回路3315、制御論理3316、及びテスト制御論理3317を更に備える。以下に記載されるシステム及び方法は、VMMシステム3300に実装され得る。
【0157】
入力回路3306は、DAC(digital to analog converter)(デジタル-アナログ変換器)、DPC(digital to pulses converter)(デジタル-パルス変換器)、AAC(analog to analog converter)(電流-電圧変換器などのアナログ-アナログ変換器)、PAC(pulse to analog level converter)(パルス-アナログレベル変換器)、又は任意の他のタイプの変換器などの回路を含み得る。入力回路3306は、正規化関数、スケーリング関数、又は算術関数を実装し得る。入力回路3306は、入力のための温度補償関数を実装し得る。入力回路3306は、ReLU又はシグモイド関数などの活性化関数を実装し得る。
【0158】
出力回路3307は、ADC(ニューロンアナログ出力をデジタルビットに変換するための、アナログ-デジタル変換器)、AAC(電流-電圧変換器などのアナログ変換器)、APC(アナログ-パルス変換器)、又は任意の他のタイプの変換器などの回路を含み得る。出力回路3307は、ReLU又はシグモイド関数などの活性化関数を実装し得る。出力回路3307は、ニューロン出力のための正規化関数、スケーリング関数、又は算術関数を実装し得る。出力回路3307は、以下に記載されるように、ニューロン出力又はアレイ出力(ビット線出力など)のための温度補償関数を実装し得る。
【0159】
図34は、VMMシステム3300内のアルゴリズムコントローラ3314によって実行することができるチューニング(メモリセルを目標にプログラム又は消去する)補正方法3400を示す。チューニング補正方法3400は、セル出力及びセルの元の目標から生じる最終誤差に基づいて適応目標を生成する。この方法は、典型的には、チューニングコマンドが受信されることに応答して開始する(ステップ3401)。選択されたセル、又は選択されたセルのグループの(プログラム/検証アルゴリズムに使用される)初期電流目標Itargetv(i)は、関数又はルックアップテーブルを使用することなどによって予測目標モデルを使用して決定され、変数DeltaErrorは、0に設定される(ステップ3402)。目標関数は、使用される場合、選択されたメモリセル又はセルのグループのI-Vプログラム曲線に基づくであろう。目標関数はまた、(セクタ内のセルアドレス及びセルレベルに依存し、ここで、セルは、それがより比較的多くの異常を示す場合、抑制条件でより多くのプログラム時間に供され、ここで、より高い電流を有するセルは、典型的にはより多くの異常を有する)セルが示すプログラム異常の程度、セル間連結、及び様々なタイプのアレイノイズなどのアレイ特性によって引き起こされる様々な変動に依存する。これらの変動は、PVT(process, voltage, temperature)(プロセス、電圧、温度)上のケイ素上で特徴付けることができる。ルックアップテーブルは、使用される場合、I-V曲線及び様々な変動をエミュレートするための同じ方法で特徴付けることができる。
【0160】
次いで、ソフト消去が、VMM内の全てのセルに対して実行され、このソフト消去は、各セルが、読み出し動作中に例えば約3~5μAの電流を引き込むように、全てのセルに対して中間弱消去レベルに消去を行う(ステップ3403)。ソフト消去は、例えば、中間セル電流に達するまで、セルに増分消去パルス電圧を印加することによって実行される。次に、プログラミング動作(目標へのディーププログラミング又は粗い/微細プログラミングなどによる)が、<pA電流レベル又は等価ゼロ重みに達するように、全ての未使用セルに対して実行される(ステップ3404)。次いで、誤差結果に基づく目標調整(補正)が実行される。セルがプログラミング中にオーバーシュートを受けたことを意味する、DeltaError>0の場合、Itargetv(i+1)は、Itarget+シータ*DeltaErrorに設定され、シータは、例えば、1、又は1に近い数である(ステップ3405A)。
【0161】
Itarget(i+1)はまた、適切な誤差目標調整/補正を用いて、前のItarget(i)に基づいて調整され得る。DeltaError<0である場合、セルがプログラミング中にアンダーシュートを受けたことを意味するが、これは、セル電流がまだ目標に達しないことを意味し、その後、Itargetv(i+1)は、前の目標Itargetv(i)に設定される(ステップ3405B)。
【0162】
次に、粗い及び/又は微細プログラム並びに検証動作が実行される(ステップ3406)。精密(微細)プログラミングステップを実行する前に、複数の徐々に小さくなる粗い目標を目標とすることなどによって、複数の適応型の粗いプログラミング方法を使用して、プログラミングを加速することができる。適応型の精密プログラミングは、例えば、微細(精密)増分プログラム電圧パルス又は定常プログラムタイミングパルスで行われる。粗いプログラミング及び微細プログラミングを実行するためのシステム及び方法の例は、本出願と同じ譲受人によって2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。
【0163】
Icellを、選択されたセルで測定する(ステップ3407)。例えば、セル電流は、電流計回路によって測定することができる。例えば、セル電流は、ADC(アナログ-デジタル変換器)回路によって測定することができ、この場合、出力は、デジタルビットによって表される。例えば、セル電流は、I-V(電流-電圧変換器)回路によって測定することができ、この場合、出力は、アナログ電圧によって表される。DeltaErrorは計算され、これは、測定されたセルにおける実際の電流(Icell)と目標電流(Itarget)との間の差を表す、Icell-Itargetである。|DeltaError|<DeltaMarginの場合、セルは、特定の許容範囲(DeltaMargin)内の目標電流を達成しており、方法は終了する(ステップ3410)。|DeltaError|=abs(DeltaError)=DeltaErrorの絶対値。そうでない場合、方法は、ステップ3403に戻り、ステップを再び順次実行する(ステップ3410)。
【0164】
図35A及び
図35Bは、VMMシステム3300内のアルゴリズムコントローラ3314によって実行することができるチューニング補正方法3500を示す。
図35Aを参照すると、方法が開始し(ステップ3501)、これは、典型的には、チューニングコマンドが受信されることに応じて行われる。VMMアレイ全体が、ソフト消去法などによって消去される(ステップ3502)。セル電流<pAレベル又は等価ゼロ重みを得るために、全ての未使用セルに対してプログラミング動作(目標へのディーププログラミング又は粗い/微細プログラミングなどによる)が実行される(ステップ3503)。VMMアレイ内の全てのセルが、粗い及び/又は微細プログラミングサイクルを使用して、0.5~1.0μAなどの中間値にプログラムされ(ステップ3504)、粗いプログラミング及び微細プログラミングを実行するためのシステム及び方法の例は、本出願と同じ譲受人によって2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。予測目標は、上記のように、関数又はルックアップテーブルを使用して使用されるセルに設定される(ステップ3505)。次に、セクタチューニング方法3507が、VMMの各セクタに対して実行される(ステップ3506)。セクタは、典型的には、アレイ内の2つ以上の隣接する行からなる。
【0165】
図35Bは、適応目標セクタチューニング方法3507を示す。セクタ内の全てのセルは、(1)粗い/微細/定常P/Vサイクル、(2)CG+(CG増分のみ)若しくはEG+(EG増分のみ)、又は相補的CG+/EG-(CG増分及びEG減分)、並びに(3)最初に最も深いプログラムされたセル(セルをグループにグループ化することを意味し、グループが、最初に最低電流プログラムされたセルを有する、漸進的グループ化など)、などの個々又は組み合わせのプログラム/検証(P/V)方法を使用して、最終的な所望の値(例えば、1nA~50nA)にプログラムされる(ステップ3508A)。次に、Icell<Itargetであるかどうかに関する決定が行われる。はいの場合、方法は、ステップ3509に進む。いいえの場合、方法は、ステップ3508Aを繰り返す。ステップ3509において、測定されたIcell-Itarget(i+1)に等しい、DeltaErrorを測定する(ステップ3509)。|DeltaError|<DeltaMarginであるかどうかに関する決定が行われる(ステップ3510)。はいの場合、方法は、完了する(ステップ3511)。いいえの場合、目標調整が実行される。セルがプログラミング中にオーバーシュートを受けたことを意味する、DeltaError>0の場合、目標は、新しい目標をItarget+シータ
*DeltaErrorに設定することによって調整され、ここで、シータは、典型的には=1である(ステップ3512A)。Itarget(i+1)はまた、適切な誤差目標調整/補正を用いて、前のItarget(i)に基づいて調整され得る。DeltaError<0の場合、セルがプログラミング中にアンダーシュートを受けたことを意味するが、これは、セルがまだ目標に達していないことを意味し、目標は、Itargetv(i+1)=Itargetv(i)を意味する、前の目標を維持することによって調整される(ステップ3512B)。セクタをソフト消去する(ステップ3513)。セクタ内の全てのセルを中間値にプログラムし(ステップ3514)、ステップ3509に戻る。
【0166】
典型的なニューラルネットワークは、正の重みw+及び負の重みw-、合計重み=w+-w-を有し得、w+及びw-は、メモリセルによって各々実装され(それぞれIw+及びIw-)、合計重み(Iw=Iw+-Iw-、電流減算)は、(アレイビット線出力回路などを使用することによって)周辺回路レベルで実行することができる。したがって、合計重みの重みチューニング実施形態は、表8に示されるような例において、w+セルとw-セルの両方を同時にチューニングすること、w+セルのみをチューニングすること、又はw-セルのみをチューニングすることを含み得る。チューニング動作は、
図34/
図35A/
図35Bに関して前述したプログラム/検証及び誤差目標調整方法を使用して実行される。検証動作は、合計重みのみ(例えば、合計重み電流を測定する/読み出すが、個々の正のw+セル電流若しくはw-セル電流を測定しない/読み出さないこと)、w+セル電流のみ、又はw-セル電流のみについて実行することができる。
【0167】
例えば、3nAの合計Iwの場合、Iw+は3nAであり得、Iw-は0nAであり得る。あるいは、Iw+は13nAであり得、Iw-は10nAであり得、これは、正の重みIw+と負の重みIw-の両方がゼロではないことを意味する(例えば、ゼロは、深くプログラムされたセルを示し得る)。これは、Iw+とIw-の両方がノイズの影響をより受けにくくなるはずであるため、特定の動作条件で好ましい場合がある。
表8:重みチューニング方法(値はnA単位の電流値である)
【表9】
【0168】
したがって、式w=(w+)-(w-)に従う差動重みマッピングを使用して、ニューラルネットワークで使用するためのチューニング値wを記憶することができる。w+及びw-のマッピングは、例えば、各値が記憶されるw+及びw-にオフセット値を含めることによって、ニューラルネットワーク内のVMMアレイにおいて生じる特定の問題に対処するように最適化することができる。
【0169】
一実施形態において、重みマッピングは、RTNノイズを低減するように最適化される。例えば、wの所望の値が0nA(ゼロw又は未使用メモリセル)である場合、1つの可能なマッピングは、(w+)=0nA及び(w-)=0nAであり、別の可能なマッピングは、(w+)=30nA及び(w-)=30nAであり、ここで、30nAは、記憶前に各w+及びw-値に加算される非ゼロのオフセット値の一例である。そのような非ゼロのオフセット値を含むことは、最終的により多くの電力を消費し、チューニングプロセス中により大きな不正確さを招くが、任意のノイズの影響を最小限に抑える。同様に、wの所望の値が1nAである場合、1つの可能なマッピングは、(w+)=1nA及び(w-)=0nAであり、別の可能なマッピングは、(w+)=30nA及び(w-)=29nAである。後者は、より多くの電力を消費し、チューニングプロセス中により大きな不正確さを招く可能性があるが、任意のノイズの影響を最小限に抑える。
【0170】
別の実施形態では、ゼロの重みwに対して、w+及びw-の両方は、ここで説明される検証動作のためのバイアスオフセット電圧の方法を使用することなどによって、ほぼゼロであるようにチューニングされることができる。この方法の場合では、w+及びw-の両方は、例えば、推論(読み出し)に使用された通常のCG電圧よりも高い制御ゲート電圧(VCG)で5nAにチューニングされる。例えば、dVCG/Ir=2mV/1nAに対して、VCG=1.5Vの値が推論において使用される場合、チューニングアルゴリズム(重みチューニングのためのプログラム検証アルゴリズム)において、VCG=1.510Vの値は、5nAの目標に達するゼロ重みセルを検証するために使用される。推論動作では、VCG=1.5Vが使用されるので、セル電流は1nA当たり2mVシフトダウンされ、したがって、検証動作における5nAは推論動作において約0nAになる。
【0171】
別の実施形態では、ゼロ重みwに対して、w+及びw-の両方は、検証動作のためのバイアスオフセット電圧の負電流チューニング方法を使用することなどによって、負電流を有するようにチューニングされることが可能であり、これについて以下で説明する。この場合、w+及びw-の両方は、例えば、推論(読み出し)に使用された通常のCG電圧よりも高い制御ゲート電圧(VCG)で-10nAにチューニングされる。例えば、dVCG/Ir=2mV/1nAに対して、VCG=1.5Vの値が推論において使用される場合、チューニングアルゴリズム(重みチューニングのためのプログラム検証アルゴリズム)において、VCG=1.530Vが、5nAの目標に達するゼロ重みセルを検証するために使用される。推論動作では、VCG=1.5Vが使用されるので、セル電流は1nA当たり2mVシフトダウンされ、したがって、検証動作における5nAは推論動作において約10nAになる。
【0172】
オフセットバイアス条件又はバイアス(電圧及び/又は電流及び/又はタイミング及び/又は温度)シーケンスの同様の方法は、著しいノイズ(RTNノイズ、熱ノイズ、又は任意の他のノイズ源など)の影響を受けやすいセルなどの異常ビットを検出するためのテストスクリーニングの目的で使用することができる。基本的に、メモリセルからのノイズを他のバイアス条件又はバイアスシーケンスよりも大幅に減衰させること(ノイズ減衰テスト)によって、ノイズをより良く検出するために使用することができるバイアス条件又はバイアスシーケンスがある。例えば、20nAのメモリセルに対して、このセルに対するバイアス条件を変調することによって、例えば、テストスクリーニングにおいて制御ゲートバイアス電圧を変化させることなどによって、このセルを別の条件に置くことから、望ましくない挙動を検出することが有利であり得る。例えば、テスタ制限又は回路制限により、バイアス条件を変調することによって、より高い電流レベルでノイズ(RTNノイズなど)の影響を受けやすいビット/セルを検出することが有利であり得る。
【0173】
メモリセルに対するRTNノイズスクリーニングなどのノイズレベルをスクリーニング又は検証する別の方法は、メモリセル出力をサンプリングすることである(4/8/.../1024回など、多数回出力を測定することなどによって)。スクリーニング基準は、任意のサンプルインスタンスの値がサンプルの平均よりもある量だけ大きいようなものである。別のスクリーニング基準は、1つのサンプルの値が次のサンプルよりもある量だけ大きいことである。これらの技法は、出願人により2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。
【0174】
上記の重み割り当てのいくつかを組み込んだメモリセルの重みをチューニングする(セルをプログラム又は消去する)方法は、セルをソフト消去し、次いでゼロ重みセル(上記など)をプログラムし、次いで上記で説明したようなノイズスクリーニングを用いて、粗い並びに微細及び/又は超微細チューニングアルゴリズムを実行することを含むことができる。粗い、微細、及び超微細チューニングアルゴリズムのための技法は、2020年3月25日に出願され、「Precise Data Tuning Method and Apparatus for Analog Neural Memory in an Artificial Neural Network」と題された米国特許出願第16/829,757号における出願によって以前に開示されており、これは、参照により本明細書に組み込まれる。
【0175】
別の実施形態では、バイアス条件シーケンシングを含む読み出し(推論)又は検証の方法を使用することによって、ノイズ寄与を低減することができる。例えば、蓄積条件は、読み出し又は検証動作が実行される前にメモリセルに対して実行される。
【0176】
別の実施形態では、制御ゲートに負電圧範囲を印加することによって、ノイズ寄与を低減することができる。別の実施形態では、ゼロ重み及び未使用セルに対するアレイのバックグラウンドデータは、変動を低減するための特定のパターンであり得る。例えば、高電流レベルバックグラウンドは、RTNノイズ低減などのノイズに対して望ましい場合がある。例えば、低電流レベルバックグラウンドは、データドリフトなどのノイズに対して望ましい場合がある。スタンバイ又はディープパワーダウンにおいて、アレイは、制御ゲート電圧を変調することによって、例えば、検証動作中に使用された制御ゲート電圧と比較して特定の電圧レベルを使用することによって、正しい状態に置かれ、これは、制御ゲートレベルが、スタンバイ又はディープパワーダウン動作中に電流を下げるか又は電流レベルを上げるように設定され得ることを意味する。
【0177】
別の実施形態では、読み出し又は検証の方法は、読み出し又は検証動作中に制御ゲートに0V、約0V、又は低バイアス電圧を印加することによって実行される。ワード線は、ワード線に印加されたパルス幅変調入力又はアナログ電圧などを介して、行データ入力(活性化値)を受け取るために、制御ゲート線の代わりに使用される。
【0178】
別の実施形態では、wに対する「0」値(ゼロw又は未使用セル)は、<10nA又は別の所定のスレッショルドとして定義することができる。すなわち、(w+)-(w-)<10nAの場合、wには「0」の値が与えられる。これは、w=0のたびにより大きな公差を提供し、ノイズ、温度変動、又は他の力によって引き起こされた不正確さに対してよりロバストである。
【0179】
別の実施形態では、重みマッピングは、温度変動を低減するように最適化される。例えば、wの所望の値が5nAである場合、1つの可能なマッピングは、(w+)=5nA及び(w-)=0nAであり、別の可能なマッピングは、(w+)=30nA及び(w-)=25nAである。後者は、より多くの電力を消費し、チューニングプロセス中により大きな不正確さを招く可能性があるが、温度変動を最小限に抑える。
【0180】
別の実施形態では、重みマッピングは、ニューロンの総ノイズ又は温度変動を低減するように最適化される。例えば、ビット線当たりの記憶されたw+及びw-値の数(例えば、5nAの場合、30nA~25nA又は50nA~45nA又は80nA~75nAとして実装することができる)は、ビット線当たりの記憶された値の数が全てのビット線に対してほぼ同じになるように、全てのビット線の間でバランスをとるようにマッピングすることができる。
【0181】
別の実施形態では、重みマッピングは、ニューロン(ビット線)の総ノイズを低減するように最適化される。例えば、ビット線ごとの記憶されたw+及びw-値(セル)の数は、ニューロン(ビット線)内の全ての重み(セル)の総ノイズ寄与が最適である(最小ノイズを有する)ように、全てのビット線の間でバランスをとることができる。
表9A:重みチューニング方法
【表9A】
表9B:重みチューニング方法
【表9B】
【0182】
表9A及び9Bは、nAで16個のレベル(状態)の例示的な実施形態を示す。すなわち、メモリセルは、ここに示されるように16個のレベルを有することができる。表9Aは、式Iw=Iw+-Iw-に従って、wが16個の異なる正の値のうちの1つであり得る状況を示し、表9Bは、wが16個の異なる負の値のうちの1つであり得る状況を示す。表に示される電流範囲は、0~80nAである。
表10A:重みチューニング方法
【表10A】
表10B:重みチューニング方法
【表10B】
【0183】
表10A及び10Bは、0~80nAから40nA~85nAへとレベルの動的全電流範囲を圧縮する実施形態を示す。
【0184】
表10A/11A/12Aに関して、Iw-は、粗い又は微細又は超微細チューニングステップ(例えば、Iw-セルのプログラム及び検証)を用いてチューニングされ得、Iw+は、微細又は超微細ステップ(例えば、Iw=(Iw+-Iw-)のプログラム及び検証、又は単にIw+セルのみの検証)を用いてチューニングされ得る。表10B/11B/12Bに関して、Iw+は、粗い又は微細又は超微細チューニングステップ(例えば、Iw+セルのプログラム及び検証)を用いてチューニングすることができ、Iw-は、微細又は超微細ステップ(例えば、Iw=(Iw+-Iw-)のプログラム及び検証、又は単にIwセルのみの検証)を用いてチューニングされ得る。
【0185】
これは、プロセス、温度、ノイズ、動作応力、又は動作条件による変動及び不整合を低減するという点で有利であり、これは、
図11~
図12に示される概念と同様である。
【0186】
表10A及び表10Bに示すように、表の下半分の値は、それらの値の全範囲が表の上半分とほぼ同じになるように、正の量(オフセットバイアス)だけシフトアップされる。オフセットは、最大電流(レベル)の半分にほぼ等しい。
表11A:重みチューニング方法
【表11A】
表11B:重みチューニング方法
【表11B】
【0187】
表11A及び11Bは、オフセットバイアス値に等しいゼロ重み(w=0)を有する、
図10A及び10Bの実施形態と同様の実施形態を示す。例として、1つのオフセットバイアス値に対する重み値の1つの範囲、2つのオフセット値に対する重みの2つのサブ範囲を示す。
表12A:重みチューニング方法
【表12A】
表12B:重みチューニング方法
【表12B】
表13:重みチューニング方法
【表13】
表13は、正の重み及び負の重みに対して変動オフセットを使用する実施形態を示す。
表14:重みチューニング方法
【表14】
表14は、正の重み及び負の重みに対して共通のオフセットを使用する実施形態を示す。
表15:重みチューニング方法
【表15】
表15は、重みに対して増加するオフセットを使用する実施形態を示す。
表16:重みチューニング方法
【表16】
表16は、重みに対して減少するオフセットを使用する実施形態を示す。それはまた、Iw+に対する一定のオフセットを示す。それはまた、Iw+に対する最大定数値を示し、基本的に全ての重みを最大値に向かってシフトする。
【0188】
表12A及び表12Bは、
図10A及び
図10Bの実施形態と同様の実施形態を示し、各w+又はw+値は、2つのメモリセルによって実装されて、合計ダイナミックレンジを更に約半分に低減する。
【0189】
上記の実施形態に提供されたw+及びw-に対する値は単なる例であり、開示される概念に従って他の値を使用することができることを理解されたい。
例えば、オフセットバイアス値は、各レベルの値をシフトする任意の値であってもよいし、又は全てのレベルに対して固定値であってもよい。実際には、各wは差動セルとして実装され、これは、プロセス、温度、ノイズ(RTN又は電源ノイズなど)、応力、又は動作条件からの変動又は不整合を最小限に抑えるのに有効であり得る。
【0190】
図36Aは、(一例としてスブスレッショルド領域における)温度にわたるデータ挙動(I-V曲線)を示し、
図36Bは、VMMシステムの動作中のデータドリフトによって生じた問題を示し、
図36C及び
図36Dは、データドリフトを補償するためのブロックを示し、
図36Cに関しては、温度変化を補償するためのブロックを示す。
【0191】
図36Aは、VMMシステムの既知の特性を示すものであり、その特性は、動作温度が増加するにつれて、VMMアレイ内の任意の所与の選択された不揮発性メモリセル内の検知電流がサブスレッショルド領域内で増加するか、飽和領域内で減少するか、又は概して線形領域内で減少するような特性である。
【0192】
図36Bは、時間使用(データドリフト)にわたるアレイ電流分布を示し、これは、(VMMアレイ内の全てのビット線からの電流の合計である)VMMアレイからの集合出力が、動作時間使用にわたって右に(又は、使用される技術によっては、左に)シフトすることを示しており、これは、総集合出力が、VMMシステムの寿命使用にわたってドリフトすることを意味する。この現象は、データが環境要因による使用条件及び劣化によってドリフトするときの、データドリフトとして知られている。
【0193】
図36Cは、データドリフトを補償するために、ビット線出力回路3610の出力に補償電流i
COMPを注入することを含み得るビット線補償回路3600を示す。ビット線補償回路3600は、抵抗器又はコンデンサネットワークに基づいて、スケーラ回路によって出力を上又は下にスケーリングすることを含み得る。ビット線補償回路3600は、その抵抗器又はコンデンサネットワークに基づいて、シフト回路によって出力をシフト又はオフセットすることを含み得る。
【0194】
図36Dは、データドリフトの量を検出するデータドリフトモニタ3620を示す。次いで、その情報は、ビット線補償回路3600への入力として使用され、その結果、i
COMPの適切なレベルが選択され得る。
【0195】
図37は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路3700を示す。ビット線補償回路3700は、調整可能な電流源3701及び調整可能な電流源3702を備え、これらは、一緒になってi
COMPを生成し、i
COMPは、調整可能な電流源3701から生成された電流から、調整可能な電流源3701によって生成された電流を引いた電流に等しい。
【0196】
図38は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路3700を示す。ビット線補償回路3800は、動作増幅器3801、調整可能な抵抗器3802、及び調整可能な抵抗器3803を備える。動作増幅器3801は、その非反転端子上で基準電圧VREFを受信し、その反転端子上でV
INPUTを受信し、ここで、V
INPUTは、
図36Cのビット線出力回路3610から受信された電圧であり、V
OUTPUTの出力を生成し、ここで、V
OUTPUTは、抵抗器3803と抵抗器3802の比に基づいてデータドリフトを補償するためのV
INPUTのスケーリングされたバージョンである。抵抗器3803及び/又は3802の値を構成することにより、V
OUTPUTは、上又は下にスケーリングされ得る。
【0197】
図39は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路3900を示す。ビット線補償回路3900は、動作増幅器3901、電流源3902、スイッチ3904、及び調整可能な積分出力コンデンサ3903を備える。ここで、電流源3902は、実際には、VMMアレイにおいて、単一のビット線、又は複数のビット線の集合体(正の重みw+を合計するための1つ、及び負の重みw-を合計するための1つなど)の出力電流である。動作増幅器3901は、その非反転端子上で基準電圧VREFを受信し、その反転端子上でV
INPUTを受信し、ここで、V
INPUTは、
図36Cのビット線出力回路3610から受信された電圧である。ビット線補償回路3900は、調整可能な積分時間においてコンデンサ3903全体にわたって電流Ineuを積分して出力電圧V
OUTPUTを生成する積分器として機能し、ここで、V
OUTPUT=Ineu
*積分時間/C
3903であり、ここで、C
3903は、コンデンサ3903の値である。したがって、出力電圧V
OUTPUTは、(ビット線)出力電流Ineuに比例し、積分時間に比例し、コンデンサ3903の容量に反比例する。ビット線補償回路3900は、V
OUTPUTの出力を生成し、ここで、V
OUTPUTの値は、コンデンサ3903の構成値及び/又はデータドリフトを補償するための積分時間に基づいてスケーリングされる。
【0198】
図40は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路4000を示す。ビット線補償回路4000は、M:N比を有する電流ミラー4010を備え、これは、I
COMP=(M/N)
*i
inputを意味する。電流ミラー4010は、電流i
INPUTを受信し、その電流をミラーリングし、任意選択的に、その電流をスケールしてi
COMPを生成する。したがって、M及び/又はN個のパラメータを構成することによって、i
COMPは、上方又は下方にスケーリングされ得る。
【0199】
図41は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路4100を示す。ビット線補償回路4100は、動作増幅器4101、調整可能なスケーリング抵抗器4102、調整可能なシフト抵抗器4103、及び調整可能な抵抗器4104を備える。動作増幅器4101は、その非反転端子上で基準電圧V
REFを受信し、その反転端子上でV
INを受信する。V
INは、V
INPUT及びVshftに応答して生成され、ここで、V
INPUTは、
図36Cのビット線出力回路3610から受信された電圧であり、Vshftは、V
INPUTとV
OUTPUTとの間でシフトを実装することを意図した電圧である。
したがって、V
OUTPUTは、データドリフトを補償するための、V
INPUTのスケーリング及びシフトされたバージョンである。
【0200】
図42は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路4200を示す。ビット線補償回路4200は、動作増幅器4201、入力電流源Ineu4202、電流シフタ4203、スイッチ4205及び4206、並びに調整可能な積分出力コンデンサ4204を備える。ここで、電流源4202は、実際には、VMMアレイ内の単一又は複数のビット線上の出力電流Ineuである。動作増幅器4201は、その非反転端子上で基準電圧VREFを受信し、その反転端子上でI
INを受信することであって、ここで、I
INは、Ineuと、電流シフタ4203によって出力された電流との合計である、受信することと、V
OUTPUTの出力を生成することであって、ここで、V
OUTPUTは、データドリフトを補償するために、(コンデンサ4204に基づいて)スケーリングされ、(Ishifter4203に基づいて)シフトされる、生成することと、を行う。
【0201】
図43~
図48は、プログラミング又は読み出し動作中に、各選択されたセルにプログラム又は読み出されるW値を提供するために使用され得る様々な回路を示す。
【0202】
図43は、調整可能な電流源4301及び調整可能な電流源4302を備えるニューロン出力回路4300を示し、これらは、一緒になってI
OUTを生成し、I
OUTは、調整可能な電流源4301によって生成された電流I
W+から、調整可能な電流源4302によって生成された電流I
W-を引いた電流に等しい。調整可能な電流Iw+4301は、正の重みを実装するために、セル電流又はニューロン電流(ビット線電流など)のスケーリングされた電流である。調整可能な電流Iw-4302は、負の重みを実装するために、セル電流又はニューロン電流(ビット線電流など)のスケーリングされた電流である。電流スケーリングは、M:N比電流ミラー回路、Iout=(M/N)
*Iinなどによって行われる。
【0203】
図44は、調整可能なコンデンサ4401、制御トランジスタ4405、スイッチ4402、スイッチ4403、及び調整可能な電流源4404Iw+を備えるニューロン出力回路4400を示し、これは、M:N電流ミラー回路などによってセル電流又は(ビット線)ニューロン電流のスケーリングされた出力電流である。トランジスタ4405は、例えば、電流4404に固定バイアス電圧を課すために使用される。回路4404は、V
OUTを生成し、ここで、V
OUTは、コンデンサ4401に反比例し、調整可能な積分時間(スイッチ4403が閉じスイッチ4402が開いた時間)に比例し、調整可能な電流源4404によって生成された電流I
W+に比例する。V
OUTは、V+-((Iw+
*積分時間)/C
4401)に等しく、ここで、C
4401は、コンデンサ4401の値である。コンデンサ4401の正の端子V+は、正の供給電圧に接続され、コンデンサ4401の負の端子V-は、出力電圧V
OUTに接続される。
【0204】
図45は、コンデンサ4401及び調整可能な電流源4502を備えるニューロン回路4500を示し、これは、M:N電流ミラーなどによるセル電流又は(ビット線)ニューロン電流のスケーリングされた電流である。回路4500は、V
OUTを生成し、ここで、V
OUTは、コンデンサ4401に反比例し、調整可能な積分時間(スイッチ4501が開いた時間)に比例し、調整可能な電流源4502によって生成された電流I
Wiに比例する。コンデンサ4401は、電流Iw+を積分する動作を完了した後、ニューロン出力回路44から再使用される。次いで、正の端子及び負の端子(V+及びV-)は、ニューロン出力回路45内で交換され、そこでは、正の端子は、出力電圧V
OUTに接続され、これは、電流Iw-によって積分解除される。負の端子は、クランプ回路(図示せず)によって前の電圧値に保持される。実際には、出力回路44は、正の重み実装に使用され、回路45は、負の重み実装に使用され、コンデンサ4401上の最終電荷は、合計重み(Qw=Qw+-Qw-)を効果的に表す。
【0205】
図46は、調整可能なコンデンサ4601、スイッチ4602、制御トランジスタ4604、及び調整可能な電流源4603を備えるニューロン回路4600を示す。回路4600は、V
OUTを生成し、ここで、V
OUTは、コンデンサ4601に反比例し、調整可能な積分時間(スイッチ4602が開いていた時間)に比例し、調整可能な電流源4603によって生成された電流I
W-に比例する。コンデンサ4601の負の端子V-は、例えば、接地に等しい。コンデンサ4601の正の端子V+は、例えば、電流Iw-を積分する前に、正の電圧に最初にプリチャージされる。ニューロン回路4600は、ニューロン回路4400と共にニューロン回路4500の代わりに使用して、合計重み(Qw=Qw+-Qw-)を実装することができる。
【0206】
図47は、動作増幅器4703及び4706、調整可能な電流源Iw+4701及びIw-4702、並びに調整可能な抵抗器4704、4705、及び4707を備えるニューロン回路4700を示す。ニューロン回路4700は、V
OUTを生成し、これは、R
4707
*(Iw+-Iw-)に等しい。調整可能な抵抗器4707は、出力のスケーリングを実装する。調整可能な電流源Iw+4701及びIw-4702はまた、M:N比電流ミラー回路(Iout=(M/N)
*Iin)などによる出力のスケーリングを実装する。
【0207】
図48は、動作増幅器4803及び4806、スイッチ4808及び4809、調整可能な電流源Iw-4802及びIw+4801、調整可能なコンデンサ4804、4805、及び4807を備えるニューロン回路4800を示す。ニューロン回路4800は、V
OUTを生成し、これは、(Iw+-Iw-)に比例し、積分時間(スイッチ4808及び4809が開いていた時間)に比例し、コンデンサ4807の容量に反比例する。調整可能なコンデンサ4807は、出力のスケーリングを実装する。調整可能な電流源Iw+4801及びIw-4802はまた、M:N比電流ミラー回路(Iout=(M/N)
*Iin)などによる出力のスケーリングを実装する。積分時間はまた、出力スケーリングを調整することができる。
【0208】
【0209】
図49Aでは、出力回路4901は、ADC回路4911を備え、これは、アナログニューロン出力4910を直接デジタル化してデジタル出力ビット4912を提供するために使用される。
【0210】
図49Bでは、出力回路4902は、ニューロン出力回路4921及びADC4911を備える。ニューロン出力回路4921は、ニューロン出力4920を受信し、それを整形し、その後、それをADC回路4911によってデジタル化して、出力4912を生成する。ニューロン出力回路4921は、前述のような正規化、スケーリング、シフト、マッピング、算術演算、活性化、及び/又は温度補償に使用することができる。ADC回路は、シリアル(傾斜若しくはランプ若しくはカウント)ADC、SAR ADC、パイプラインADC、シグマデルタADC、又は任意のタイプのADCであり得る。
【0211】
図49Cでは、出力回路は、ニューロン出力4930を受信するニューロン出力回路4921を備え、変換器回路4931は、ニューロン出力回路4921からの出力を出力4932に変換するためのものである。変換器4931は、ADC、AAC(電流-電圧変換器などのアナログ-アナログ変換器)、APC(アナログ-パルス変換器)、又は任意の他のタイプの変換器を備えることができる。ADC4911又は変換器4931は、例えば、ビットマッピング(例えば、量子化)又はクリッピング(例えば、クリップピングされたReLU)によって、活性化関数を実装するために使用され得る。ADC4911及び変換器4931は、より低い又はより高い精度(例えば、より低い又はより高い数のビット)、より低い又はより高い性能(例えば、より遅い又はより速い速度)などのように構成可能であり得る。
【0212】
スケーリング及びシフトのための別の実施形態は、アレイ(ビット線)出力を、より少ない又はより多いビット精度を有するものなどのデジタルビットに変換し、次いで、特定の関数(例えば、線形又は非線形、圧縮、非線形活性化など)に従って、正規化(例えば、12ビットから8ビット)、シフト、又は再マッピングなどによってデジタル出力ビットを操作するために使用される、(シリアルADC、SAR ADC、パイプラインADC、傾斜ADCなどの)ADC(アナログ-デジタル)変換回路を構成することによるものである。ADC変換回路の例は、本出願と同じ譲受人によって2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。
【0213】
表9は、読み出し、消去、及びプログラム動作を実行するための代替アプローチを示す。
表9:フラッシュメモリセルの動作
【表17】
読み出し及び消去動作は、前の表と同様である。しかしながら、プログラミングのための2つの方法は、ファウラーノルドハイム(FN)トンネリング機構によって実装される。
【0214】
入力をスケーリングするための実施形態は、一度にVMMの特定の数の行を可能にし、次いで、結果を完全に組み合わせることなどによって行うことができる。
【0215】
別の実施形態は、入力電圧をスケーリングし、正規化のために出力を適切に再スケーリングすることである。
【0216】
パルス幅変調入力をスケーリングするための別の実施形態は、パルス幅のタイミングを変調することによるものである。この技術の一例は、本出願と同じ譲受人によって2019年6月21日に出願された、「Configurable Input Blocks and Output Blocks and Physical Layout for Analog Neural Memory in Deep Learning Artificial Neural Network」と題する米国特許出願第16/449,201号に記載されており、これは、参照により本明細書に組み込まれる。
【0217】
入力をスケーリングするための別の実施形態は、例えば、8ビット入力IN7:0について、一度に1つずつ入力バイナリビットを可能にし、順番にそれぞれIN0、IN1、...、IN7を評価し、次いで、出力結果を適切なバイナリビット重み付けと組み合わせることによるものである。この技術の一例は、本出願と同じ譲受人によって2019年6月21日に出願された、「Configurable Input Blocks and Output Blocks and Physical Layout for Analog Neural Memory in Deep Learning Artificial Neural Network」と題する米国特許出願第16/449,201号に記載されており、これは、参照により本明細書に組み込まれる。
【0218】
任意選択的に、上記の実施形態では、電流を検証又は読み出す目的でセル電流を測定することは、例えば、8~32回、平均の又は複数の測定値をとって、(RTN若しくは任意のランダムノイズの)ノイズの影響を低減し、及び/又は欠陥があり冗長ビットによって置き換えられる必要があるいずれかの外れ値ビットを検出することであり得る。
【0219】
本明細書で使用される場合、「の上方に(over)」及び「に(on)」という用語は両方とも、「に直接」(中間材料、要素、又は間隙がそれらの間に配設されていない)、及び「に間接的に」(中間材料、要素、又は間隙がそれらの間に配設されている)を包括的に含むことに留意されるべきである。同様に、「隣接した」という用語は、「直接隣接した」(中間材料、要素、又は間隙がそれらの間に配設されていない)、及び「間接的に隣接した」(中間材料、要素、又は間隙がそれらの間に配設されている)を含み、「に取り付けられた」は、「に直接取り付けられた」(中間材料、要素、又は間隙がそれらの間に配設されていない)、及び「に間接的に取り付けられた」(中間材料、要素、又は間隙がそれらの間に配設されている)を含み、「電気的に結合された」は、「に直接電気的に結合された」(要素を一緒に電気的に接続する中間材料又は要素がそれらの間にない)、及び「に間接的に電気的に結合された」(要素を一緒に電気的に接続する中間材料又は要素がそれらの間にある)を含む。例えば、要素を「基板の上方に」形成することは、その要素を基板に直接、中間材料/要素をそれらの間に伴わずに形成すること、及びその要素を基板に間接的に1つ以上の中間材料/要素をそれらの間に伴って形成することを含み得る。
【手続補正書】
【提出日】2023-10-19
【手続補正1】
【補正対象書類名】特許請求の範囲
【補正対象項目名】全文
【補正方法】変更
【補正の内容】
【特許請求の範囲】
【請求項1】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、重み値wは、式w=(w+)-(w-)に従って、前記アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+及びw-は、非ゼロのオフセット値を含む、ニューラルネットワーク。
【請求項2】
前記非ゼロのオフセット値は、正の値である、請求項1に記載のニューラルネットワーク。
【請求項3】
前記非ゼロのオフセット値は、負の値である、請求項1に記載のニューラルネットワーク。
【請求項4】
wに対して0の値が所望されるとき、前記非ゼロのオフセット値に等しい値は、w+及びw-に対して記憶される、請求項1に記載のニューラルネットワーク。
【請求項5】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項1に記載のニューラルネットワーク。
【請求項6】
前記所定のスレッショルドは、5nAである、請求項5に記載のニューラルネットワーク。
【請求項7】
前記所定のスレッショルドは、10nAである、請求項5に記載のニューラルネットワーク。
【請求項8】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項1に記載のニューラルネットワーク。
【請求項9】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項1に記載のニューラルネットワーク。
【請求項10】
前記第1の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってw-にチューニングされる、請求項1に記載のニューラルネットワーク。
【請求項11】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、前記アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+及びw-値の記憶は、前記アレイ内の全ての列の間でほぼ均等に分散される、ニューラルネットワーク。
【請求項12】
非ゼロのオフセット値は、正の値である、請求項11に記載のニューラルネットワーク。
【請求項13】
非ゼロのオフセット値は、負の値である、請求項11に記載のニューラルネットワーク。
【請求項14】
0の値がwに対して所望されるとき
、非ゼロのオフセット値に等しい値は、w+及びw-に対して記憶される、請求項11に記載のニューラルネットワーク。
【請求項15】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項11に記載のニューラルネットワーク。
【請求項16】
前記所定のスレッショルドは、5nAである、請求項15に記載のニューラルネットワーク。
【請求項17】
前記所定のスレッショルドは、10nAである、請求項15に記載のニューラルネットワーク。
【請求項18】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項11に記載のニューラルネットワーク。
【請求項19】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項11に記載のニューラルネットワーク。
【請求項20】
前記第1の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされる、請求項11に記載のニューラルネットワーク。
【請求項21】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルの差動対においてゼロ値をプログラミングし、検証し、及び読み出す方法であって、前記方法は、
前記差動対における第1のセルw+を第1の電流値にプログラムするステップと、
第1の電圧にバイアス電圧を加えたものに等しい電圧を前記第1のセルの制御ゲート端子に印加することによって、前記第1のセルを検証するステップと、
前記差動対における第2のセルw-を前記第1の電流値にプログラムするステップと、
前記第1の電圧に前記バイアス電圧を加えたものに等しい電圧を前記第2のセルの制御ゲート端子に印加することによって、前記第2のセルを検証するステップと、
前記第1の電圧に等しい電圧を前記第1のセルの前記制御ゲート端子に印加することによって、前記第1のセルを読み出すステップと、
前記第1の電圧に等しい電圧を前記第2のセルの前記制御ゲート端子に印加することによって、前記第2のセルを読み出すステップと、
式w=(w+)-(w-)に従って値wを計算するステップと、を含む、方法。
【請求項22】
前記第1のセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされ、前記第2のセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされる、請求項21に記載の方法。
【請求項23】
前記第1の電流値は、正の値である、請求項
21に記載の方法。
【請求項24】
前記第
1の電流値は、負の値である、請求項
21に記載の方法。
【請求項25】
前記第1のセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2のセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってw-にチューニングされる、請求項
21に記載の方法。
【請求項26】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、前記アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、差動対w+及びw-として記憶され、w+は、前記アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対として記憶され、w-は、前記アレイ内の第3の不揮発性メモリセル及び第4の不揮発性メモリセルの差動対として記憶され、w+及びw-値の記憶は、バイアス値によってオフセットされる、ニューラルネットワーク。
【請求項27】
全ての前記メモリセルの電流範囲は、ほぼ、バイアス値を表すメモリセル電流値分だけ低減される、請求項
26に記載のニューラルネットワーク。
【請求項28】
前記メモリセルは、いくつかの電流レベルを有する、請求項
26に記載のニューラルネットワーク。
【請求項29】
前記バイアス値は、いくつかのメモリセルレベルにわたって共有される、請求項
27に記載のニューラルネットワーク。
【請求項30】
前記バイアス値は、正の値である、請求項
26に記載のニューラルネットワーク。
【請求項31】
前記バイアス値は、負の値である、請求項
26に記載のニューラルネットワーク。
【請求項32】
0の値がwに対して所望されるとき、前記バイアス値に等しい値は、w+及びw-に対して記憶される、請求項
26に記載のニューラルネットワーク。
【請求項33】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項
26に記載のニューラルネットワーク。
【請求項34】
前記所定のスレッショルドは、5nAである、請求項
33に記載のニューラルネットワーク。
【請求項35】
前記所定のスレッショルドは、10nAである、請求項
33に記載のニューラルネットワーク。
【請求項36】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項
26に記載のニューラルネットワーク。
【請求項37】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項
26に記載のニューラルネットワーク。
【請求項38】
前記第1及び第3の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされ、前記第2及び第4の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってチューニングされる、請求項
26に記載のニューラルネットワーク。
【請求項39】
ニューラルネットワークであって、
不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、前記アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+に対する値は、非ゼロ値の第1の範囲から選択され、w-に対する値は、非ゼロ値の第2の範囲から選択され、前記第1の範囲及び前記第2の範囲は重複しない、ニューラルネットワーク。
【請求項40】
wに対する0の値は、所定のスレッショルド未満のwに対する記憶された値によって示される、請求項
39に記載のニューラルネットワーク。
【請求項41】
前記所定のスレッショルドは、5nAである、請求項
40に記載のニューラルネットワーク。
【請求項42】
前記所定のスレッショルドは、10nAである、請求項
40に記載のニューラルネットワーク。
【請求項43】
前記不揮発性メモリセルは、スプリットゲートフラッシュメモリセルである、請求項
39に記載のニューラルネットワーク。
【請求項44】
前記不揮発性メモリセルは、積層ゲートフラッシュメモリセルである、請求項
39に記載のニューラルネットワーク。
【請求項45】
前記第1の不揮発性メモリセルは、粗い、微細、又は超微細チューニングアルゴリズムのうちの1つ以上によってw+にチューニングされ、前記第2の不揮発性メモリセルは、微細又は超微細チューニングアルゴリズムのうちの1つ以上によってw-にチューニングされる、請求項
39に記載のニューラルネットワーク。
【請求項46】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを読み出す方法であって、前記方法は、
前記アレイ内の選択されたセル内に記憶された重みを読み出すステップを含み、前記読み出すステップは、
前記選択されたセルの制御ゲート端子にゼロの電圧バイアスを印加するステップと、
前記選択されたセルからの電流出力を含むニューロン出力電流を検知するステップと、を含む、方法。
【請求項47】
前記読み出すステップは、
前記選択されたセルのワード線端子に電圧を印加するステップを更に含む、請求項
46に記載の方法。
【請求項48】
ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを動作させる方法であって、前記方法は、
前記不揮発性メモリセルの制御ゲートに第1のバイアス電圧を印加することによって、前記不揮発性メモリセルを読み出すステップと、
スタンバイ動作、ディープパワーダウン動作、又はテスト動作のうちの1つ以上の間に、前記不揮発性メモリセルの前記制御ゲートに第2のバイアス電圧を印加するステップと、を含む、方法
。
【手続補正2】
【補正対象書類名】明細書
【補正対象項目名】全文
【補正方法】変更
【補正の内容】
【発明の詳細な説明】
【技術分野】
【0001】
(優先権の主張)
本出願は、2020年1月3日に出願された「Precise Data Tuning Method and Apparatus for Analog Neuromorphic Memory in an Artificial Neural Network」という名称の米国特許仮出願第62/957,013号の優先権を主張するものである、2020年3月25日に出願された「Precise Data Tuning Method and Apparatus for Analog Neuromorphic Memory in an Artificial Neural Network」という名称の米国特許出願第16/829,757号の一部継続出願である、2021年2月25日に出願された「Precise Data Tuning Method and Apparatus for Analog Neural Memory in an Artificial Neural Network」という名称の米国特許出願第17/185,725号の優先権を主張するものである。
【0002】
(発明の分野)
人工ニューラルネットワーク内のベクトルマトリックス乗算(vector-by-matrix multiplication、VMM)アレイ内の不揮発性メモリセルの浮遊ゲートに正確な量の電荷を精密かつ迅速に堆積させるための精密チューニング方法及び装置について、多数の実施形態が開示される。
【背景技術】
【0003】
人工ニューラルネットワークは、生物学的ニューラルネットワーク(動物の中枢神経系、特に脳)を模倣しており、多数の入力に依存し得、かつ、一般的に未知である関数を推定する又は近似するために使用される。人工ニューラルネットワークは、概して、お互いの間でメッセージを交換する相互接続した「ニューロン」の層を含む。
【0004】
図1は人工ニューラルネットワークを示しており、図中、円は、入力又はニューロンの層を表す。接続(シナプスと呼ばれる)は、矢印によって表され、経験に基づいてチューニングされ得る数値の重みを有する。これにより、人工ニューラルネットワークは入力に適応し、学習可能になる。典型的には、人工ニューラルネットワークは、複数の入力の層を含む。典型的には、1つ以上のニューロンの中間層、及びニューラルネットワークの出力を提供するニューロンの出力層が存在する。各レベルでニューロンは、シナプスから受信したデータに基づいて個々に又は集合的に決定を行う。
【0005】
高性能情報処理用の人工ニューラルネットワークの開発における主要な課題のうちの1つは、適切なハードウェア技術の欠如である。実際には、実用人工ニューラルネットワークは、非常に多数のシナプスに依拠しており、これによりニューロン間の高い接続性、すなわち、非常に高度な計算処理の並列化が可能となる。原理的には、このような複雑性は、デジタルスーパーコンピュータ又は専用グラフィックプロセッシングユニットクラスタによって実現が可能である。しかしながら、高コストに加え、これらのアプローチはまた、生物学的ネットワークが主として低精度のアナログ計算を実施するのではるかに少ないエネルギーしか消費しないのと比較して、エネルギー効率が劣っていることに悩まされている。人工ニューラルネットワークにはCMOSアナログ回路が使用されてきたが、ほとんどのCMOS実装シナプスは、多数のニューロン及びシナプスを前提とすると、嵩高過ぎていた。
【0006】
出願人は以前に、参照により組み込まれる米国特許公開第2017/0337466号として公開された米国特許出願第15/594,439号において、シナプスとして1つ以上の不揮発性メモリアレイを利用する人工(アナログ)ニューラルネットワークを開示した。不揮発性メモリアレイは、アナログニューロモーフィックメモリとして動作する。本明細書で使用される場合、ニューロモーフィックという用語は、神経システムのモデルを実装する回路を意味する。アナログニューロモーフィックメモリは、第1の複数の入力を受信して、それから第1の複数の出力を生成するように構成されている第1の複数のシナプス、及び第1の複数の出力を受信するように構成された第1の複数のニューロンを含む。第1の複数のシナプスは複数のメモリセルを含み、メモリセルの各々は、半導体基板内に形成された、間にチャネル領域が延在する離間したソース領域及びドレイン領域と、チャネル領域の第1の部分の上方に絶縁されて配設される浮遊ゲートと、チャネル領域の第2の部分の上方に絶縁されて配設される非浮遊ゲートと、を含む。複数のメモリセルの各々は、浮遊ゲートの多くの電子に対応する重み値を記憶するように構成されている。複数のメモリセルは、第1の複数の入力に、記憶された重み値を乗算して第1の複数の出力を生成するように構成される。この様式で配置されるメモリセルのアレイは、ベクトルマトリックス乗算(VMM)アレイと称され得る。
【0007】
VMMアレイに使用される各不揮発性メモリセルは、浮遊ゲート内に電荷、すなわち電子の数、を非常に具体的かつ精密な量で保持するように消去及びプログラムされなければならない。例えば、各浮遊ゲートはN個の異なる値のうちの1つを保持しなければならず、ここで、Nは、各セルによって示され得る異なる重みの数である。Nの例としては、16、32、64、128及び256が挙げられる。1つの課題は、異なるNの値に必要な精度及び粒度で選択されたセルをプログラムする能力である。例えば、選択されたセルが64個の異なる値のうちの1つを含み得る場合、極めて高い精度がプログラム動作で必要とされる。
【0008】
必要とされるのは、アナログニューロモーフィックメモリにおいてVMMアレイと共に使用するのに適した、改善されたプログラミングシステム及び方法である。
【発明の概要】
【0009】
アナログニューロモーフィックメモリシステム内のVMMアレイ内の不揮発性メモリセルの浮遊ゲートに正確な量の電荷を精密かつ迅速に堆積させるための精密チューニングアルゴリズム及び装置について、多数の実施形態が開示される。それにより、選択されたセルは、N個の異なる値のうちの1つを保持するために、極めて高い精度でプログラムすることができる。
【0010】
一実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを含み、重み値wは、式w=(w+)-(w-)に従って、アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+及びw-は、非ゼロのオフセット値を含む。
【0011】
別の実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを備え、アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って、第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、ここで、w+及びw-値の記憶は、アレイ内の全ての列の間でほぼ均等に分散される。
【0012】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルの差動対においてゼロ値をプログラミングし、検証し、及び読み出す方法は、差動対の第1のセルw+を第1の電流値にプログラムするステップと、第1の電圧にバイアス電圧を加えたものに等しい電圧を第1のセルの制御ゲート端子に印加することによって第1のセルを検証するステップと、差動対の第2のセルw-を第1の電流値にプログラムするステップと、第1の電圧にバイアス電圧を加えたものに等しい電圧を第2のセルの制御ゲート端子に印加することによって第2のセルを検証するステップと、第1の電圧に等しい電圧を第1のセルの制御ゲート端子に印加することによって第1のセルを読み出すステップと、第1の電圧に等しい電圧を第2のセルの制御ゲート端子に印加することによって第2のセルを読み出すステップと、式w=(w+)-(w-)に従って値wを計算するステップとを含む。
【0013】
別の実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを備え、アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従う差動対w+及びw-として記憶され、w+は、アレイ内の第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対として記憶され、w-は、アレイ内の第3の不揮発性メモリセル及び第4の不揮発性メモリセルの差動対として記憶され、w+及びw-の記憶は、バイアス値によってオフセットされる。
【0014】
別の実施形態では、ニューラルネットワークは、不揮発性メモリセルのベクトルマトリックス乗算アレイを備え、アレイは、不揮発性メモリセルの行及び列に編成され、重み値wは、式w=(w+)-(w-)に従って第1の不揮発性メモリセル及び第2の不揮発性メモリセルの差動対w+及びw-として記憶され、w+に対する値は、非ゼロ値の第1の範囲から選択され、w-に対する値は、非ゼロ値の第2の範囲から選択され、第1の範囲及び第2の範囲は、重複しない。
【0015】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを読み出す方法は、アレイ内の選択されたセル内に記憶された重みを読み出すステップを含み、読み出すステップは、選択されたセルの制御ゲート端子にゼロ電圧バイアスを印加するステップと、選択されたセルから出力される電流を含むニューロン出力電流を検知するステップとを含む。
【0016】
別の実施形態では、ベクトルマトリックス乗算アレイ内の不揮発性メモリセルを動作させる方法は、前記不揮発性メモリセルの制御ゲートに第1のバイアス電圧を印加することによって、前記不揮発性メモリセルを読み出すステップと、スタンバイ動作、ディープパワーダウン動作、又はテスト動作のうちの1つ以上の間に、不揮発性メモリセルの制御ゲートに第1のバイアス電圧を印加すること、及び不揮発性メモリセルの制御ゲートに第2のバイアス電圧を印加することによって、不揮発性メモリセルを読み出すステップを含む。
【0017】
【0018】
【0019】
【0020】
【0021】
【0022】
【0023】
【0024】
【0025】
【0026】
【0027】
【0028】
【0029】
【0030】
【0031】
【0032】
【0033】
【0034】
【0035】
【0036】
【0037】
【0038】
【0039】
【0040】
【0041】
【0042】
【0043】
【0044】
【0045】
【0046】
【0047】
【0048】
【0049】
【0050】
【0051】
【0052】
【0053】
【0054】
【0055】
【0056】
【0057】
【0058】
【0059】
【0060】
【0061】
【0062】
【0063】
【0064】
【0065】
【0066】
【0067】
【0068】
【0069】
【0070】
【図面の簡単な説明】
【0071】
【
図1】先行技術の人工ニューラルネットワークを示す図である。
【
図2】先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図3】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図4】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図5】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図6】別の先行技術のスプリットゲートフラッシュメモリセルを示す。
【
図7】先行技術の積層ゲートフラッシュメモリセルを示す。
【
図8】1つ以上のVMMアレイを利用する例示的な人工ニューラルネットワークの様々なレベルを示す図である。
【
図9】VMMアレイ及び他の回路を備えるVMMシステムを示すブロック図である。
【
図10】1つ以上のVMMシステムを利用する例示的な人工ニューラルネットワークを示すブロック図である。
【
図25】先行技術の長・短期メモリシステムを示す。
【
図26】長・短期メモリシステムで使用する例示的なセルを示す。
【
図29】先行技術のゲート付き回帰型ユニットシステムを示す。
【
図30】ゲート付き回帰型ユニットシステムでの使用のための例示的なセルを示す。
【
図36A】セルに記憶された値に対する温度の影響を示す。
【
図36B】VMMシステムの動作中のデータドリフトによって生じた問題を示す。
【
図36C】データドリフトを補償するためのブロックを示す。
【発明を実施するための形態】
【0072】
本発明の人工ニューラルネットワークは、CMOS技術及び不揮発性メモリアレイの組み合わせを利用する。
不揮発性メモリセル
【0073】
デジタル不揮発性メモリは、周知である。例えば、参照により本明細書に組み込まれる、米国特許第5,029,130号(「’130号特許」)は、フラッシュメモリセルの一種である、スプリットゲート不揮発性メモリセルのアレイを開示する。このようなメモリセル210を
図2に示す。各メモリセル210は、半導体基板12内に形成されたソース領域14及びドレイン領域16を含み、ソース領域14とドレイン領域16との間にはチャネル領域18がある。浮遊ゲート20は、チャネル領域18の第1の部分の上方に絶縁されて形成され(並びに、チャネル領域18の第1の部分の導電性を制御して)、ソース領域14の一部分の上方にかけて形成される。ワード線端子22(典型的には、ワード線に結合される)は、チャネル領域18の第2の部分の上方に絶縁されて配設される、(並びに、チャネル領域18の第2の部分の導電性を制御する)第1の部分と、浮遊ゲート20の上方で上に延在する第2の部分と、を有する。浮遊ゲート20及びワード線端子22は、ゲート酸化物によって基板12から絶縁される。ビット線端子24はドレイン領域16に結合される。
【0074】
ワード線端子22に高圧正電圧を加えることによって、メモリセル210に対して消去が行われ(電子が浮遊ゲートから除去される)、これによって、浮遊ゲート20の電子は、浮遊ゲート20からワード線端子22までそれらの間にある絶縁体の中をファウラーノルドハイム(Fowler-Nordheim)トンネリングを介して通過する。
【0075】
メモリセル210は、ワード線端子22に正電圧、及びソース領域14に正電圧を加えることによってプログラムされる(電子が浮遊ゲートに印加される)。電子電流は、ソース領域14(ソース線端子)からドレイン領域16に向かって流れる。電子は加速し、ワード線端子22と浮遊ゲート20との間の間隙に達すると、発熱する。熱せられた電子の一部は、浮遊ゲート20からの静電引力に起因して、浮遊ゲート20にゲート酸化物を介して注入される。
【0076】
メモリセル210は、ドレイン領域16及びワード線端子22に正の読み出し電圧を加える(ワード線端子の下方のチャネル領域18の部分をオンにする)ことによって、読み出される。浮遊ゲート20が正に帯電する(すなわち、電子を消去する)と、浮遊ゲート20の下方のチャネル領域18の部分も同様にオンになり、電流はチャネル領域18を流れ、これは、消去された状態つまり「1」の状態として検知される。浮遊ゲート20が負に帯電する(すなわち、電子でプログラムされる)と、浮遊ゲート20の下方のチャネル領域の部分はほとんど又は完全にオフになり、電流はチャネル領域18を流れず(又はほとんど流れず)、これは、プログラムされた状態つまり「0」の状態として検知される。
【0077】
表1は、読み出し、消去、及びプログラム動作を実行するためのメモリセル110の端子に印加され得る典型的な電圧範囲を示す。
表1:
図2のフラッシュメモリセル210の動作
【表1】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。
【0078】
図3は、制御ゲート(control gate、CG)端子28を追加した、
図2のメモリセル210と同様のメモリセル310を示す。制御ゲート端子28は、プログラミング中に高電圧(例えば、10V)、消去中に低又は負電圧(例えば、0v/-8V)、読み出し中に低又は中程度電圧(例えば、0v/2.5V)でバイアスされる。他の端子は、
図2の端子と同様にバイアスされる。
【0079】
図4は、ソース領域14と、ドレイン領域16と、チャネル領域18の第1の部分の上方にある浮遊ゲート20と、チャネル領域18の第2の部分の上方にある選択ゲート22(典型的には、ワード線、WL、に結合される)と、浮遊ゲート20の上方にある制御ゲート28と、ソース領域14の上方にある消去ゲート30と、を備える、4ゲートメモリセル410を示す。この構成は、あらゆる目的のため参照により本明細書に組み込まれる、米国特許第6,747,310号に記載されている。ここで、全てのゲートは、浮遊ゲート20を除いて、非浮遊ゲートであり、つまり、それらは電圧源に電気的に接続される又は接続可能である。プログラミングは、熱せられた電子がチャネル領域18から浮遊ゲート20にその電子自体を注入することによって実行される。消去は、電子が浮遊ゲート20から消去ゲート30へトンネリングすることによって実行される。
【0080】
表2は、読み出し、消去、及びプログラム動作を実行するためのメモリセル410の端子に印加され得る典型的な電圧範囲を示す。
表2:
図4のフラッシュメモリセル410の動作
【表2】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。
【0081】
図5は、メモリセル510が消去ゲートEG端子を含まないことを除いて、
図4のメモリセル410と同様のメモリセル510を示す。消去は、基板18を高電圧にバイアスし、制御ゲートCG端子28を低電圧又は負電圧にバイアスすることによって実行される。代替的に、ワード線端子22を正電圧にバイアスし、制御ゲート端子28を負電圧にバイアスすることによって、消去が実行される。プログラミング及び読み出しは、
図4のものと同様である。
【0082】
図6は、別の種類のフラッシュメモリセルである、3ゲートメモリセル610を示す。メモリセル610は、メモリセル610が別個の制御ゲート端子を有しないことを除いて、
図4のメモリセル410と同一である。(消去ゲート端子の使用を通じて消去が起こる)消去動作及び読み出し動作は、制御ゲートバイアスが印加されないことを除いて、
図4のものと同様である。プログラミング動作もまた、制御ゲートバイアスなしで行われるため、結果として、プログラム動作中は、制御ゲートバイアスの不足を補償するため、より高い電圧がソース線端子に印加されなければならない。
【0083】
表3は、読み出し、消去、及びプログラム動作を実行するためのメモリセル610の端子に印加され得る典型的な電圧範囲を示す。
表3:
図6のフラッシュメモリセル610の動作
【表3】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。
【0084】
図7は、別の種類のフラッシュメモリセルである、積層ゲートメモリセル710を示す。メモリセル710は、浮遊ゲート20がチャネル領域18全体の上方にわたって延在し、制御ゲート端子22(ワード線に結合される)が絶縁層(図示せず)によって分離されて浮遊ゲート20の上方に延在することを除いて、
図2のメモリセル210と同様である。消去、プログラミング、及び読み出し動作は、メモリセル210について前述したものと同様の方法で動作する。
【0085】
表4は、読み出し、消去、及びプログラム動作を実行するためのメモリセル710及び基板12の端子に印加され得る典型的な電圧範囲を示す。
表4:
図7のフラッシュメモリセル710の動作
【表4】
【0086】
「読み出し1」は、セル電流がビット線に出力される読み出しモードである。「読み出し2」は、セル電流がソース線端子に出力される読み出しモードである。任意選択的に、メモリセル210、310、410、510、610、又は710の行及び列を含むアレイでは、ソース線は、メモリセルの1行又はメモリセルの隣接する2行に結合され得る。すなわち、ソース線端子は、メモリセルの隣接する行によって共有され得る。
【0087】
上記の人工ニューラルネットワークにおける不揮発性メモリセルの種類のうちの1つを含むメモリアレイを利用するために、2つの修正が行われる。第一に、以下に更に説明されるように、アレイ内の他のメモリセルのメモリ状態に悪影響を与えずに各メモリセルを個々にプログラム、消去、及び読み出しできるように線を構成する。第二に、メモリセルの連続的(アナログ)プログラミングを提供する。
【0088】
具体的には、アレイ内の各メモリセルのメモリ状態(すなわち、浮遊ゲートの電荷)を、完全に消去された状態から完全にプログラムされた状態へ、独立して、かつ他のメモリセルの乱れが最小で、連続的に変えることができる。別の実施形態では、アレイ内の各メモリセルのメモリ状態(すなわち、浮遊ゲートの電荷)を、完全にプログラムされた状態から完全に消去された状態へ、及び逆もまた同様に、独立して、かつ他のメモリセルの乱れが最小で、連続的に変えることができる。これはつまり、セル記憶がアナログであるか、又は多数の不連続値(16個又は64個の異なる値など)のうちの1つを最低限記憶することができることを意味し、これにより、メモリアレイ内の全てのセルが非常に精密に、かつ個々にチューニング可能となり、また、メモリアレイが、記憶、及びニューラルネットワークのシナプシスの重みへの微細チューニング調整に対して、理想的なものになる。
【0089】
本明細書に記載される方法及び手段は、限定することなく、SONOS(silicon-oxide-nitride-oxide-silicon,charge trap in nitride)(ケイ素-酸化物-窒化物-酸化物-ケイ素、窒化物中の電荷トラップ)、MONOS(metal-oxide-nitride-oxide-silicon,metal charge trap in nitride)(金属-酸化物-窒化物-酸化物-ケイ素、窒化物中の金属電荷トラップ)、ReRAM(resistive ram)(抵抗変化型メモリ)、PCM(phase change memory)(相変化メモリ)、MRAM(magnetic ram)(磁気抵抗メモリ)、FeRAM(ferroelectric ram)(強誘電体メモリ)、OTP(bi-level or multi-level one time programmable)(バイレベル又はマルチレベルの1回のみのプログラムが可能)及びCeRAM(correlated electron ram)(強相関電子メモリ)などの他の不揮発性メモリ技術に適用することができる。本明細書に記載される方法及び手段は、限定することなく、SRAM、DRAM、及び他の揮発性シナプスセルなどのニューラルネットワークに使用される揮発性メモリ技術に適用することができる。
不揮発性メモリセルアレイを使用するニューラルネットワーク
【0090】
図8は、本実施形態の不揮発性メモリアレイを利用するニューラルネットワークの非限定例を概念的に例解する。この例は、顔認識アプリケーション用に不揮発性メモリアレイニューラルネットワークを使用するが、不揮発性メモリアレイベースのニューラルネットワークを使用して他の適切なアプリケーションを実装することも可能である。
【0091】
S0は入力層であり、この例では、5ビット精度の32×32ピクセルRGB画像である(すなわち、各色R、G、及びBにつき1つずつで3つの32×32ピクセルアレイであり、各ピクセルは5ビット精度である)。入力層S0から層C1に行くシナプスCB1は、一部のインスタンスには異なる重みのセットを適用し、他のインスタンスには共有の重みを適用し、入力画像を3×3ピクセルの重なり合うフィルタ(カーネル)でスキャンし、1ピクセル(又はモデルによっては2ピクセル以上)ずつフィルタをシフトする。具体的には、画像の3×3部分における9ピクセルの値(すなわち、フィルタ又はカーネルと称される)は、シナプスCB1に提供され、そこで、これらの9個の入力値に適切な重みを乗算し、その乗算の出力を合計後、単一の出力値が決定され、特徴マップC1の層のうちの1つのピクセルを生成するためにCB1の第1のシナプスによって与えられる。3×3フィルタは次に、入力層S0内で右側に1ピクセルだけシフトされ(すなわち、3ピクセルの列を右側に追加し、左側で3ピクセルの列をドロップする)、これにより、この新しく位置づけられたフィルタの9ピクセル値はシナプスCB1に提供され、そこでそれらに上記と同じ重みを乗算し、関連するシナプスによって第2の単一の出力値を決定する。このプロセスを、3×3フィルタが入力層S0の32×32ピクセル画像全体にわたって3色全て及び全てのビット(精度値)についてスキャンするまで続ける。プロセスは次に、層C1の特徴マップ全てが計算されるまで、異なる重みのセットを使用して繰り返されて、C1の異なる特徴マップを生成する。
【0092】
本例では、層C1において、各々30×30ピクセルを有する16個の特徴マップが存在する。各ピクセルは、入力とカーネルとの乗算から抽出された新しい特徴ピクセルであり、したがって、各特徴マップは、二次元アレイであり、したがってこの例では、層C1は、二次元アレイの16層を構成する(本明細書で言及される層及びアレイは、必ずしも物理的関係ではなく論理的な関係であり、すなわち、アレイは必ずしも物理的な二次元アレイに配向されないことに留意されたい)。層C1内の16個の特徴マップの各々は、フィルタスキャンに適用される異なるシナプス重みのセット16個のうちの1つによって生成される。C1特徴マップは全て、境界同定など、同じ画像特徴の異なる態様を対象とすることができる。例えば、第1のマップ(この第1のマップを生成するために使用される全てのスキャンに共有される第1の重みセットを使用して生成される)は、円形エッジを識別することができ、第2のマップ(第1の重みセットと異なる第2の重みセットを使用して生成される)は、長方形エッジ又はある特定の特徴のアスペクト比などを識別することができる。
【0093】
層C1から層S1へ行く前には、各特徴マップ内の重なり合わずに連続する2×2領域からの値をプールする活性化関数P1(プーリング)が適用される。プーリング関数の目的は、近隣の位置を平均すること(又はmax関数を使用することも可能である)、例えばエッジ位置の依存性を低減すること、及び次の段階に行く前にデータサイズを低減することである。層S1において、16個の15×15特徴マップ(すなわち、各々15×15ピクセルの異なるアレイ16個)が存在する。層S1から層C2に行くシナプスCB2は、S1内のマップを4×4フィルタにより1ピクセルのフィルタシフトでスキャンする。層C2において、22個の12×12特徴マップが存在する。層C2から層S2へ行く前には、各特徴マップ内の重なり合わずに連続する2×2領域からの値をプールする活性化関数P2(プーリング)が適用される。層S2において、22個の6×6特徴マップが存在する。層S2から層C3へ行くシナプスCB3では活性化関数(プーリング)が適用され、ここで層C3内の全てのニューロンは、CB3のそれぞれのシナプスを介して層S2内の全てのマップに接続する。層C3において、64個のニューロンが存在する。層C3から出力層S3へと行くシナプスCB4は、C3をS3に完全に接続する、すなわち、層C3内の全てのニューロンは、層S3内の全てのニューロンに接続される。S3における出力は、10個のニューロンを含み、ここで出力が最も高いニューロンが、クラスを決定する。この出力は、例えば、元の画像の内容の同定又は分類(クラス分け)を示すことができる。
【0094】
シナプスの各層は、不揮発性メモリセルのアレイ又はアレイの一部を使用して実装される。
【0095】
図9は、その目的のために使用可能なシステムのブロック図である。VMMシステム32は、不揮発性メモリセルを含み、ある層と次の層との間のシナプス(図
8のCB1、CB2、CB3、及びCB4など)として利用される。具体的には、VMMシステム32は、行及び列に配置された不揮発性メモリセルを備えるVMMアレイ33、消去ゲート及びワード線ゲートデコーダ34、制御ゲートデコーダ35、ビット線デコーダ36、並びにソース線デコーダ37を備え、それらのデコーダは、不揮発性メモリセルアレイ33に対するそれぞれの入力をデコードする。VMMアレイ33への入力は、消去ゲート及びワード線ゲートデコーダ34から、又は制御ゲートデコーダ35から行うことができる。この例におけるソース線デコーダ37はまた、VMMアレイ33の出力をデコードする。代替的に、ビット線デコーダ36が、VMMアレイ33の出力をデコードすることができる。
【0096】
VMMアレイ33は、2つの目的を果たす。第一に、VMMアレイ33は、VMMシステム32によって使用される重みを記憶する。第二に、VMMアレイ33は、効果的に、入力に、VMMアレイ33に記憶された重みを乗算し、それらを出力線(ソース線又はビット線)ごとに合計して出力を生成し、これは、次の層への入力又は最後の層への入力になる。乗算及び加算の関数を実行することによって、VMMアレイ33は、別個の乗算及び加算の論理回路の必要性をなくし、また、その場でのメモリ計算により電力効率も良い。
【0097】
VMMアレイ33の出力は、VMMアレイ33の出力を合計してその畳み込み用の単一の値を作成する、差動加算器(加算オペアンプ又は加算電流ミラーなど)38に供給される。差動加算器38は、正の重み入力及び負の重み入力両方の総和を実行して単一の値を出力するように配置される。
【0098】
差動加算器38の合計された出力値は、次に出力を整流する活性化関数回路39に供給される。活性化関数回路39は、シグモイド関数、tanh関数、ReLU関数、又は任意の他の非線形関数を提供し得る。活性化関数回路39の整流された出力値は、次の層(例えば
図8のC1)の特徴マップの要素になり、次いで、次のシナプスに適用されて次の特徴マップ層又は最後の層を生成する。したがって、この例では、VMMアレイ33は、複数のシナプスを構成し(ニューロンの前の層から、又は画像データベースなどの入力層から、入力を受信する)、加算器38及び活性化関数回路39は、複数のニューロンを構成する。
【0099】
図9のVMMシステム32への入力(WLx、EGx、CGx、及び任意選択的にBLx及びSLx)は、アナログレベル、バイナリレベル、デジタルパルス(この場合、パルスを適切な入力アナログレベルに変換するためにパルス-アナログ変換器PACが必要とされ得る)又はデジタルビット(この場合、デジタルビットを適切な入力アナログレベルに変換するためにDACが提供される)であり得、出力は、アナログレベル、バイナリレベル、デジタルパルス、又はデジタルビットであり得る(この場合、出力アナログレベルをデジタルビットに変換するために出力ADCが提供される)。
【0100】
図10は、図中でVMMシステム32a、32b、32c、32d及び32eとして標示されたVMMシステム32の多数の層の使用を示すブロック図である。
図10に示されるように、入力(Inputxで示される)は、デジタル-アナログ変換器31によってデジタルからアナログに変換され、入力VMMシステム32aに提供される。変換されたアナログ入力は、電圧又は電流であり得る。第1の層の入力D/A変換は、入力VMMシステム32aのマトリックス乗算器の適切なアナログレベルに入力Inputxをマッピングする関数又はLUT(ルックアップテーブル)を使用することによって行うことができる。入力変換はまた、外部アナログ入力を入力VMMシステム32aへのマッピングされたアナログ入力に変換するために、アナログ-アナログ(analog to analog、A/A)変換器によって行うこともできる。入力変換はまた、外部デジタル入力を入力VMMシステム32aへのマッピングされたデジタルパルスに変換するために、デジタル-デジタルパルス(digital-to-digital pules、D/P)変換器によって行うこともできる。
【0101】
入力VMMシステム32aによって生成された出力は、次に、次のVMMシステム(隠しレベル1)32bへの入力として提供され、次に入力VMMシステム(隠しレベル2)32cへの入力として提供される出力を生成する、などとなる。VMMシステム32の様々な層は、畳み込みニューラルネットワーク(convolutional neural network、CNN)のシナプス及びニューロンの各層として機能する。各VMMシステム32a、32b、32c、32d及び32eは、対応の不揮発性メモリアレイを備える、スタンドアローンの物理的システムとすることができるか、又は複数のVMMシステムは、同じ物理的不揮発性メモリアレイの異なる部分を利用することができるか、又は複数のVMMシステムは、同じ物理的不揮発性メモリアレイの重なり合う部分を利用することができる。各VMMシステム32a、32b、32c、32d、及び32eはまた、そのアレイ又はニューロンの様々な部分に対して時間多重化され得る。
図10に示される例は、5つの層(32a、32b、32c、32d、32e)、すなわち、1つの入力層(32a)、2つの隠れ層(32b、32c)、及び2つの全接続層(32d、32e)を含む。当業者であれば、これは単なる例示であり、代わりにシステムが2つを超える隠れ層及び2つを超える完全接続層を含み得ることを理解するであろう。
VMMアレイ
【0102】
図11は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1100を示す。VMMアレイ1100は、不揮発性メモリセルのメモリアレイ1101と、不揮発性基準メモリセルの基準アレイ1102(アレイの頂部に位置する)と、を含む。代替的に、別の基準アレイが底部に位置することができる。
【0103】
VMMアレイ1100では、制御ゲート線1103などの制御ゲート線が垂直方向に延びており(したがって、行方向の基準アレイ1102が、制御ゲート線1103に直交する)、消去ゲート線1104などの消去ゲート線が水平方向に延びている。ここで、VMMアレイ1100への入力は、制御ゲート線(CG0、CG1、CG2、CG3)に提供され、VMMアレイ1100の出力は、ソース線(SL0、SL1)に現れる。一実施形態では、偶数行のみが使用され、別の実施形態では、奇数行のみが使用される。各ソース線(それぞれSL0、SL1)の電流は、その特定のソース線に接続されたメモリセルからの全ての電流の合計関数を実行する。
【0104】
ニューラルネットワークについて本明細書に記載されているように、VMMアレイ1100の不揮発性メモリセル、すなわちVMMアレイ1100のフラッシュメモリは、サブスレッショルド領域で動作するように構成されることが好ましい。
【0105】
本明細書に記載される不揮発性基準メモリセル及び不揮発性メモリセルは、以下のように弱い反転でバイアスされる:
Ids=Io*e(Vg-Vth)/nVt=w*Io*e(Vg)/nVt
式中、w=e(-Vth)/nVtであり、
式中、Idsはドレイン-ソース間電流であり、Vgはメモリセルのゲート電圧であり、Vthはメモリセルのスレッショルド電圧であり、Vtは熱電圧=k*T/qであり、kはボルツマン定数、Tはケルビン温度、qは電子電荷であり、nは傾斜係数=1+(Cdep/Cox)であり、Cdep=空乏層の容量、及びCoxはゲート酸化物層の容量であり、Ioは、スレッショルド電圧に等しいゲート電圧におけるメモリセル電流であり、Ioは(Wt/L)*u*Cox*(n-1)*Vt2に比例し、式中、uはキャリア移動度であり、Wt及びLはそれぞれ、メモリセルの幅及び長さである。
【0106】
メモリセル(基準メモリセル又は周辺メモリセルなど)又はトランジスタを使用して入力電流Idsを入力電圧Vgに変換するI-Vログ変換器を使用した場合、Vgは以下のとおりである:
Vg=n*Vt*log[Ids/wp*Io]
式中、wpは、基準又は周辺メモリセルのwである。
【0107】
メモリセル(基準メモリセル又は周辺メモリセルなど)又はトランジスタを使用して入力電流Idsを入力電圧Vgに変換するI-Vログ変換器を使用した場合、Vgは以下のとおりである:
Vg=n*Vt*log[Ids/wp*Io]
【0108】
式中、wpは、基準又は周辺メモリセルのwである。
【0109】
ベクトルマトリックス乗算器VMMアレイとして使用されるメモリアレイについて、出力電流は以下である:
Iout=wa*Io*e(Vg)/nVt、すなわち
Iout=(wa/wp)*Iin=W*Iin
W=e(Vthp-Vtha)/nVt
Iin=wp*Io*e(Vg)/nVt
式中、wa=メモリアレイの各メモリセルのwである。
【0110】
ワード線又は制御ゲートは、入力電圧のためのメモリセルの入力として使用することができる。
【0111】
代替的に、本明細書に記載されたVMMアレイの不揮発性メモリセルは、線形領域で動作するように構成することができる。
Ids=ベータ*(Vgs-Vth)*Vds、 ベータ=u*Cox*Wt/L、
W ∝ (Vgs-Vth)
すなわち、直線領域における重みWは(Vgs-Vth)に比例する。
【0112】
ワード線又は制御ゲート又はビット線又はソース線は、線形領域内で動作するメモリセルの入力として使用することができる。ビット線又はソース線は、メモリセルの出力として使用することができる。
【0113】
I-V線形変換器用に、線形領域で動作するメモリセル(基準メモリセル又は周辺メモリセルなど)若しくはトランジスタ、又は抵抗器を使用して、入出力電流を入出力電圧に線形変換することができる。
【0114】
代替的に、本明細書に記載されたVMMアレイのメモリセルは、飽和領域で動作するように構成することができる。
Ids=1/2
*ベータ*(Vgs-Vth)2、 ベータ=u*Cox*Wt/L
W ∝ (Vgs-Vth)2、すなわち、重みWは(Vgs-Vth)2に比例する。
【0115】
ワード線、制御ゲート、又は消去ゲートは、飽和領域内で動作するメモリセルの入力として使用することができる。ビット線又はソース線は、出力ニューロンの出力として使用することができる。
【0116】
代替的に、本明細書に記載されるVMMアレイのメモリセルは、全ての領域又はそれらの組み合わせ(サブスレッショルド、線形、又は飽和)で使用することができる。
【0117】
図9のVMMアレイ33のための他の実施形態は、参照により本明細書に組み込まれる米国特許出願第15/826,345号に記載されている。上記出願に記載されているように、ソース線又はビット線は、ニューロン出力(電流和出力)として使用することができる。
【0118】
図12は、
図2に示されるメモリセル210に特に適したニューロンVMMアレイ1200を示し、入力層と次の層との間のシナプスとして利用される。VMMアレイ1200は、不揮発性メモリセルのメモリアレイ1203と、第1の不揮発性基準メモリセルの基準アレイ1201と、第2の不揮発性基準メモリセルの基準アレイ1202と、を含む。アレイの列方向に配置された基準アレイ1201及び1202は、端子BLR0、BLR1、BLR2、及びBLR3に流入する電流入力を電圧入力WL0、WL1、WL2、及びWL3に変換するように機能する。実際には、第1及び第2の不揮発性基準メモリセルは、電流入力が流入する状態で、マルチプレクサ1214(一部のみ示す)を通してダイオード接続される。基準セルは、目標基準レベルにチューニング(例えば、プログラム)される。目標基準レベルは、基準ミニアレイマトリックス(図示せず)によって提供される。
【0119】
メモリアレイ1203は、2つの目的を果たす。第一に、メモリアレイ1003は、VMMアレイ1200により使用される重みを、それぞれのメモリセルに記憶する。第二に、メモリアレイ1203は、メモリアレイ1203に記憶された重みを、入力(すなわち、端子BLR0、BLR1、BLR2、及びBLR3に提供された電流入力であり、これを基準アレイ1201及び1202が入力電圧に変換して、ワード線WL0、WL1、WL2、及びWL3に供給する)に有効に乗算して、次いで、全ての結果(メモリセル電流)を加算して、それぞれのビット線(BL0~BLN)の出力を生成し、この出力は次の層への入力又は最後の層への入力となる。乗算及び加算の関数を実行することで、メモリアレイ1203は、別個の乗算及び加算の論理回路の必要性をなくし、また、電力効率も良い。ここで、電圧入力はワード線WL0、WL1、WL2、及びWL3に提供され、出力は、読み出し(推論)動作中にそれぞれのビット線BL0~BLNに現れる。ビット線BL0~BLNの各々の電流は、その特定のビット線に接続された全ての不揮発性メモリセルからの電流の合計関数を実行する。
【0120】
表5は、VMMアレイ1200の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示し、FLTは、浮遊、すなわち電圧が印加されないことを示す。行は、読み出し、消去、及びプログラムの動作を示す。
表5:
図12のVMMアレイ1200の動作
【表5】
【0121】
図13は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1300を示す。VMMアレイ1300は、不揮発性メモリセルのメモリアレイ1303と、第1の不揮発性基準メモリセルの基準アレイ1301と、第2の不揮発性基準メモリセルの基準アレイ1302と、を含む。基準アレイ1301及び1302は、VMMアレイ1300の行方向に延びる。VMMアレイは、VMMアレイ1300においてワード線が垂直方向に延びることを除いて、VMM1000と同様である。ここで、入力はワード線(WLA0、WLB0、WLA1、WLB2、WLA2、WLB2、WLA3、WLB3)に提供され、出力は、読み出し動作中にソース線(SL0、SL1)に現れる。各ソース線の電流は、その特定のソース線に接続されたメモリセルからの全ての電流の合計関数を実行する。
【0122】
表6は、VMMアレイ1300の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示す。行は、読み出し、消去、及びプログラムの動作を示す。
表6:
図13のVMMアレイ1300の動作
【表6】
【0123】
図14は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1400を示す。VMMアレイ1400は、不揮発性メモリセルのメモリアレイ1403と、第1の不揮発性基準メモリセルの基準アレイ1401と、第2の不揮発性基準メモリセルの基準アレイ1402と、を含む。基準アレイ1401及び1402は、端子BLR0、BLR1、BLR2、及びBLR3に流入する電流入力を電圧入力CG0、CG1、CG2、及びCG3に変換するように機能する。実際には、第1及び第2の不揮発性基準メモリセルは、電流入力がBLR0、BLR1、BLR2、及びBLR3を通って流入する状態で、マルチプレクサ1412(一部のみ示す)を通してダイオード接続される。マルチプレクサ1412は、読み出し動作中に第1及び第2の不揮発性基準メモリセルの各々のビット線(BLR0など)の一定電圧を確実にするために、対応のマルチプレクサ1405及びカスコーディングトランジスタ1404をそれぞれ含む。基準セルは、目標基準レベルにチューニングされる。
【0124】
メモリアレイ1403は、2つの目的を果たす。第一に、メモリアレイ1203は、VMMアレイ1400によって使用される重みを記憶する。第二に、メモリアレイ1403は、メモリアレイに記憶された重みを、入力(端子BLR0、BLR1、BLR2、及びBLR3に提供された電流入力であり、基準アレイ1401及び1402がこれらの電流入力を入力電圧に変換して、制御ゲート(CG0、CG1、CG2、及びCG3)に供給する)に有効に乗算して、次いで、全ての結果(セル電流)を加算して出力を生成し、この出力はBL0~BLNに現れ、次の層への入力又は最後の層への入力となる。メモリアレイが乗算及び加算の関数を実行することで、別個の乗算及び加算の論理回路の必要性がなくなり、また、電力効率も良い。ここで、入力は制御ゲート線(CG0、CG1、CG2、及びCG3)に提供され、出力は、読み出し動作中にビット線(BL0~BLN)に現れる。各ビット線の電流は、その特定のビット線に接続されたメモリセルからの全ての電流の合計関数を実行する。
【0125】
VMMアレイ1400は、メモリアレイ1403内の不揮発性メモリセルの一方向チューニングを実装する。すなわち、各不揮発性メモリセルは消去され、次いで、浮遊ゲートの所望の電荷に達するまで部分的にプログラムされる。これは、例えば、以下に記載される精密プログラミング技術を使用して実行することができる。過度に多くの電荷が浮遊ゲートに加えられる場合(その結果、誤った値がセルに記憶される)、セルは消去されなければならず、一連の部分的なプログラミング動作をやり直さなければならない。示されるように、同じ消去ゲート(EG0又はEG1など)を共有する2つの行は、一緒に消去される必要があり(ページ消去として知られる)、その後、各セルは、浮遊ゲートの所望の電荷に達するまで部分的にプログラムされる。
【0126】
表7は、VMMアレイ1400の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルの制御ゲート、選択セルと同じセクタ内の非選択セルの制御ゲート、選択セルとは異なるセクタ内の非選択セルの制御ゲート、選択セルの消去ゲート、非選択セルの消去ゲート、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示す。行は、読み出し、消去、及びプログラムの動作を示す。
表7:
図14のVMMアレイ1400の動作
【表7】
【0127】
図15は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1500を示す。VMMアレイ1500は、不揮発性メモリセルのメモリアレイ1503と、基準アレイ1501又は第1の不揮発性基準メモリセルと、第2の不揮発性基準メモリセルの基準アレイ1502と、を備える。EG線EGR0、EG0、EG1、及びEGR1は垂直に延び、CG線CG0、CG1、CG2、及びCG3並びにSL線WL0、WL1、WL2、及びWL3は水平に延びる。VMMアレイ1500は、VMMアレイ1500が双方向チューニングを実装することを除いてVMMアレイ1400と同様であり、各個々のセルは、個別のEG線の使用により、浮遊ゲートの所望の電荷量に達するために、完全に消去され、部分的にプログラムされ、必要に応じて部分的に消去することができる。示されるように、基準アレイ1501及び1502は、端子BLR0、BLR1、BLR2及びBLR3における入力電流を制御ゲート電圧CG0、CG1、CG2及びCG3に変換し(マルチプレクサ1514を介したダイオード接続された基準セルの作用を通じて)、これらの電圧は行方向でメモリセルに印加される。電流出力(ニューロン)は、ビット線BL0~BLN中にあり、各ビット線は、その特定のビット線に接続された不揮発性メモリセルからの全ての電流を合計する。
【0128】
表8は、VMMアレイ1500の動作電圧を示す。表中の列は、選択セルのワード線、非選択セルのワード線、選択セルのビット線、非選択セルのビット線、選択セルの制御ゲート、選択セルと同じセクタ内の非選択セルの制御ゲート、選択セルとは異なるセクタ内の非選択セルの制御ゲート、選択セルの消去ゲート、非選択セルの消去ゲート、選択セルのソース線、及び非選択セルのソース線に加えられる電圧を示す。行は、読み出し、消去、及びプログラムの動作を示す。
表8:
図15のVMMアレイ1500の動作
【表8】
【0129】
図16は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1600を示す。VMMアレイ1600では、入力INPUT
0....、INPUT
Nは、ビット線BL
0、...BL
Nでそれぞれ受信され、出力OUTPUT
1、OUTPUT
2、OUTPUT
3、及びOUTPUT
4は、ソース線SL
0、SL
1、SL
2、及びSL
3にそれぞれ生成される。
【0130】
図17は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1700を示す。この例では、入力INPUT
0、INPUT
1、INPUT
2、及びINPUT
3は、ソース線SL
0、SL
1、SL
2、及びSL
3でそれぞれ受信され、出力OUTPUT
0、...OUTPUT
Nは、ビット線BL
0、...、BL
Nに生成される。
【0131】
図18は、
図2に示されるメモリセル210に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1800を示す。この例では、入力INPUT
0、...、INPUT
Mは、ワード線WL
0、...、WL
Mでそれぞれ受信され、出力OUTPUT
0、...OUTPUT
Nは、ビット線BL
0、...、BL
Nに生成される。
【0132】
図19は、
図3に示されるメモリセル310に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ1900を示す。この例では、入力INPUT
0、...、INPUT
Mは、ワード線WL
0、...、WL
Mでそれぞれ受信され、出力OUTPUT
0、...OUTPUT
Nは、ビット線BL
0、...、BL
Nに生成される。
【0133】
図20は、
図4に示されるメモリセル410に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2000を示す。この例では、入力INPUT
0、...、INPUT
nがそれぞれ垂直制御ゲート線CG
0、...、CG
Nに受信され、出力OUTPUT
1及びOUTPUT
2がソース線SL
0及びSL
1に生成される。
【0134】
図21は、
図4に示されるメモリセル410に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2100を示す。この例では、入力INPUT
0、...、INPUT
Nは、ビット線BL
0、...、BL
Nにそれぞれ結合されているビット線制御ゲート2901-1、2901-2、...、2901-(N-1)及び2901-Nのゲートにそれぞれ受信される。例示的な出力OUTPUT
1及びOUTPUT
2が、ソース線SL
0及びSL
1に生成される。
【0135】
図22は、
図3に示されるメモリセル310、
図5に示されるメモリセル510、及び
図7に示されるメモリセル710に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2200を示す。この例では、入力INPUT
0、...、INPUT
Mは、ワード線WL
0、...、WL
Mに受信され、出力OUTPUT
0、...、OUTPUT
Nは、ビット線BL
0、...、BL
Nにそれぞれ生成される。
【0136】
図23は、
図3に示されるメモリセル310、
図5に示されるメモリセル510、及び
図7に示されるメモリセル710に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2300を示す。この例では、入力INPUT
0、...、INPUT
Mは、制御ゲート線CG
0、...、CG
Mに受信される。出力OUTPUT
0、...、OUTPUT
Nは、垂直ソース線SL
0、...、SL
Nにそれぞれ生成され、各ソース線SL
iは、列i内の全てのメモリセルのソース線に結合されている。
【0137】
図24は、
図3に示されるメモリセル310、
図5に示されるメモリセル510、及び
図7に示されるメモリセル710に特に適しており、かつ入力層と次の層との間でシナプス及びニューロンの一部として利用される、ニューロンVMMアレイ2400を示す。この例では、入力INPUT
0、...、INPUT
Mは、制御ゲート線CG
0、...、CG
Mに受信される。出力OUTPUT
0、...、OUTPUT
Nは、垂直ビット線BL
0、...、BL
Nにそれぞれ生成され、各ビット線BL
iは、列i内の全てのメモリセルのビット線に結合されている。
長・短期メモリ
【0138】
先行技術は、長・短期メモリ(long short-term memory、LSTM)として知られる概念を含む。LSTMは、人工ニューラルネットワークで使用されることが多い。LSTMは、人工ニューラルネットワークが、所定の任意の期間にわたって情報を覚え、後続の動作においてその情報を使用することを可能にする。従来のLSTMは、セル、入力ゲート、出力ゲート、及び忘却ゲートを含む。3つのゲートは、セル内及びセル外への情報の流れ、及び情報がLSTM内で記憶される期間を調節する。VMMは、LSTMにおいて特に有用である。
【0139】
図25は、例示的なLSTM2500を示す。この例におけるLSTM2500は、セル2501、2502、2503、及び2504を含む。セル2501は、入力ベクトルx
0を受け取り、出力ベクトルh
0及びセル状態ベクトルc
0を生成する。セル2502は、入力ベクトルx
1と、セル2501からの出力ベクトル(隠れ状態)h
0と、セル2501からのセル状態c
0と、を受け取り、出力ベクトルh
1と、セル状態ベクトルc
1と、を生成する。セル2503は、入力ベクトルx
2と、セル2502からの出力ベクトル(隠れ状態)h
1と、セル2502からのセル状態c
1と、を受け取り、出力ベクトルh
2と、セル状態ベクトルc
2と、を生成する。セル2504は、入力ベクトルx
3と、セル2503からの出力ベクトル(隠れ状態)h
2と、セル2503からのセル状態c
2と、を受け取り、出力ベクトルh
3を生成する。追加のセルも使用可能であり、4つのセルを有するLSTMは、単なる例である。
【0140】
図26は、
図25のセル2501、2502、2503、及び2504に使用可能なLSTMセル2600の例示的な実装を示す。LSTMセル2600は、入力ベクトルx(t)と、先行するセルからのセル状態ベクトルc(t-1)と、先行するセルからの出力ベクトルh(t-1)と、を受け取り、セル状態ベクトルc(t)及び出力ベクトルh(t)を生成する。
【0141】
LSTMセル2600は、シグモイド関数デバイス2601、2602、及び2603を含み、各々が0~1の数を適用して、入力ベクトルの各成分が出力ベクトルに寄与する程度を制御する。LSTMセル2600はまた、入力ベクトルに双曲線正接関数を適用するためのtanhデバイス2604及び2605と、2つのベクトルを乗算するための乗算器デバイス2606、2607、及び2608と、2つのベクトルを加算するための加算器デバイス2609と、を含む。出力ベクトルh(t)は、システム内の次のLSTMセルに提供することができるか、又は他の目的でアクセスすることができる。
【0142】
図27は、LSTMセル2600の一実装の一例であるLSTMセル2700を示す。読者の便宜のために、LSTMセル2600からの同じ採番方法が、LSTMセル2700で使用される。シグモイド関数デバイス2601、2602、及び2603、並びにtanhデバイス2604は各々、複数のVMMアレイ2701及び活性化回路ブロック2702を含む。したがって、VMMアレイは、特定のニューラルネットワークシステムで使用されるLSTMセルにおいて特に有用であることが分かる。
【0143】
LSTMセル2700の代替例(及びLSTMセル2600の一実装の別の例)を
図28に示す。
図28では、シグモイド関数デバイス2601、2602及び2603、並びにtanhデバイス2604は、同じ物理ハードウェア(VMMアレイ2801及び活性化関数ブロック2802)を、時分割多重化された方式で共有し得る。LSTMセル2800はまた、2つのベクトルを乗算するための乗算器デバイス2803と、2つのベクトルを加算するための加算器デバイス2808と、(活性化回路ブロック2802を含む)tanhデバイス2605と、値i(t)を、i(t)がシグモイド関数ブロック2802から出力されるときに記憶するためのレジスタ2807と、値f(t)
*c(t-1)を、その値がマルチプレクサ2810を介して乗算器デバイス2803から出力されるときに記憶するためのレジスタ2804と、値i(t)
*u(t)を、その値がマルチプレクサ2810を介して乗算器デバイス2803から出力されるときに記憶するためのレジスタ2805と、値o(t)
*c~(t)を、その値がマルチプレクサ2810を介して乗算器デバイス2803から出力されるときに記憶するためのレジスタ2806と、マルチプレクサ2809と、を含む。
【0144】
LSTMセル2700がVMMアレイ2701とそれぞれの活性化関数ブロック2702との複数のセットを含むのに対し、LSTMセル2800は、LSTMセル2800の実施形態において複数の層を表すために使用される、VMMアレイ2801及び活性化関数ブロック2802の1つのセットのみを含む。LSTMセル2800は、LSTMセル2700と比較して、VMM及び活性化関数ブロックのために必要とするスペースは1/4で済むので、LSTMセル2800は、LSTM2700よりも必要とするスペースが少ない。
【0145】
LSTMユニットは典型的には複数のVMMアレイを含み、これらは各々、加算器及び活性化回路ブロック及び高電圧生成ブロックなどの、VMMアレイの外側の特定の回路ブロックによって提供される機能を必要とすることを更に理解することができる。各VMMアレイのための別個の回路ブロックを提供することは、半導体デバイス内にかなりの量のスペースを必要とし、幾分非効率的であろう。したがって、以下に記載される実施形態では、VMMアレイ自体の外側に必要とされる回路の最小化を試みる。
ゲート付き回帰型ユニット
【0146】
アナログVMM実装は、ゲート付き回帰型ユニット(gated recurrent unit、GRU)に利用することができる。GRUは、反復(recurrent)人工ニューラルネットワーク内のゲート機構である。GRUは、GRUセルが一般にLSTMセルよりも少ない構成要素を含むことを除いて、LSTMに類似している。
【0147】
図29は、例示的なGRU2900を示す。この例におけるGRU2900は、セル2901、2902、2903、及び2904を含む。セル2901は、入力ベクトルx
0を受け取り、出力ベクトルh
0を生成する。セル2902は、入力ベクトルx
1と、セル2901からの出力ベクトルh
0と、を受け取り、出力ベクトルh
1を生成する。セル2903は、入力ベクトルx
2と、セル2902からの出力ベクトル(隠れ状態)h
1と、を受け取り、出力ベクトルh
2を生成する。セル2904は、入力ベクトルx
3と、セル2903からの出力ベクトル(隠れ状態)h
2と、を受け取り、出力ベクトルh
3を生成する。追加のセルも使用可能であり、4つのセルを有するGRUは、単なる例である。
【0148】
図30は、
図29のセル2901、2902、2903、及び2904に使用することができるGRUセル3000の例示的な実装を示す。GRUセル3000は、入力ベクトルx(t)と、先行するGRUセルからの出力ベクトルh(t-1)と、を受け取り、出力ベクトルh(t)を生成する。GRUセル3000は、シグモイド関数デバイス3001及び3002を含み、それらの各々が、出力ベクトルh(t-1)及び入力ベクトルx(t)からの成分に0~1の数を適用する。GRUセル3000はまた、入力ベクトルに双曲線正接関数を適用するためのtanhデバイス3003と、2つのベクトルを乗算するための複数の乗算器デバイス3004、3005、及び3006と、2つのベクトルを加算するための加算器デバイス3007と、1から入力を減算して出力を生成するための相補デバイス3008と、を含む。
【0149】
図31は、GRUセル3000の一実装の一例であるGRUセル3100を示す。読者の便宜のために、GRUセル3000からの同じ採番方法が、GRUセル3100で使用される。
図31から分かるように、シグモイド関数デバイス3001及び3002、並びにtanhデバイス3003は各々、複数のVMMアレイ3101及び活性化関数ブロック3102を含む。したがって、VMMアレイは、特定のニューラルネットワークシステムで使用されるGRUセルにおいて特に使用されることが分かる。
【0150】
GRUセル3100の代替例(及びGRUセル3000の一実装の別の例)を
図32に示す。
図32において、GRUセル3200は、VMMアレイ3201及び活性化関数ブロック3202を利用しており、シグモイド関数として構成された場合には、0~1の数を適用して、入力ベクトルの各成分が出力ベクトルに寄与する程度を制御する。
図32では、シグモイド関数デバイス3001及び3002、並びにtanhデバイス3003は、同じ物理ハードウェア(VMMアレイ3201及び活性化関数ブロック3202)を、時分割多重化された方式で共有する。GRUセル3200はまた、2つのベクトルを乗算するための乗算器デバイス3203と、2つのベクトルを加算するための加算器デバイス3205と、1から入力を減算して、出力を生成するための相補デバイス3209と、マルチプレクサ3204と、値h(t-1)
*r(t)を、その値がマルチプレクサ3204を介して乗算器デバイス3203から出力されるときに保持するためのレジスタ3206と、値h(t-1)
*z(t)を、その値がマルチプレクサ3204を介して乗算器デバイス3203から出力されるときに保持するためのレジスタ3207と、値h^(t)
*(1-z((t))を、その値がマルチプレクサ3204を介して乗算器デバイス3203から出力されるときに保持するためのレジスタ3208と、を備える。
【0151】
GRUセル3100がVMMアレイ3101及び活性化関数ブロック3102の複数のセットを含むのに対し、GRUセル3200は、GRUセル3200の実施形態において複数の層を表すために使用される、VMMアレイ3201及び活性化関数ブロック3202の1つのセットのみを含む。GRUセル3200は、GRUセル3100と比較して、VMM及び活性化関数ブロックのために必要とするスペースは1/3で済むので、GRUセル3200は、GRUセル3100よりも必要とするスペースが少ない。
【0152】
GRUを利用するシステムは、典型的には複数のVMMアレイを含み、これらの各々は、加算器及び活性化回路ブロック及び高電圧生成ブロックなどの、VMMアレイの外側の特定の回路ブロックによって提供される機能を必要とすることを更に理解することができる。各VMMアレイのための別個の回路ブロックを提供することは、半導体デバイス内にかなりの量のスペースを必要とし、幾分非効率的であろう。したがって、以下に記載される実施形態では、VMMアレイ自体の外側に必要とされる回路の最小化を試みる。
【0153】
VMMアレイへの入力は、アナログレベル、バイナリレベル、タイミングパルス、又はデジタルビットであり得、出力は、アナログレベル、バイナリレベル、タイミングパルス、又はデジタルビット(この場合、出力アナログレベルの電流又は電圧をデジタルビットに変換するために出力ADCが必要とされる)であり得る。
【0154】
VMMアレイ内の各メモリセルに関して、各重みwは、単一のメモリセルによって、又は差分セルによって、又は2つのブレンドメモリセル(2つ以上のセルの平均)によって実装することができる。差分セルの場合では、重みwを差分重み(w=w+-w-)として実装するために、2つのメモリセルが必要とされる。2つのブレンドメモリセルの場合は、2つのセルの平均として重みwを実装するために2つのメモリセルが必要とされる。
VMM内のセルの精密なチューニングのための実施形態
【0155】
図33は、VMMシステム3300のブロック図を示す。VMMシステム3300は、VMMアレイ3301、行デコーダ3302、高電圧デコーダ3303、列デコーダ3304、ビット線ドライバ3305、入力回路3306、出力回路3307、制御論理3308、及びバイアス生成器3309を備える。VMMシステム3300は、チャージポンプ3311、チャージポンプレギュレータ3312、及び高電圧レベル生成器3313を含む、高電圧生成ブロック3310を更に備える。VMMシステム3300は、アルゴリズムコントローラ3314、アナログ回路3315、制御論理3316、及びテスト制御論理3317を更に備える。以下に記載されるシステム及び方法は、VMMシステム3300に実装され得る。
【0156】
入力回路3306は、DAC(digital to analog converter)(デジタル-アナログ変換器)、DPC(digital to pulses converter)(デジタル-パルス変換器)、AAC(analog to analog converter)(電流-電圧変換器などのアナログ-アナログ変換器)、PAC(pulse to analog level converter)(パルス-アナログレベル変換器)、又は任意の他のタイプの変換器などの回路を含み得る。入力回路3306は、正規化関数、スケーリング関数、又は算術関数を実装し得る。入力回路3306は、入力のための温度補償関数を実装し得る。入力回路3306は、ReLU又はシグモイド関数などの活性化関数を実装し得る。
【0157】
出力回路3307は、ADC(ニューロンアナログ出力をデジタルビットに変換するための、アナログ-デジタル変換器)、AAC(電流-電圧変換器などのアナログ変換器)、APC(アナログ-パルス変換器)、又は任意の他のタイプの変換器などの回路を含み得る。出力回路3307は、ReLU又はシグモイド関数などの活性化関数を実装し得る。出力回路3307は、ニューロン出力のための正規化関数、スケーリング関数、又は算術関数を実装し得る。出力回路3307は、以下に記載されるように、ニューロン出力又はアレイ出力(ビット線出力など)のための温度補償関数を実装し得る。
【0158】
図34は、VMMシステム3300内のアルゴリズムコントローラ3314によって実行することができるチューニング(メモリセルを目標にプログラム又は消去する)補正方法3400を示す。チューニング補正方法3400は、セル出力及びセルの元の目標から生じる最終誤差に基づいて適応目標を生成する。この方法は、典型的には、チューニングコマンドが受信されることに応答して開始する(ステップ3401)。選択されたセル、又は選択されたセルのグループの(プログラム/検証アルゴリズムに使用される)初期電流目標Itargetv(i)は、関数又はルックアップテーブルを使用することなどによって予測目標モデルを使用して決定され、変数DeltaErrorは、0に設定される(ステップ3402)。目標関数は、使用される場合、選択されたメモリセル又はセルのグループのI-Vプログラム曲線に基づくであろう。目標関数はまた、(セクタ内のセルアドレス及びセルレベルに依存し、ここで、セルは、それがより比較的多くの異常を示す場合、抑制条件でより多くのプログラム時間に供され、ここで、より高い電流を有するセルは、典型的にはより多くの異常を有する)セルが示すプログラム異常の程度、セル間連結、及び様々なタイプのアレイノイズなどのアレイ特性によって引き起こされる様々な変動に依存する。これらの変動は、PVT(process, voltage, temperature)(プロセス、電圧、温度)上のケイ素上で特徴付けることができる。ルックアップテーブルは、使用される場合、I-V曲線及び様々な変動をエミュレートするための同じ方法で特徴付けることができる。
【0159】
次いで、ソフト消去が、VMM内の全てのセルに対して実行され、このソフト消去は、各セルが、読み出し動作中に例えば約3~5μAの電流を引き込むように、全てのセルに対して中間弱消去レベルに消去を行う(ステップ3403)。ソフト消去は、例えば、中間セル電流に達するまで、セルに増分消去パルス電圧を印加することによって実行される。次に、プログラミング動作(目標へのディーププログラミング又は粗い/微細プログラミングなどによる)が、<pA電流レベル又は等価ゼロ重みに達するように、全ての未使用セルに対して実行される(ステップ3404)。次いで、誤差結果に基づく目標調整(補正)が実行される。セルがプログラミング中にオーバーシュートを受けたことを意味する、DeltaError>0の場合、Itargetv(i+1)は、Itarget+シータ*DeltaErrorに設定され、シータは、例えば、1、又は1に近い数である(ステップ3405A)。
【0160】
Itarget(i+1)はまた、適切な誤差目標調整/補正を用いて、前のItarget(i)に基づいて調整され得る。DeltaError<0である場合、セルがプログラミング中にアンダーシュートを受けたことを意味するが、これは、セル電流がまだ目標に達しないことを意味し、その後、Itargetv(i+1)は、前の目標Itargetv(i)に設定される(ステップ3405B)。
【0161】
次に、粗い及び/又は微細プログラム並びに検証動作が実行される(ステップ3406)。精密(微細)プログラミングステップを実行する前に、複数の徐々に小さくなる粗い目標を目標とすることなどによって、複数の適応型の粗いプログラミング方法を使用して、プログラミングを加速することができる。適応型の精密プログラミングは、例えば、微細(精密)増分プログラム電圧パルス又は定常プログラムタイミングパルスで行われる。粗いプログラミング及び微細プログラミングを実行するためのシステム及び方法の例は、本出願と同じ譲受人によって2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。
【0162】
Icellを、選択されたセルで測定する(ステップ3407)。例えば、セル電流は、電流計回路によって測定することができる。例えば、セル電流は、ADC(アナログ-デジタル変換器)回路によって測定することができ、この場合、出力は、デジタルビットによって表される。例えば、セル電流は、I-V(電流-電圧変換器)回路によって測定することができ、この場合、出力は、アナログ電圧によって表される。DeltaErrorは計算され、これは、測定されたセルにおける実際の電流(Icell)と目標電流(Itarget)との間の差を表す、Icell-Itargetである。|DeltaError|<DeltaMarginの場合、セルは、特定の許容範囲(DeltaMargin)内の目標電流を達成しており、方法は終了する(ステップ3410)。|DeltaError|=abs(DeltaError)=DeltaErrorの絶対値。そうでない場合、方法は、ステップ3403に戻り、ステップを再び順次実行する(ステップ3410)。
【0163】
図35A及び
図35Bは、VMMシステム3300内のアルゴリズムコントローラ3314によって実行することができるチューニング補正方法3500を示す。
図35Aを参照すると、方法が開始し(ステップ3501)、これは、典型的には、チューニングコマンドが受信されることに応じて行われる。VMMアレイ全体が、ソフト消去法などによって消去される(ステップ3502)。セル電流<pAレベル又は等価ゼロ重みを得るために、全ての未使用セルに対してプログラミング動作(目標へのディーププログラミング又は粗い/微細プログラミングなどによる)が実行される(ステップ3503)。VMMアレイ内の全てのセルが、粗い及び/又は微細プログラミングサイクルを使用して、0.5~1.0μAなどの中間値にプログラムされ(ステップ3504)、粗いプログラミング及び微細プログラミングを実行するためのシステム及び方法の例は、本出願と同じ譲受人によって2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。予測目標は、上記のように、関数又はルックアップテーブルを使用して使用されるセルに設定される(ステップ3505)。次に、セクタチューニング方法3507が、VMMの各セクタに対して実行される(ステップ3506)。セクタは、典型的には、アレイ内の2つ以上の隣接する行からなる。
【0164】
図35Bは、適応目標セクタチューニング方法3507を示す。セクタ内の全てのセルは、(1)粗い/微細/定常P/Vサイクル、(2)CG+(CG増分のみ)若しくはEG+(EG増分のみ)、又は相補的CG+/EG-(CG増分及びEG減分)、並びに(3)最初に最も深いプログラムされたセル(セルをグループにグループ化することを意味し、グループが、最初に最低電流プログラムされたセルを有する、漸進的グループ化など)、などの個々又は組み合わせのプログラム/検証(P/V)方法を使用して、最終的な所望の値(例えば、1nA~50nA)にプログラムされる(ステップ3508A)。次に、Icell<Itargetであるかどうかに関する決定が行われる。はいの場合、方法は、ステップ3509に進む。いいえの場合、方法は、ステップ3508Aを繰り返す。ステップ3509において、測定されたIcell-Itarget(i+1)に等しい、DeltaErrorを測定する(ステップ3509)。|DeltaError|<DeltaMarginであるかどうかに関する決定が行われる(ステップ3510)。はいの場合、方法は、完了する(ステップ3511)。いいえの場合、目標調整が実行される。セルがプログラミング中にオーバーシュートを受けたことを意味する、DeltaError>0の場合、目標は、新しい目標をItarget+シータ
*DeltaErrorに設定することによって調整され、ここで、シータは、典型的には=1である(ステップ3512A)。Itarget(i+1)はまた、適切な誤差目標調整/補正を用いて、前のItarget(i)に基づいて調整され得る。DeltaError<0の場合、セルがプログラミング中にアンダーシュートを受けたことを意味するが、これは、セルがまだ目標に達していないことを意味し、目標は、Itargetv(i+1)=Itargetv(i)を意味する、前の目標を維持することによって調整される(ステップ3512B)。セクタをソフト消去する(ステップ3513)。セクタ内の全てのセルを中間値にプログラムし(ステップ3514)、ステップ3509に戻る。
【0165】
典型的なニューラルネットワークは、正の重みw+及び負の重みw-、合計重み=w+-w-を有し得、w+及びw-は、メモリセルによって各々実装され(それぞれIw+及びIw-)、合計重み(Iw=Iw+-Iw-、電流減算)は、(アレイビット線出力回路などを使用することによって)周辺回路レベルで実行することができる。したがって、合計重みの重みチューニング実施形態は、表
9に示されるような例において、w+セルとw-セルの両方を同時にチューニングすること、w+セルのみをチューニングすること、又はw-セルのみをチューニングすることを含み得る。チューニング動作は、
図34/
図35A/
図35Bに関して前述したプログラム/検証及び誤差目標調整方法を使用して実行される。検証動作は、合計重みのみ(例えば、合計重み電流を測定する/読み出すが、個々の正のw+セル電流若しくはw-セル電流を測定しない/読み出さないこと)、w+セル電流のみ、又はw-セル電流のみについて実行することができる。
【0166】
例えば、3nAの合計Iwの場合、Iw+は3nAであり得、Iw-は0nAであり得る。あるいは、Iw+は13nAであり得、Iw-は10nAであり得、これは、正の重みIw+と負の重みIw-の両方がゼロではないことを意味する(例えば、ゼロは、深くプログラムされたセルを示し得る)。これは、Iw+とIw-の両方がノイズの影響をより受けにくくなるはずであるため、特定の動作条件で好ましい場合がある。
表
9:重みチューニング方法(値はnA単位の電流値である)
【表9】
【0167】
したがって、式w=(w+)-(w-)に従う差動重みマッピングを使用して、ニューラルネットワークで使用するためのチューニング値wを記憶することができる。w+及びw-のマッピングは、例えば、各値が記憶されるw+及びw-にオフセット値を含めることによって、ニューラルネットワーク内のVMMアレイにおいて生じる特定の問題に対処するように最適化することができる。
【0168】
一実施形態において、重みマッピングは、RTNノイズを低減するように最適化される。例えば、wの所望の値が0nA(ゼロw又は未使用メモリセル)である場合、1つの可能なマッピングは、(w+)=0nA及び(w-)=0nAであり、別の可能なマッピングは、(w+)=30nA及び(w-)=30nAであり、ここで、30nAは、記憶前に各w+及びw-値に加算される非ゼロのオフセット値の一例である。そのような非ゼロのオフセット値を含むことは、最終的により多くの電力を消費し、チューニングプロセス中により大きな不正確さを招くが、任意のノイズの影響を最小限に抑える。同様に、wの所望の値が1nAである場合、1つの可能なマッピングは、(w+)=1nA及び(w-)=0nAであり、別の可能なマッピングは、(w+)=30nA及び(w-)=29nAである。後者は、より多くの電力を消費し、チューニングプロセス中により大きな不正確さを招く可能性があるが、任意のノイズの影響を最小限に抑える。
【0169】
別の実施形態では、ゼロの重みwに対して、w+及びw-の両方は、ここで説明される検証動作のためのバイアスオフセット電圧の方法を使用することなどによって、ほぼゼロであるようにチューニングされることができる。この方法の場合では、w+及びw-の両方は、例えば、推論(読み出し)に使用された通常のCG電圧よりも高い制御ゲート電圧(VCG)で5nAにチューニングされる。例えば、dVCG/Ir=2mV/1nAに対して、VCG=1.5Vの値が推論において使用される場合、チューニングアルゴリズム(重みチューニングのためのプログラム検証アルゴリズム)において、VCG=1.510Vの値は、5nAの目標に達するゼロ重みセルを検証するために使用される。推論動作では、VCG=1.5Vが使用されるので、セル電流は1nA当たり2mVシフトダウンされ、したがって、検証動作における5nAは推論動作において約0nAになる。
【0170】
別の実施形態では、ゼロ重みwに対して、w+及びw-の両方は、検証動作のためのバイアスオフセット電圧の負電流チューニング方法を使用することなどによって、負電流を有するようにチューニングされることが可能であり、これについて以下で説明する。この場合、w+及びw-の両方は、例えば、推論(読み出し)に使用された通常のCG電圧よりも高い制御ゲート電圧(VCG)で-10nAにチューニングされる。例えば、dVCG/Ir=2mV/1nAに対して、VCG=1.5Vの値が推論において使用される場合、チューニングアルゴリズム(重みチューニングのためのプログラム検証アルゴリズム)において、VCG=1.530Vが、5nAの目標に達するゼロ重みセルを検証するために使用される。推論動作では、VCG=1.5Vが使用されるので、セル電流は1nA当たり2mVシフトダウンされ、したがって、検証動作における5nAは推論動作において約10nAになる。
【0171】
オフセットバイアス条件又はバイアス(電圧及び/又は電流及び/又はタイミング及び/又は温度)シーケンスの同様の方法は、著しいノイズ(RTNノイズ、熱ノイズ、又は任意の他のノイズ源など)の影響を受けやすいセルなどの異常ビットを検出するためのテストスクリーニングの目的で使用することができる。基本的に、メモリセルからのノイズを他のバイアス条件又はバイアスシーケンスよりも大幅に減衰させること(ノイズ減衰テスト)によって、ノイズをより良く検出するために使用することができるバイアス条件又はバイアスシーケンスがある。例えば、20nAのメモリセルに対して、このセルに対するバイアス条件を変調することによって、例えば、テストスクリーニングにおいて制御ゲートバイアス電圧を変化させることなどによって、このセルを別の条件に置くことから、望ましくない挙動を検出することが有利であり得る。例えば、テスタ制限又は回路制限により、バイアス条件を変調することによって、より高い電流レベルでノイズ(RTNノイズなど)の影響を受けやすいビット/セルを検出することが有利であり得る。
【0172】
メモリセルに対するRTNノイズスクリーニングなどのノイズレベルをスクリーニング又は検証する別の方法は、メモリセル出力をサンプリングすることである(4/8/.../1024回など、多数回出力を測定することなどによって)。スクリーニング基準は、任意のサンプルインスタンスの値がサンプルの平均よりもある量だけ大きいようなものである。別のスクリーニング基準は、1つのサンプルの値が次のサンプルよりもある量だけ大きいことである。これらの技法は、出願人により2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。
【0173】
上記の重み割り当てのいくつかを組み込んだメモリセルの重みをチューニングする(セルをプログラム又は消去する)方法は、セルをソフト消去し、次いでゼロ重みセル(上記など)をプログラムし、次いで上記で説明したようなノイズスクリーニングを用いて、粗い並びに微細及び/又は超微細チューニングアルゴリズムを実行することを含むことができる。粗い、微細、及び超微細チューニングアルゴリズムのための技法は、2020年3月25日に出願され、「Precise Data Tuning Method and Apparatus for Analog Neural Memory in an Artificial Neural Network」と題された米国特許出願第16/829,757号における出願によって以前に開示されており、これは、参照により本明細書に組み込まれる。
【0174】
別の実施形態では、バイアス条件シーケンシングを含む読み出し(推論)又は検証の方法を使用することによって、ノイズ寄与を低減することができる。例えば、蓄積条件は、読み出し又は検証動作が実行される前にメモリセルに対して実行される。
【0175】
別の実施形態では、制御ゲートに負電圧範囲を印加することによって、ノイズ寄与を低減することができる。別の実施形態では、ゼロ重み及び未使用セルに対するアレイのバックグラウンドデータは、変動を低減するための特定のパターンであり得る。例えば、高電流レベルバックグラウンドは、RTNノイズ低減などのノイズに対して望ましい場合がある。例えば、低電流レベルバックグラウンドは、データドリフトなどのノイズに対して望ましい場合がある。スタンバイ又はディープパワーダウンにおいて、アレイは、制御ゲート電圧を変調することによって、例えば、検証動作中に使用された制御ゲート電圧と比較して特定の電圧レベルを使用することによって、正しい状態に置かれ、これは、制御ゲートレベルが、スタンバイ又はディープパワーダウン動作中に電流を下げるか又は電流レベルを上げるように設定され得ることを意味する。
【0176】
別の実施形態では、読み出し又は検証の方法は、読み出し又は検証動作中に制御ゲートに0V、約0V、又は低バイアス電圧を印加することによって実行される。ワード線は、ワード線に印加されたパルス幅変調入力又はアナログ電圧などを介して、行データ入力(活性化値)を受け取るために、制御ゲート線の代わりに使用される。
【0177】
別の実施形態では、wに対する「0」値(ゼロw又は未使用セル)は、<10nA又は別の所定のスレッショルドとして定義することができる。すなわち、(w+)-(w-)<10nAの場合、wには「0」の値が与えられる。これは、w=0のたびにより大きな公差を提供し、ノイズ、温度変動、又は他の力によって引き起こされた不正確さに対してよりロバストである。
【0178】
別の実施形態では、重みマッピングは、温度変動を低減するように最適化される。例えば、wの所望の値が5nAである場合、1つの可能なマッピングは、(w+)=5nA及び(w-)=0nAであり、別の可能なマッピングは、(w+)=30nA及び(w-)=25nAである。後者は、より多くの電力を消費し、チューニングプロセス中により大きな不正確さを招く可能性があるが、温度変動を最小限に抑える。
【0179】
別の実施形態では、重みマッピングは、ニューロンの総ノイズ又は温度変動を低減するように最適化される。例えば、ビット線当たりの記憶されたw+及びw-値の数(例えば、5nAの場合、30nA~25nA又は50nA~45nA又は80nA~75nAとして実装することができる)は、ビット線当たりの記憶された値の数が全てのビット線に対してほぼ同じになるように、全てのビット線の間でバランスをとるようにマッピングすることができる。
【0180】
別の実施形態では、重みマッピングは、ニューロン(ビット線)の総ノイズを低減するように最適化される。例えば、ビット線ごとの記憶されたw+及びw-値(セル)の数は、ニューロン(ビット線)内の全ての重み(セル)の総ノイズ寄与が最適である(最小ノイズを有する)ように、全てのビット線の間でバランスをとることができる。
表9A:重みチューニング方法
【表9A】
表9B:重みチューニング方法
【表9B】
【0181】
表9A及び9Bは、nAで16個のレベル(状態)の例示的な実施形態を示す。すなわち、メモリセルは、ここに示されるように16個のレベルを有することができる。表9Aは、式Iw=Iw+-Iw-に従って、wが16個の異なる正の値のうちの1つであり得る状況を示し、表9Bは、wが16個の異なる負の値のうちの1つであり得る状況を示す。表に示される電流範囲は、0~80nAである。
表10A:重みチューニング方法
【表10A】
表10B:重みチューニング方法
【表10B】
【0182】
表10A及び10Bは、0~80nAから40nA~85nAへとレベルの動的全電流範囲を圧縮する実施形態を示す。
【0183】
表10A/11A/12Aに関して、Iw-は、粗い又は微細又は超微細チューニングステップ(例えば、Iw-セルのプログラム及び検証)を用いてチューニングされ得、Iw+は、微細又は超微細ステップ(例えば、Iw=(Iw+-Iw-)のプログラム及び検証、又は単にIw+セルのみの検証)を用いてチューニングされ得る。表10B/11B/12Bに関して、Iw+は、粗い又は微細又は超微細チューニングステップ(例えば、Iw+セルのプログラム及び検証)を用いてチューニングすることができ、Iw-は、微細又は超微細ステップ(例えば、Iw=(Iw+-Iw-)のプログラム及び検証、又は単にIwセルのみの検証)を用いてチューニングされ得る。
【0184】
これは、プロセス、温度、ノイズ、動作応力、又は動作条件による変動及び不整合を低減するという点で有利であり、これは、
図11~
図12に示される概念と同様である。
【0185】
表10A及び表10Bに示すように、表の下半分の値は、それらの値の全範囲が表の上半分とほぼ同じになるように、正の量(オフセットバイアス)だけシフトアップされる。オフセットは、最大電流(レベル)の半分にほぼ等しい。
表11A:重みチューニング方法
【表11A】
表11B:重みチューニング方法
【表11B】
【0186】
表11A及び11Bは、オフセットバイアス値に等しいゼロ重み(w=0)を有する、
表10A及び10Bの実施形態と同様の実施形態を示す。例として、1つのオフセットバイアス値に対する重み値の1つの範囲、2つのオフセット値に対する重みの2つのサブ範囲を示す。
表12A:重みチューニング方法
【表12A】
表12B:重みチューニング方法
【表12B】
表13:重みチューニング方法
【表13】
表13は、正の重み及び負の重みに対して変動オフセットを使用する実施形態を示す。
表14:重みチューニング方法
【表14】
表14は、正の重み及び負の重みに対して共通のオフセットを使用する実施形態を示す。
表15:重みチューニング方法
【表15】
表15は、重みに対して増加するオフセットを使用する実施形態を示す。
表16:重みチューニング方法
【表16】
表16は、重みに対して減少するオフセットを使用する実施形態を示す。それはまた、Iw+に対する一定のオフセットを示す。それはまた、Iw+に対する最大定数値を示し、基本的に全ての重みを最大値に向かってシフトする。
【0187】
表12A及び表12Bは、
図10A及び
図10Bの実施形態と同様の実施形態を示し、各w+又はw+値は、2つのメモリセルによって実装されて、合計ダイナミックレンジを更に約半分に低減する。
【0188】
上記の実施形態に提供されたw+及びw-に対する値は単なる例であり、開示される概念に従って他の値を使用することができることを理解されたい。
例えば、オフセットバイアス値は、各レベルの値をシフトする任意の値であってもよいし、又は全てのレベルに対して固定値であってもよい。実際には、各wは差動セルとして実装され、これは、プロセス、温度、ノイズ(RTN又は電源ノイズなど)、応力、又は動作条件からの変動又は不整合を最小限に抑えるのに有効であり得る。
【0189】
図36Aは、(一例としてスブスレッショルド領域における)温度にわたるデータ挙動(I-V曲線)を示し、
図36Bは、VMMシステムの動作中のデータドリフトによって生じた問題を示し、
図36C及び
図36Dは、データドリフトを補償するためのブロックを示し、
図36Cに関しては、温度変化を補償するためのブロックを示す。
【0190】
図36Aは、VMMシステムの既知の特性を示すものであり、その特性は、動作温度が増加するにつれて、VMMアレイ内の任意の所与の選択された不揮発性メモリセル内の検知電流がサブスレッショルド領域内で増加するか、飽和領域内で減少するか、又は概して線形領域内で減少するような特性である。
【0191】
図36Bは、時間使用(データドリフト)にわたるアレイ電流分布を示し、これは、(VMMアレイ内の全てのビット線からの電流の合計である)VMMアレイからの集合出力が、動作時間使用にわたって右に(又は、使用される技術によっては、左に)シフトすることを示しており、これは、総集合出力が、VMMシステムの寿命使用にわたってドリフトすることを意味する。この現象は、データが環境要因による使用条件及び劣化によってドリフトするときの、データドリフトとして知られている。
【0192】
図36Cは、データドリフトを補償するために、ビット線出力回路3610の出力に補償電流i
COMPを注入することを含み得るビット線補償回路3600を示す。ビット線補償回路3600は、抵抗器又はコンデンサネットワークに基づいて、スケーラ回路によって出力を上又は下にスケーリングすることを含み得る。ビット線補償回路3600は、その抵抗器又はコンデンサネットワークに基づいて、シフト回路によって出力をシフト又はオフセットすることを含み得る。
【0193】
図36Dは、データドリフトの量を検出するデータドリフトモニタ3620を示す。次いで、その情報は、ビット線補償回路3600への入力として使用され、その結果、i
COMPの適切なレベルが選択され得る。
【0194】
図37は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路3700を示す。ビット線補償回路3700は、調整可能な電流源3701及び調整可能な電流源3702を備え、これらは、一緒になってi
COMPを生成し、i
COMPは、調整可能な電流源3701から生成された電流から、調整可能な電流源370
2によって生成された電流を引いた電流に等しい。
【0195】
図38は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路3700を示す。ビット線補償回路3800は、動作増幅器3801、調整可能な抵抗器3802、及び調整可能な抵抗器3803を備える。動作増幅器3801は、その非反転端子上で基準電圧VREFを受信し、その反転端子上でV
INPUTを受信し、ここで、V
INPUTは、
図36Cのビット線出力回路3610から受信された電圧であり、V
OUTPUTの出力を生成し、ここで、V
OUTPUTは、抵抗器3803と抵抗器3802の比に基づいてデータドリフトを補償するためのV
INPUTのスケーリングされたバージョンである。抵抗器3803及び/又は3802の値を構成することにより、V
OUTPUTは、上又は下にスケーリングされ得る。
【0196】
図39は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路3900を示す。ビット線補償回路3900は、動作増幅器3901、電流源3902、スイッチ3904、及び調整可能な積分出力コンデンサ3903を備える。ここで、電流源3902は、実際には、VMMアレイにおいて、単一のビット線、又は複数のビット線の集合体(正の重みw+を合計するための1つ、及び負の重みw-を合計するための1つなど)の出力電流である。動作増幅器3901は、その非反転端子上で基準電圧VREFを受信し、その反転端子上でV
INPUTを受信し、ここで、V
INPUTは、
図36Cのビット線出力回路3610から受信された電圧である。ビット線補償回路3900は、調整可能な積分時間においてコンデンサ3903全体にわたって電流Ineuを積分して出力電圧V
OUTPUTを生成する積分器として機能し、ここで、V
OUTPUT=Ineu
*積分時間/C
3903であり、ここで、C
3903は、コンデンサ3903の値である。したがって、出力電圧V
OUTPUTは、(ビット線)出力電流Ineuに比例し、積分時間に比例し、コンデンサ3903の容量に反比例する。ビット線補償回路3900は、V
OUTPUTの出力を生成し、ここで、V
OUTPUTの値は、コンデンサ3903の構成値及び/又はデータドリフトを補償するための積分時間に基づいてスケーリングされる。
【0197】
図40は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路4000を示す。ビット線補償回路4000は、M:N比を有する電流ミラー4010を備え、これは、I
COMP=(M/N)
*i
inputを意味する。電流ミラー4010は、電流i
INPUTを受信し、その電流をミラーリングし、任意選択的に、その電流をスケールしてi
COMPを生成する。したがって、M及び/又はN個のパラメータを構成することによって、i
COMPは、上方又は下方にスケーリングされ得る。
【0198】
図41は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路4100を示す。ビット線補償回路4100は、動作増幅器4101、調整可能なスケーリング抵抗器4102、調整可能なシフト抵抗器4103、及び調整可能な抵抗器4104を備える。動作増幅器4101は、その非反転端子上で基準電圧V
REFを受信し、その反転端子上でV
INを受信する。V
INは、V
INPUT及びVshftに応答して生成され、ここで、V
INPUTは、
図36Cのビット線出力回路3610から受信された電圧であり、Vshftは、V
INPUTとV
OUTPUTとの間でシフトを実装することを意図した電圧である。
したがって、V
OUTPUTは、データドリフトを補償するための、V
INPUTのスケーリング及びシフトされたバージョンである。
【0199】
図42は、
図36のビット線補償回路3600の一実施形態であるビット線補償回路4200を示す。ビット線補償回路4200は、動作増幅器4201、入力電流源Ineu4202、電流シフタ4203、スイッチ4205及び4206、並びに調整可能な積分出力コンデンサ4204を備える。ここで、電流源4202は、実際には、VMMアレイ内の単一又は複数のビット線上の出力電流Ineuである。動作増幅器4201は、その非反転端子上で基準電圧VREFを受信し、その反転端子上でI
INを受信することであって、ここで、I
INは、Ineuと、電流シフタ4203によって出力された電流との合計である、受信することと、V
OUTPUTの出力を生成することであって、ここで、V
OUTPUTは、データドリフトを補償するために、(コンデンサ4204に基づいて)スケーリングされ、(Ishifter4203に基づいて)シフトされる、生成することと、を行う。
【0200】
図43~
図48は、プログラミング又は読み出し動作中に、各選択されたセルにプログラム又は読み出されるW値を提供するために使用され得る様々な回路を示す。
【0201】
図43は、調整可能な電流源4301及び調整可能な電流源4302を備えるニューロン出力回路4300を示し、これらは、一緒になってI
OUTを生成し、I
OUTは、調整可能な電流源4301によって生成された電流I
W+から、調整可能な電流源4302によって生成された電流I
W-を引いた電流に等しい。調整可能な電流Iw+4301は、正の重みを実装するために、セル電流又はニューロン電流(ビット線電流など)のスケーリングされた電流である。調整可能な電流Iw-4302は、負の重みを実装するために、セル電流又はニューロン電流(ビット線電流など)のスケーリングされた電流である。電流スケーリングは、M:N比電流ミラー回路、Iout=(M/N)
*Iinなどによって行われる。
【0202】
図44は、調整可能なコンデンサ4401、制御トランジスタ4405、スイッチ4402、スイッチ4403、及
びM:N電流ミラー回路などによってセル電流又は(ビット線)ニューロン電流のスケーリングされた出力電流である
電流Iw+を生成する、調整可能な電流源4404を備える、ニューロン出力回路4400を示す。トランジスタ4405は、例えば、電流4404に固定バイアス電圧を課すために使用される。回路4404は、V
OUTを生成し、ここで、V
OUTは、コンデンサ4401に反比例し、調整可能な積分時間(スイッチ4403が閉じスイッチ4402が開いた時間)に比例し、調整可能な電流源4404によって生成された電流I
W+に比例する。V
OUTは、V+-((Iw+
*積分時間)/C
4401)に等しく、ここで、C
4401は、コンデンサ4401の値である。コンデンサ4401の正の端子V+は、正の供給電圧に接続され、コンデンサ4401の負の端子V-は、出力電圧V
OUTに接続される。
【0203】
図45は、コンデンサ4401及
びM:N電流ミラー
回路などに
よってセル電流又は(ビット線)ニューロン電流のスケーリングされた電流
Iw-を生成する、調整可能な電流源4502を備えるニューロン回路4500を示す。回路4500は、V
OUTを生成し、ここで、V
OUTは、コンデンサ4401に反比例し、調整可能な積分時間(スイッチ4501が開いた時間)に比例し、調整可能な電流源4502によって生成された電流I
Wiに比例する。コンデンサ4401は、電流Iw+を積分する動作を完了した後、ニューロン出力回路44から再使用される。次いで、正の端子及び負の端子(V+及びV-)は、ニューロン出力回路45内で交換され、そこでは、正の端子は、出力電圧V
OUTに接続され、これは、電流Iw-によって積分解除される。負の端子は、クランプ回路(図示せず)によって前の電圧値に保持される。実際には、出力回路44は、正の重み実装に使用され、回路45は、負の重み実装に使用され、コンデンサ4401上の最終電荷は、合計重み(Qw=Qw+-Qw-)を効果的に表す。
【0204】
図46は、調整可能なコンデンサ4601、スイッチ4602、制御トランジスタ4604、及び調整可能な電流源4603を備えるニューロン回路4600を示す。回路4600は、V
OUTを生成し、ここで、V
OUTは、コンデンサ4601に反比例し、調整可能な積分時間(スイッチ4602が開いていた時間)に比例し、調整可能な電流源4603によって生成された電流I
W-に比例する。コンデンサ4601の負の端子V-は、例えば、接地に等しい。コンデンサ4601の正の端子V+は、例えば、電流Iw-を積分する前に、正の電圧に最初にプリチャージされる。ニューロン回路4600は、ニューロン回路4400と共にニューロン回路4500の代わりに使用して、合計重み(Qw=Qw+-Qw-)を実装することができる。
【0205】
図47は、動作増幅器4703及び4706、調整可能な電流源Iw+4701及びIw-4702、並びに調整可能な抵抗器4704、4705、及び4707を備えるニューロン回路4700を示す。ニューロン回路4700は、V
OUTを生成し、これは、R
4707
*(Iw+-Iw-)に等しい。調整可能な抵抗器4707は、出力のスケーリングを実装する。調整可能な電流源Iw+4701及びIw-4702はまた、M:N比電流ミラー回路(Iout=(M/N)
*Iin)などによる出力のスケーリングを実装する。
【0206】
図48は、動作増幅器4803及び4806、スイッチ4808及び4809、調整可能な電流源Iw-4802及びIw+4801、調整可能なコンデンサ4804、4805、及び4807を備えるニューロン回路4800を示す。ニューロン回路4800は、V
OUTを生成し、これは、(Iw+-Iw-)に比例し、積分時間(スイッチ4808及び4809が開いていた時間)に比例し、コンデンサ4807の容量に反比例する。調整可能なコンデンサ4807は、出力のスケーリングを実装する。調整可能な電流源Iw+4801及びIw-4802はまた、M:N比電流ミラー回路(Iout=(M/N)
*Iin)などによる出力のスケーリングを実装する。積分時間はまた、出力スケーリングを調整することができる。
【0207】
【0208】
図49Aでは、出力回路4901は、ADC回路4911を備え、これは、アナログニューロン出力4910を直接デジタル化してデジタル出力ビット4912を提供するために使用される。
【0209】
図49Bでは、出力回路4902は、ニューロン出力回路4921及びADC4911を備える。ニューロン出力回路4921は、ニューロン出力4920を受信し、それを整形し、その後、それをADC回路4911によってデジタル化して、出力4912を生成する。ニューロン出力回路4921は、前述のような正規化、スケーリング、シフト、マッピング、算術演算、活性化、及び/又は温度補償に使用することができる。ADC回路は、シリアル(傾斜若しくはランプ若しくはカウント)ADC、SAR ADC、パイプラインADC、シグマデルタADC、又は任意のタイプのADCであり得る。
【0210】
図49Cでは、出力回路は、ニューロン出力4930を受信するニューロン出力回路4921を備え、変換器回路4931は、ニューロン出力回路4921からの出力を出力4932に変換するためのものである。変換器4931は、ADC、AAC(電流-電圧変換器などのアナログ-アナログ変換器)、APC(アナログ-パルス変換器)、又は任意の他のタイプの変換器を備えることができる。ADC4911又は変換器4931は、例えば、ビットマッピング(例えば、量子化)又はクリッピング(例えば、クリップピングされたReLU)によって、活性化関数を実装するために使用され得る。ADC4911及び変換器4931は、より低い又はより高い精度(例えば、より低い又はより高い数のビット)、より低い又はより高い性能(例えば、より遅い又はより速い速度)などのように構成可能であり得る。
【0211】
スケーリング及びシフトのための別の実施形態は、アレイ(ビット線)出力を、より少ない又はより多いビット精度を有するものなどのデジタルビットに変換し、次いで、特定の関数(例えば、線形又は非線形、圧縮、非線形活性化など)に従って、正規化(例えば、12ビットから8ビット)、シフト、又は再マッピングなどによってデジタル出力ビットを操作するために使用される、(シリアルADC、SAR ADC、パイプラインADC、傾斜ADCなどの)ADC(アナログ-デジタル)変換回路を構成することによるものである。ADC変換回路の例は、本出願と同じ譲受人によって2019年11月11日に出願された、「Precise Programming Method and Apparatus for Analog Neural Memory in a Deep Learning Artificial Neural Network」と題する米国特許仮出願第62/933,809号に記載されており、これは、参照により本明細書に組み込まれる。
【0212】
表
17は、読み出し、消去、及びプログラム動作を実行するための代替アプローチを示す。
表
17:フラッシュメモリセルの動作
【表17】
読み出し及び消去動作は、前の表と同様である。しかしながら、プログラミングのための2つの方法は、ファウラーノルドハイム(FN)トンネリング機構によって実装される。
【0213】
入力をスケーリングするための実施形態は、一度にVMMの特定の数の行を可能にし、次いで、結果を完全に組み合わせることなどによって行うことができる。
【0214】
別の実施形態は、入力電圧をスケーリングし、正規化のために出力を適切に再スケーリングすることである。
【0215】
パルス幅変調入力をスケーリングするための別の実施形態は、パルス幅のタイミングを変調することによるものである。この技術の一例は、本出願と同じ譲受人によって2019年6月21日に出願された、「Configurable Input Blocks and Output Blocks and Physical Layout for Analog Neural Memory in Deep Learning Artificial Neural Network」と題する米国特許出願第16/449,201号に記載されており、これは、参照により本明細書に組み込まれる。
【0216】
入力をスケーリングするための別の実施形態は、例えば、8ビット入力IN7:0について、一度に1つずつ入力バイナリビットを可能にし、順番にそれぞれIN0、IN1、...、IN7を評価し、次いで、出力結果を適切なバイナリビット重み付けと組み合わせることによるものである。この技術の一例は、本出願と同じ譲受人によって2019年6月21日に出願された、「Configurable Input Blocks and Output Blocks and Physical Layout for Analog Neural Memory in Deep Learning Artificial Neural Network」と題する米国特許出願第16/449,201号に記載されており、これは、参照により本明細書に組み込まれる。
【0217】
任意選択的に、上記の実施形態では、電流を検証又は読み出す目的でセル電流を測定することは、例えば、8~32回、平均の又は複数の測定値をとって、(RTN若しくは任意のランダムノイズの)ノイズの影響を低減し、及び/又は欠陥があり冗長ビットによって置き換えられる必要があるいずれかの外れ値ビットを検出することであり得る。
【0218】
本明細書で使用される場合、「の上方に(over)」及び「に(on)」という用語は両方とも、「に直接」(中間材料、要素、又は間隙がそれらの間に配設されていない)、及び「に間接的に」(中間材料、要素、又は間隙がそれらの間に配設されている)を包括的に含むことに留意されるべきである。同様に、「隣接した」という用語は、「直接隣接した」(中間材料、要素、又は間隙がそれらの間に配設されていない)、及び「間接的に隣接した」(中間材料、要素、又は間隙がそれらの間に配設されている)を含み、「に取り付けられた」は、「に直接取り付けられた」(中間材料、要素、又は間隙がそれらの間に配設されていない)、及び「に間接的に取り付けられた」(中間材料、要素、又は間隙がそれらの間に配設されている)を含み、「電気的に結合された」は、「に直接電気的に結合された」(要素を一緒に電気的に接続する中間材料又は要素がそれらの間にない)、及び「に間接的に電気的に結合された」(要素を一緒に電気的に接続する中間材料又は要素がそれらの間にある)を含む。例えば、要素を「基板の上方に」形成することは、その要素を基板に直接、中間材料/要素をそれらの間に伴わずに形成すること、及びその要素を基板に間接的に1つ以上の中間材料/要素をそれらの間に伴って形成することを含み得る。
【国際調査報告】