A/Dコンバータ その2

5月17日修正
---
"C:\Program Files\LTC\SwCADIII\lib\sym\Misc\pic16adc.asy"
の内容が間違っていたので差し替えました。
---

前回のA/Dコンバータ その1では、LTspiceでPIC16内蔵A/Dコンバータの入力回路(サンプル&ホールド回路)のモデルを作りました。

PIC16F88のデータシートのアナログ入力モデル


前回作成したLTspiceモデル



これを元にサブサーキットとシンボルを作りました。

準備

以下はLTspiceがデフォルトのディレクトリ"C:\Program Files\LTC\SwCADIII"にインストールされているという前提で書きます。違う場所にインストールした人は適宜読み替えてください。

サブサーキットファイルに関しては、以下の引用部分の内容をメモ帳などで"C:\Program Files\LTC\SwCADIII\lib\sub\pic16adc.sub"という名前で保存します。

"C:\Program Files\LTC\SwCADIII\lib\sub\pic16adc.sub"
.SUBCKT PIC16ADC ADC CTRL HOLD VDD VSS
Cpin ADC VSS 5p
D1 VSS ADC D
D2 ADC VDD D
Ileackage ADC VSS 500nA
Ric N001 ADC 1k
S1 N001 N002 CTRL VSS SS
Chold HOLD VSS 120p
Rss HOLD N002 {17k-2k*Vs}
.model D D
.model SS SW(Vt=1V Vh=0V)
.ENDS

シンボルファイルは、"C:\Program Files\LTC\SwCADIII\lib\sym\Misc\pic16adc.asy"として保存します。

5月17日修正
---
冒頭でも書きましたが
"C:\Program Files\LTC\SwCADIII\lib\sym\Misc\pic16adc.asy"
の内容が間違っていたので差し替えました。
---

"C:\Program Files\LTC\SwCADIII\lib\sym\Misc\pic16adc.asy"
Version 4
SymbolType CELL
RECTANGLE Normal -160 -80 32 16
WINDOW 0 0 32 Left 0
SYMATTR Prefix X
SYMATTR Description pic16f88 ADC sample & hold circuit
SYMATTR SpiceLine Vs=5
SYMATTR Value pic16adc
SYMATTR ModelFile pic16adc.sub
PIN -160 -48 LEFT 8
PINATTR PinName ADC
PINATTR SpiceOrder 1
PIN -160 -16 LEFT 8
PINATTR PinName CTRL
PINATTR SpiceOrder 2
PIN 32 -32 RIGHT 8
PINATTR PinName HOLD
PINATTR SpiceOrder 3
PIN -48 -80 TOP 8
PINATTR PinName VDD
PINATTR SpiceOrder 4
PIN -48 16 BOTTOM 8
PINATTR PinName VSS
PINATTR SpiceOrder 5

これで"Misc"からpic16adcが使えるようになったと思います。使えなかったらコメント欄で教えてください。対処できないかもしれませんけど。

各端子の説明

VDD:PICのVDD端子に相当します
VSS:PICのVSS端子に相当します
ADC:PICのアナログ入力端子に相当します
CTRL:PICから外部に出る端子ではありません。サンプル/ホールドを制御する端子で、HでサンプルLでホールドになります。しきい値は電源電圧にかかわらず1Vです。
HOLD:サンプル&ホールド回路に取り込まれた電圧を読み取るための端子です。PICから外部へは出ません。

使い方

今回のシンボルを使って、前回の例題を描き直してみました。






Vs=5VはVDD-VSS間の電圧です。回路図上のサンプル&ホールド回路の上で右クリックをして出てくるウインドウ上のSpiceLineの欄にVsを設定します。PICを3.3Vで動作させているのならVs=3.3Vと書きます。


これは、電源電圧に応じてサンプリングスイッチの寄生抵抗が変化するためです。


tag: LTspice A/Dコンバータ PIC 

comment

Secret

FC2カウンター
カテゴリ
ユーザータグ

LTspiceAkaiKKRmachikaneyamaScilabKKRPSoC強磁性CPAPICOPアンプecalj状態密度常微分方程式モンテカルロ解析トランジスタodeDOSインターフェーススイッチング回路定電流PDS5022分散関係半導体シェルスクリプト乱数レベルシフトHP6632A温度解析ブレッドボード可変抵抗I2Cトランジスタ技術R6452A確率論バンド構造セミナーバンドギャップ反強磁性数値積分熱設計絶縁非線形方程式ソルバ偏微分方程式PWscfA/Dコンバータマフィンティン半径フォトカプラカオスISO-I2CGW近似LM358LEDシュミットトリガ三端子レギュレータ74HC4053アナログスイッチUSBサーボ数値微分直流動作点解析補間カレントミラーTL431PC817C発振回路FFT電子負荷VESTA開発環境量子力学単振り子bzqlty基本並進ベクトル2ちゃんねるチョッパアンプ標準ロジックパラメトリック解析アセンブラブラべ格子BSchQuantumESPRESSOイジング模型LDA状態方程式GGA仮想結晶近似VCA熱伝導SMPスイッチト・キャパシタキュリー温度Quantum_ESPRESSOスーパーリーグTLP621トレーナーバトルewidth最適化Maxima抵抗失敗談相対論コバルト繰り返し位相図六方最密充填構造ポケモンGOスピン軌道相互作用gfortranランダムウォークFETスレーターポーリング曲線cygwinQSGW不規則合金ラプラス方程式MCU条件分岐データロガーマントルUPS固有値問題格子比熱シュレディンガー方程式熱力学詰め回路ガイガー管QNAP井戸型ポテンシャルダイヤモンドOpenMPTLP521ハーフメタルLM555ubuntu平均場近似ブラウン運動フェルミ面NE555ZnOゼーベック係数TLP552xcrysdenCIF最小値最大値awkfsolveテスタ第一原理計算Ubuntu差し込みグラフFXA-7020ZR三角波過渡解析Writer509自動計測スーパーセル起電力トランスCK1026MAS830LフィルタPGAP-10MBEOPA2277ナイキスト線図ノコギリ波AACircuitEAGLE2SC1815PIC16F785LMC662CapSense負帰還安定性入出力固定スピンモーメントFSMTeX結晶磁気異方性全エネルギーc/a合金multiplotgnuplot非線型方程式ソルバL10構造正規分布等高線ジバニャン方程式初期値interp1fcc面心立方構造ウィグナーザイツ胞半金属デバイ模型磁気モーメント電荷密度重積分SIC不純物問題擬ポテンシャル状態図cif2cellPWgui二相共存ウルツ鉱構造edeltquantumESPRESSOフォノンリジッドバンド模型スワップ領域BaO岩塩構造ルチル構造ヒストグラム確率論マテリアルデザインフラクタルマンデルブロ集合キーボードRealforceクーロン散乱三次元疎行列縮退化学反応関数フィッティング最小二乗法Excel直流解析PCTS-110TS-112日本語パラメータ・モデル等価回路モデル文字列不規則局所モーメント陰解法熱拡散方程式HiLAPWCrank-Nicolson法連立一次方程式specx.fifort境界条件両対数グラフ片対数グラフGimp円周率ヒストグラムシンボル線種グラフの分割軸ラベル凡例トラックボール

最新コメント
リンク

にほんブログ村 その他趣味ブログ 電子工作へ