リファレンス・マニュアル

このドキュメントは以下の貢献者により著作権所有 © 2010-2015 されています。あなたは、GNU General Public License ( http://www.gnu.org/licenses/gpl.html ) のバージョン 3 以降、あるいはクリエイティブ・コモンズ・ライセンス ( http://creativecommons.org/licenses/by/3.0/ ) のバージョン 3.0 以降のいずれかの条件の下で、配布または変更することができます。

このガイドの中のすべての商標は、正当な所有者に帰属します。

*貢献者*

Jean-Pierre Charras, Fabrizio Tappero.

翻訳

starfort <starfort AT nifty.com>, 2015. Norio Suzuki <nosuzuki AT postcard.st>, 2015. yoneken <yoneken AT kicad.jp>, 2011-2015. Silvermoon, Zenyouji, Millo, Nenokuni 2011-2012.

フィードバック

このドキュメントに関するコメントや提案をKiCad メーリングリストに送ってください : https://launchpad.net/~kicad-developers

発行日とソフトウエアのバージョン

2015年5月30日 発行

1. Eeschema 入門

1.1. 説明

Eeschema は、KiCad の一部として配布されている強力な回路図エディタソフトウェアであり、次のオペレーティングシステムの下で利用可能です。:

  • Linux

  • Apple OS X

  • Windows

OS に関係なく、すべての Eeschema ファイルは一方の OS から他方のものへ 100 %互換性があります。

Eeschema は、図面、コントロール、レイアウト、ライブラリ管理および、PCB 設計ソフトウェアへのアクセスといったすべての機能が Eeschema 内で実行される統合ソフトウェアです。

Eeschema は、プリント基板設計ソフトウェア PcbNew とともに使用されることを想定しています。また、PCB の電気的接続を記述するネットリストファイルをエクスポートすることも可能です。

Eeschema は、コンポーネントの作成/編集やライブラリの管理ができるコンポーネント・ライブラリ・エディタを含んでいます。また、現代の回路図エディタソフトに必要不可欠な機能だけでなく、以下の追加機能も組み込まれています。:

  • Electrical rules check (ERC) for the automatic control of incorrect and missing connections

  • 多くの形式 (Postscript, PDF, HPGL, SVG) をサポートしたプロットファイルのエクスポート。

  • (様々なフォーマットを設定できるよう Python スクリプトを使用した)部品表 (BOM) の生成。

1.2. 技術的な概要

Eeschema は、コンピュータで利用可能なメモリの大きさにのみ制限を受けます。コンポーネント、ピン、接続、シート、の数に関して明示的な制限はありません。複数シートからなる回路図では、階層的な表示となります。

Eeschema は、次のタイプの複数のシートからなる回路図を扱うことができます:

  • 単一の階層 (各図が一度だけ使用される)。

  • 複雑な階層 (いくつかの図は、一度以上の複数回使用される)。

  • 平面的(フラット)な階層 (マスター図面の中、いくつかの図面は明示的に接続されない)。

2. Eeschema コマンド全般

2.1. Eeschema コマンドへのアクセス

以下に示す様々な方法でコマンドを起動できます:

  • 画面上部のメニューバーをクリックする。

  • 画面上部のアイコンをクリックする (一般コマンド)。

  • Clicking on the icons on the right side of the screen (particular commands or "tools").

  • 画面左側のアイコンをクリックする(表示オプション)。

  • マウスボタンをクリックする(重要な補助コマンド)。特に右クリックでは、カーソル下の要素に対応したコンテキストメニューを開きます(ズーム、グリッドと要素の編集)。

  • Function keys (F1, F2, F3, F4, Insert and space keys). Specifically: The "Escape" key often allows the canceling of a command in progress. The "Insert" key allows the duplication of the last element created.

下図に様々なコマンドの配置を示します。:

commands overview

2.2. マウスコマンド

2.2.1. 基本コマンド

左ボタン

  • シングルクリック: カーソルに下にあるコンポーネントあるいはテキストの属性をステータスバーへ表示する。

  • ダブルクリック: コンポーネントあるいはテキストを編集する。(要素が編集可能な場合)

右ボタン

  • コンテキストメニューを開く。

2.2.2. ブロックの操作

Eeschema では、選択範囲を移動、ドラッグ、コピー、削除することができます。

マウスの左ボタンを押しながらドラッグして範囲を選択し、左ボタンを離すと範囲の選択ができます。

“Shift” と “Ctrl” キーのうちどちらか1 つ、もしくは “Shift” と “Ctrl” キーの両方を押しながら選択することで、選択した範囲をコピーするか、ドラッグするか、削除するか、が変わります。

左マウスボタン

選択範囲を移動。

Shift + 左マウスボタン

選択範囲をコピー。

Ctrl + 左マウスボタン

選択範囲をドラッグ。

Ctrl + Shift + 左マウスボタン

選択範囲を削除。

ドラッグまたはコピー中、次のことができます:

  • もう一度クリックして要素を置き直す。

  • 右ボタンをクリックして取消す。

ブロック移動コマンドが実行されているとき、マウスの右ボタンからコンテキストメニューを開くと、他のブロックコマンドも選択できます:

main window popup

2.3. ホットキー

  • The "?" key displays the current hotkey list.

  • ホットキーは、上部メニューバーの "設定" から "ホットキーの編集" を選択すると変更できます。

以下はデフォルトのホットキーのリストです:

Default hotkey list

全てのホットキーは、ホットキーエディタでユーザが再定義できます。

Hotkeys editor window

2.4. グリッドサイズの選択

Eeschema では、表示/非表示が可能なグリッド上でカーソルが動きます。コンポーネント・ライブラリ・エディタでもグリッドは表示されます。

コンテキストメニューあるいは「設定/オプション」メニューから、グリッドサイズを変えることができます。

デフォルトのグリッドサイズは、50 mil (0.050”) あるいは 1,27 mm です。

これは回路図上で配線や部品を配置したり、コンポーネント・ライブラリ・エディタ上で回路記号のピンを配置するのに適したサイズです。

25 mil から 10 mil のより細かいグリッドでも作業できます。これは、ピンの配置や配線ではなく、コンポーネント本体のデザインあるいはテキストやコメントを配置する時に使うことを意図しています。

2.5. ズームの選択

ズームレベルを変えるには:

  • 右クリックしてコンテキストメニューを開き、希望のズームを選択。

  • あるいはファンクションキーを使って:

    • F1: ズームイン

    • F2: ズームアウト

    • F4 または(マウスを止めたまま)中央ボタンをクリック: 画面の中央をカーソル位置近辺に設定

  • ウィンドウのズーム:

    • マウスホイール: ズームイン/ズームアウト

    • Shift+ マウスホイール : 上/下 パン

    • Ctrl+マウスホイール : 左/右 パン

2.6. カーソルの座標表示

表示単位は inch あるいは mm です。しかしながら、Eeschema は内部的には常に 1/1000 inchで扱っています。

ウィンドウの下部右側には以下の情報が表示されます:

  • ズーム倍率

  • カーソルの絶対位置

  • カーソルの相対位置

相対座標値 (x, y) はスペースキーで (0, 0) へリセットされます。これは2点間の距離を測る時に役立ちます。

images/ja/status_bar.png

2.7. 上部メニューバー

上部メニューバーでは、回路図やプログラム設定を開いたり、保存したり、ヘルプメニューを開いたりできます。

menubar

2.8. 上部ツールバー

このツールバーから、Eeschema の主な機能へアクセスできます。

Eeschema が単独で実行されている場合、以下のツールが有効です。:

images/toolbar_schedit_standalone.png

Eeschema がプロジェクトマネージャー (KiCad) から実行されている場合、以下のツールが有効です。:

images/toolbar_schedit.png

プロジェクトを初期化するツールは無効です。このツールは プロジェクトマネージャー にあります。

new schematic icon

新規回路図の作成(単独実行時のみ)

Open schematic icon

既存回路図を開く(単独実行時のみ)

icons/save_png

Save complete (hierarchical) schematic.

Page Settings icon

ページの設定(用紙サイズと表題欄の編集)

icons/print_button_png

回路図の印刷(プリントダイアログを開く)

icons/cut_button_png

選択したアイテムを切り取り(ブロック移動の間に選択された要素を削除)

icons/copyblock_png

選択したアイテムをコピー(ブロック移動時に選択された要素をクリップボードにコピー)

icons/paste_png

貼り付け(現在のシートで最後に選択した要素,あるいはブロックを貼り付け)

icons/undo_png

一つ前のコマンドを元に戻す(10段階まで)

icons/redo_png

一つ前のコマンドをやり直し(10段階まで)。

search icon

コンポーネントとテキストの検索(ダイアログの呼び出し)

search replace icon

テキストの検索と置換(ダイアログの呼び出し)

icons/zoom_in icons/zoom_out

ズームイン/ズームアウト(画面中央近辺)

icons/zoom_redraw

回路図ビューの再描画

icons/zoom_fit_in_page_png

回路図表示を画面サイズに合わせる

hierarchy navigator icon

図面図の階層ナビゲータを表示(ツリー構造(サブシートがある場合)と階層を表示)

icons/leave_sheet

現在のシートそのままで上の階層へ(現在のシートをそのままにして、階層を一つ上がる)

icons/libedit_png

ライブラリエディタ - コンポーネントの作成と編集( Libedit の呼び出し)

icons/library_browse_png

ライブラリブラウザ - コンポーネントの参照( Viewlib )

icons_annotate_png

回路図のアノテーション。

ERC icon

ERC (エレクトリック・ルール・チェッカ)。自動で電気的接続をチェックする。

Netlist icon

ネットリストの作成(Pcbnew,Spice フォーマット及びその他フォーマットでエクスポート)

BOM icon

部品表 (BOM : Bill of Materials) の生成。

edit_module icon

Edit footprint.

run cvpcb icon

Call CvPcb to assign footprints to components.

icons/pcbnew_png

Pcbnew (プリント基板のレイアウト)の実行

Import Footprint Names icon

CvPcb の .cmp ファイルより、コンポーネント・フットプリント・フィールドの情報をバックインポート

2.9. 右ツールバー

images/toolbar_schedit_rightside.png

This toolbar contains tools to:

* コンポーネント、ワイヤ、バス、ジャンクション、ラベル、テキストの配置 * シートの階層メニューのナビゲーション * 階層サブシートと接続シンボルの作成 * コンポーネントの削除

The detailed use of these tools is described in the chapter "Diagram Creation/Editing". An outline of their use is given below.

icons/cursor_png

進行中の命令やツールの停止。

icons/hierarchy_cursor_png

階層の上下移動: サブシートを開いたり(サブシートの シンボルをクリック)、階層を戻ったり できます。(サブシートの何もないエリア でクリック)

New Component icon

コンポーネントの配置。

Add Power icon

電源ポートの配置。

icons/add_line_png

ワイヤの配置。

icons/add_bus_png

バスの配置。

icons/add_line2bus_png

ワイヤ - バスエントリを配置。これらの要素は装飾的な役割だけなので、 配線間の接続に使用すべきではありません。

icons/add_bus2bus_png

バス - バスエントリを配置。これは2本のバス同士をつなぐだけです。

icons/noconn_png

Place a "No Connect" flag. These are placed on component pins which are not to be connected. This is useful in the ERC function to check if pins are intentionally left not connected or are missed.

icons/add_junction_png

ジャンクション(接続点)の配置。 接続状況が はっきりしない2本の交差する配線や、 ピン同士を接続します。

icons/add_line_label_png

ネット名(ローカルラベル)の配置。異なるワイヤは、 同じシート内 で 同一のラベルを使用すると接続されます。異なるシート間の接続の 場合は、グローバルラベルを使用してください。

Global label icon

Place a global label. All global labels with the same name are connected, even between different sheets.

icons/add_hierarchical_label_png

階層のラベル入力。シートと、そのシートシンボルを含む 親シート間の接続を配置します。

icons/add_hierarchical_subsheet_png

階層シートの作成。サブシートのデータを保存するためには,ファイル名を指定する必要があります。

icons/import_hierarchical_label_png

Import hierarchical labels from a subsheet. These hierarchical labels must already be placed in the subsheet. These are equivalent to pins on a component, and must be connected using wires.

icons/add_hierar_pin_png

階層ピンをシートに配置。この機能は上のものとほとんど同じですが、 事前にグローバルシンボルをサブシートに配置しておく必要がありません。

icons/add_dashed_line_png

図形ラインかポリゴンを配置。装飾用です。ワイヤと異なり接続されません。

icons/add_text_png

(コメント)テキストの配置。装飾用。

icons/image_png

ビットマップイメージの追加。

icons/cancel_png

Delete selected element.

If several superimposed elements are selected, the priority is given to the smallest (in the decreasing priorities: junction, "No Connect", wire, bus, text, component). This also applies to hierarchical sheets. Note: the "Undelete" function of the general toolbar allows you to cancel last deletions.

2.10. 左ツールバー

このツールバーは表示オプションを管理します:

icons/grid

グリッドを表示/非表示(トグル動作)

icons/unit_inch

単位をインチ系へ設定

icons/unit_mm

単位を mm 系へ設定

icons/cursor_shape

カーソルの形を変える

icons/hidden_pin

非表示のピンを表示する/表示しない(トグル動作)

icons/lines90

配線、バスを自由角度で描画

2.11. コンテキストメニューとクイックエディット

右クリックで選択要素に応じたコンテキストメニューを開き、下記の機能にアクセスします:

  • ズーム倍率。

  • グリッド調整。

  • パラメータ編集。

1000000000000134000001411D7B987C_png

要素を選択しないでコンテキストメニューを呼び出す。

1000000000000198000001DF29593D94_png

ラベルの編集。

10000000000001AC000001C185B85332_png

コンポーネントの編集。

3. 上部メニューバーの主なメニュー

3.1. ファイルメニュー

File menu

新規回路図プロジェクト

現在の回路図をクリアし,新しい回路図を初期化する。

既存の回路図プロジェクトを開く

回路図の階層を開く。

最近開いたファイル

最近開いたファイルのリストから開く。

回路図シートの追加

現在の回路図へ別のシートの内容を追加する。

回路図プロジェクトの保存

現在のシートと全ての階層を保存する。

現在のシートのみ保存

階層の他のシートを除く現在のシートを 保存する。

名前を付けて保存

名前を付けて現在のシートを保存。

ページ設定

ページの寸法とタイトルブロックを設定する。

印刷

印刷メニューにアクセスする( プロットと印刷 の章を参照)。

出図(プロット)

Postscript HPGL あるいは SVF フォーマットで出図 (Export) する( プロットと印刷 の章を参照)。

閉じる

保存せずに終了する。

3.2. 設定メニュー

3.2.1. 設定

Preferences menu

コンポーネントライブラリ

ライブラリとライブラリパスを選択。

色の設定

印刷、プロット(出図)の色を選択。

回路図エディタオプション

一般的なオプション ( 単位、グリッドサイズ、ファイル名等)。

言語

インターフェイスの言語を選択。

ホットキー

リスト、編集、エクスポート、インポートのホットキー設定。

設定の保存

.pro ファイルへプロジェクトの設定を保存。

設定の読込み

.pro ファイルからプロジェクトの設定を読込み。

3.2.2. 設定メニュー / コンポーネントライブラリ

Library settings

このダイアログは、コンポーネントライブラリと検索パスの設定に使用されます。設定パラメータは .pro ファイルに保存されます。異なるディレクトリでは、異なる設定ファイルを使用することも可能です。

Eeschema は次の優先度順に設定ファイルを検索します。:

  1. 現在のディレクトリ内の設定ファイル (projectname.pro) 。 KiCad ディレクトリ内の kicad.pro という設定ファイル。このファイルはデフォルト設定として使用されます. ファイルが見つからない場合のデフォルト値。少なくともロードするためのライブラリのリストを記入し、設定を保存する必要があります。

“回路図の読込み時にキャッシュ/ライブラリの衝突をチェック” ボックスはライブラリの衝突を救済する設定用に使われます。詳細は、キャッシュされたコンポーネントのレスキュー を参照のこと。

3.2.3. 設定メニュー / 色の設定

Color settings

様々な要素の描画色と背景色(黒または白のみ)の設定。

3.2.4. 設定メニュー / 回路図エディタオプション

Schematic Editor Options

計測単位:

表示とカーソル座標の単位 (インチまたは mm )を選択。

グリッドサイズ:

グリッドサイズの選択。

通常グリッド(0.050 インチあるいは 1.27mm)での作業を推奨 より 細かいグリッドはコンポーネント作成で使用

デフォルトのバス線幅:

ペンのサイズはバスを描画するために使用される。

セグメント幅の変更:

ペンのサイズはペンサイズが指定されていないオブジェクトを 描画するために使用される。

デフォルトペンサイズ:

新しいテキストやラベルが新規作成される時に使用される。

アイテムを水平方向にリピート

要素複写する際のX軸のシフト値(通常値は0)

(コンポーネント、ラベル、配線といったアイテムの配置後、 :: インサート キーにより複写される。)

アイテムを垂直方向にリピート

要素複写する際のY軸の シフト値(通常、値は 0.100 inch あるいは 2,54 mm)

ラベルのカウントアップリピート:

バスの配線のように,一つずつカウントアップ する値 (通常、値は 1 か -1 )。

自動保存の間隔:

バックアップを保存する時間間隔(分)。

部品 ID の表記方法:

コンポーネント名を示すために使われる接尾辞の形式 (U1A, U1.A, U1-1, etc.)

グリッドの表示:

チェックがある場合:グリッドを表示。

非表示ピンの表示:

非表示 ( または hidden) ピンを表示。チェックがある場合、 電源ピンも表示される。

拡大縮小時にカーソルを中心へ移動させない:

拡大縮小時にカーソルの位置を変更しない。

マウスの中ボタンを、画像のパンに利用する

有効にすると、マウス中ボタンを押した時にカーソル移動に合わせてシート全体が移動する。

パン可能な領域を、スクロールサイズ範囲内に制限する

有効にすると、マウス中ボタンでの 表示領域外へのシート移動はできません。

オブジェクト移動時に表示領域を移動

チェックがある場合、配線作業や要素移動中にウィンドウから カーソルが出ようとすると、自動的にウィンドウが追従する。

バス、配線の 90 度入力

チェックがある場合,バスや配線は垂直または水平になる。

チェックがない場合、バスと配線はどんな傾きにも配置できる。

ページの境界を表示

チェックがある場合、画面上にページの境界が表示される。

3.2.5. 言語設定

デフォルトのモードで使用してください。他言語は主に開発目的で利用されます。

3.3. ヘルプメニュー

KiCad についての広範囲なチュートリアルについては、オンラインヘルプ(この文書)にアクセスします。ビルドと環境を明示してバグレポートを送る時は、“バージョン情報をコピー” を使って下さい。

4. 上部ツールバーの主なツール

4.1. ページ設定

Sheet Settings icon アイコンにより、ページ設定にアクセスできます。ここでは用紙サイズと右下隅にある表題欄のテキストセクションを定義することができます。

Page Settings

シートの数やシート番号といったデータは、自動的に更新されます。左向き矢印のボタンを押すと今日の日付を “変更日” の日付に設定することができますが、自動的には更新されません。

4.2. 回路図エディタのオプション

4.2.1. 全般オプション

Schematic Editor Options

4.2.2. フィールド名のテンプレート

各々のコンポーネントでデフォルトで存在するカスタムフィールド(フィールドが空のままでも可)を定義できます。

Template Field Names settings

4.3. 検索ツール

Find icon アイコンは、検索ツールへのアクセスに使われます。

Find dialog

現在のシートあるいは階層全体内にある、リファレンス、値、テキスト文字列を検索することができます。見つかると、関係するサブシートの見つかった要素の上にカーソルが移動します。

4.4. ネットリストツール

Netlist icon アイコンで、ネットリストファイルを生成するツールを呼び出します。

ネットリストファイルは、階層全体(通常のオプション)の全ての接続の記述を作成します。

マルチシートの階層において、ローカルラベルは自身が属するシート内だけで通用します。したがって、シート3のラベル TOTO は、シート5のラベル TOTO とは接続されません(意図的にそれらを接続していない場合)。これは、シート番号(アノテーションコマンドによって更新される)がローカルラベルと関連付けられているからです。

注1:

Eeschema にはラベルの長さに制限はありませんが、生成されたネットリストを利用するソフトウェアには制限のある場合があります。

注2:

区切られた単語として表示されてしまうため、ラベルの中では空白文字(半角スペース)を使うべきではありません。それは Eeschema の制限ではなく、多くのネットリストフォーマットにおいて、ラベルは空白文字を含んでいないものと定義されているからです。

Netlist dialog

オプション:

デフォルトの出力形式に設定 :

デフォルトのフォーマットとして Pcbnew を選択するためには、チェックを入れてください。

以下のような他のフォーマットも生成できます:

  • Orcad PCB2

  • CadStar

  • Spice, シミュレータ用

“プラグインの追加” を使うと、外部プラグインでネットリスト・フォーマット・リストを拡張できます( PadsPcb プラグインなど)。

4.5. アノテーションツール

icons_annotate_png アイコンからアノテーションツールを呼び出します。このツールは使用されている全てのコンポーネントに対して自動的にリファレンス(参照番号)の割り付けを行います。

多パーツコンポーネント(4ゲート入りの 7400 TTL など)には、マルチパート (multi-part) の接尾辞が割り当てられます。従って、U3に指定された7400 TTL は、U3A、U3B、U3C、U3D に分かれます。

無条件に全てのコンポーネントに、または未だアノテートされていない新規のコンポーネントだけに、アノテートできます。

annotate-dialog_img

実行範囲

全ての回路図、階層を使用:全てのシートを再アノテート (通常の選択)

現在のページでのみ使用:現在のシートのみ再アノテート(このオプションは特別な場合にのみ使用されます。 例えば、現在のシートの抵抗のみを対象としたい場合など)

既存のアノテーションをキープ:条件付きのアノテーション。新しいコンポーネントのみ再アノテート(通常の選択)。

既存のアノテーションをリセット:無条件のアノテーション。全てのコンポーネントを再アノテートします(このオプションは重複したリファレンスがある場合に使われます)。

既存のアノテーションをリセット、ただし複数ユニットを持つ部品はキープ:再アノテートの時、全ての多パーツコンポーネントのグループ (例えば、U2A, U2B) を維持します。

アノテーションの順番

コンポーネントの番号付けを行う順番を選択します。

アノテーションの選択

コンポーネント番号の選択方法を選択します。

4.6. エレクトリック・ルール・チェッカ (ERC) ツール

ERC icon アイコンで、エレクトリック・ルール・チェッカ (ERC) ツールを呼出します。

このツールは設計の検証を行い、特に接続忘れや矛盾を検出するのに役立ちます。

一度 ERC を実行すると、Eeschema はラベルやピン上に問題を目立たせるマーカーを配置します。マーカー上で左クリックすると診断結果を表示します。エラーファイルを生成させることもできます。

4.6.1. ERC ダイアログ:ERC

ERC dialog

エラーはエレクトリック・ルール・チェッカ (ERC) ダイアログボックスに表示されます:

  • 合計(エラーと警告の合計数)

  • 警告(警告の発生数)

  • エラー(エラーの発生数)

オプション:

  • ERC レポートファイルの生成:ERC レポートファイルを生成するには、このオプションをチェックします。

コマンド:

  • マーカーの削除:全ての ERC エラー/警告マーカーを消去する

  • 実行:エレクトリック・ルール・チェッカを実行する

  • 閉じる: このダイアログボックスを閉じる

注:

  • エラーメッセージをクリックすると、回路図の対応するマーカーにジャンプします。

4.6.2. ERC ダイアログ:オプション

ERC Options dialog

このタブページで、ピン間の接続ルールを設定できます。それぞれのケースに対して、3つのオプションから選択できます。:

  • エラーなし(No error: 緑)

  • 警告(Warning: 黄)

  • エラー(Error: 赤)

マトリックスのそれぞれの四角上でクリックすることにより、内容を変更できます。

4.7. 部品表 (BOM) ツール

BOM icon アイコンで、部品表 (BOM) ツールを呼出します。このメニューから、コンポーネントと階層接続グローバルラベルの一覧表が生成できます。

BOM dialog

Eeschema の部品表 (BOM) ツールは外部プラグイン (通常、XSLT 又は Python) を利用します。いくつかが提供中で、KiCad プログラムのあるディレクトリへインストールされます。

部品表 (BOM) で使用されるコンポーネントプロパティは、次のとおりです。:

  • Value - unique name for each part used.

  • Footprint - either manually entered or back-annotated (see below).

  • Field1 - Manufacturer’s name.

  • Field2 - Manufacturer’s Part Number.

  • Field3 - Distributor’s Part Number.

例:

Component Properties dialog

4.8. フットプリント割当用インポート(バックアノテート)ツール

4.8.1. アクセス:

Import Footprint Names icon アイコンで、バックアノテートツールを呼出します。

このツールを使うと、PcbNew で変更されたフットプリントを Eeschema のフットプリントフィールドへ反映させること (imported back) ができます。

5. 回路図の作成と編集

5.1. はじめに

回路図は1枚のシートのみを使用しても作成可能ですが、規模の大きな回路図の場合は複数のシートで構成することもできます。

回路図が複数のシートから構成される場合を階層構造と呼び、構成する全てのシート(各シートはそれぞれ1つのファイルから成っています)が Eeschema のプロジェクトを構成することになります。階層構造を持つ回路図については 階層回路図 の章に記述があります。

5.2. 基本的な検討事項

Eeschema を使う回路図設計は、単なる回路図画像の描画に留まりません。この回路図設計は,開発フローのスタートとなります。:

A schematic mainly consists of components, wires, labels, junctions, buses and power ports. For clarity in the schematic, you can place purely graphical elements like bus entries, comments, and polylines.

5.3. 開発フロー

dev-chain_png

コンポーネントはコンポーネントライブラリから回路図へと配置されます。回路図が完成した後で、PcbNew が回路の接続情報とフットプリントをインポートできるように、ネットリストが作られます。

5.4. コンポーネントの配置と編集

5.4.1. コンポーネントの検索と配置

To load a component into your schematic you can use the icon New Component icon . A dialog box allows you to type the name of the component to load.

Choose Component dialog

“コンポーネントの選択” ダイアログは、名前、キーワード、検索フィールドへの入力内容でコンポーネントをフィルタリングできます。

コンポーネントを回路図へ配置する前に、ホットキーや右クリックで表示されるコンテキストメニューを使って、コンポーネントの回転( 90 度ごと)、横軸/縦軸でのミラー、フィールドの編集ができます。これらの変更は,部品を配置した後でも簡単に行うことができます。

配置中のコンポーネントは次のようになります。:

component during placement

5.4.2. 電源ポート(コンポーネント)

電源ポートもコンポーネントのひとつです( “power” ライブラリに分類されています)。よって、これまで説明したコンポーネントの配置と同じ手順で配置することができます。しかし、これらは頻繁に配置されるものなので、 Add Power icon “電源ポートの配置” ツールが用意されています。このツールは “power” ライブラリを探して直接参照します。

5.4.3. (配置された)コンポーネントの編集と変更

コンポーネントの編集には,以下の2種類があります:

  • コンポーネント自身の変更:部品の位置、向き、複数ユニットを持つコンポーネントのユニット選択。

  • コンポーネントフィールドの変更:リファレンス、定数、フットプリント、等。

コンポーネントが配置された直後に必要に応じてそれらの部品定数を設定します(特に抵抗やコンデンサなど)。しかし、コンポーネントを配置した直後に部品のリファレンスの割り当てを行ったり、あるいは7400のような複数ユニットを持つコンポーネント内の部品番号を設定したりすることは無駄になってしまうかもしれません。これらコンポーネントのリファレンスや部品番号は、アノテーション機能を使うことで後から自動的に割り振ることができます。

コンポーネントの変更

コンポーネントのプロパティを編集するには、マウスカーソルをコンポーネント上へ移動させ、以下のいずれかの操作をします。:

  • コンポーネントをダブルクリックして、全てのプロパティを編集することができるダイアログボックス(コンポーネントプロパティ)を開く。

  • 右クリックしてコンテキストメニューを開き、表示された編集コマンドを選択する: 移動、回転、編集、削除など。

テキストフィールドの編集

リファレンス、定数、位置、向き、テキストサイズ、フィールドの可視性を変更できます。:

  • テキストフィールドをダブルクリックし編集する。

  • 右クリックしてコンテキストメニューを開き、表示された編集コマンドを選択する: 移動、回転、編集、削除など。

他のオプションの変更や新たにフィールド項目を作成する場合は、コンポーネントをダブルクリックし、コンポーネントプロパティのダイアログを開きます。

Component Properties dialog

それぞれのフィールドについて表示/非表示と回転(表示方向)を設定することができます。表示位置は常に普通に表示される(回転やミラーがない)コンポーネントに対するもので、コンポーネントのアンカー位置への相対座標で指定します。

“ライブラリのデフォルト値にリセット” ボタンは、コンポーネントを元の向きにセットし、オプション、サイズ、位置、各フィールドを初期化します。しかし、回路図情報を壊してしまう可能性があるため、テキストフィールド(リファレンス、定数、フットプリント等)の内容は変更されません。

5.5. ワイヤ、バス、ラベル、電源ポートの接続

5.5.1. はじめに

これら全ての描画要素は、画面右に縦表示されているツールバーに配置されています。

これらの要素を以下に示します:

  • ワイヤ: コンポーネント間の接続

  • バス: バス配線をまとめラベルを用いて接続

  • Polylines: for graphic presentation.

  • ジャンクション(接続点): ワイヤやバスの交差点で接続

  • ワイヤ - バスエントリ: バス配線とワイヤの接続。グラフィックのみ!

  • ネット名(ローカルラベル): 接続の作成やラベリング

  • グローバルラベル: シート間での接続

  • テキスト: コメントとアノテーション用

  • "No Connect" flags: to terminate a pin that does not need any connection.

  • 階層シート, とその接続ピン

5.5.2. 接続 (ワイヤとラベル)

接続を確立する方法は2つあります:

  • ピン間のワイヤ

  • ラベル

以下の図はこれら2種類の接続方法を示します。

Wires labels

注 1:

ラベルが示す “接続” 点は、ラベル一文字目の左下になります。この点は、未接続時には小さな四角で表示されます。

この点は、ワイヤに接しているか、ピンの接続位置に重なっていなければなりません。

注 2:

接続を確立するためには、ワイヤの端を他のセグメントかピンへ接続します。

もし配線とピンが重なりあった場合(ピンの終端へ接続されずにワイヤがピンを乗り越えた場合)、これらは接続されません。

注 3:

交差したワイヤは暗黙的に未接続となります。もし接続する必要がある場合は、ワイヤの交差点にジャンクション(接続点)シンボルの配置が必要になります。

以前に示した図(ワイヤが DB25FEMALE 22, 21, 20, 19 ピンに接続されているもの)では,このジャンクション(接続点)シンボルを使った場合を示しています。

注 4:

1つのワイヤに2つの異なるラベルが配置されている場合、これらのラベルで示される両方の信号同士が接続されます。どちらか一方のラベルで接続されている全ての信号が互いに接続されます。

5.5.3. バス接続

以下に示す回路図では、多くのピンがバスへ接続されています。

Example schematic with buses

バスのメンバ

回路図を見易くするため、信号の集合体としてバスを利用し、接頭語+数値というフォーマットで名前が付けられます。上の図では、PCA0、PCA1、PCA2 は PCA バスのメンバとなります。

バスそのものを指す場合は、PCA[N..m] のように呼びます。この場合、N と m はバスの最初と最後のワイヤ番号になります。例えば、 PCA バスに 0 から 19 までの 20 本のメンバがある場合、バスの呼び名は PCA[0..19] となります。しかしながら、PCA0、PCA1、PCA2… 以外に WRITE、READ のような信号を含めて一つのバスにすることはできません。

バスのメンバ同士の接続

バスの同一メンバ間でピンを接続する場合は、ラベルによって接続しなければなりません。(バスは信号の集合体であるため)ピンはバスへ直接接続できません。Eeschema はこのような接続を無視します。

上に示したような例では、ピンに接続しているワイヤへ配置されたラベルによってピン間が接続されます。バスワイヤへのバスエントリ部( 45 度曲がっているワイヤ部分)は外観上の見易さを目的としているだけで、Eeschema で回路図としての意味はありません。(論理的な接続である必要はありません)

もしコンポーネントのピン番号が昇順で並んでいるのであれば(メモリやマイクロプロセッサなどで良く見かけます)、以下の手順のように繰り返しコマンド (インサート キー ) を用いることで非常に速く接続を行う事ができます。:

  • 最初のラベルを配置します(例えば PCA0 )

  • 繰り返しコマンドを使用してメンバのラベルを配置します。Eeschema は理論的に次のピン位置に相当する縦方向に整列した次のラベル( PCA1、PCA2、…)を自動的に生成します。

  • 最初のラベルの下にワイヤを配置します。同様に繰り返しコマンドを利用し、ラベルの下へワイヤを配置していきます。

  • 必要に応じて、同じ方法(最初のエントリを配置し,繰り返しコマンドを使用する)を用い、バスエントリを配置して下さい。

メインメニュー “設定” → “回路図エディタオプション” で、繰り返しに関するパラメータを設定することができます:

  • アイテムを垂直方向にリピート(縦方向の間隔)。

  • アイテムを水平方向にリピート(横方向の間隔)。

  • ラベルのカウントアップリピート( 2, 3,… のようなインクリメント(加算)/またはデクリメント(減算))

バスのシート間接続

階層構造になっている回路図において、シート間で異なる名前のバス同士を接続する必要がある場合があります。この接続の手順を以下に示します。

Bus junction example

バス PCA[0..15],ADR[0..7],BUS[5..10] は互いに接続されています。(接続点に注意してください。縦方向のバスが横方向のバスの中央で接続されています。)

More precisely, the corresponding members are connected together : PCA0, ADR0 are connected, (as same as PCA1 and ADR1 … PCA7 and ADR7).

さらに、PCA5 と BUS5 と ADR5 も接続されてます。( PCA6 と BUS6 と ADR6,PCA7 と BUS7 と ADR7 も同様です)

PCA8 と BUS8 も接続されることになります。( PCA9 と BUS9,PCA10 と BUS10 も同様です)

5.5.4. 電源ポートの接続

コンポーネントに電源ピンがある場合も、他の信号と同様に接続する必要があります。

ゲートやフリップフロップのようなコンポーネントは見えていない電源ピンを持っています。これらの扱いは少し厄介です。難点は以下の2つです:

  • 電源ピンが非表示であるため、ワイヤを接続できない。

  • 電源ピンの名前が解らない。

これら電源ピンの設定を可視に変更し接続することはあまり良い方法とは言えません。これをしてしまうと,回路図が読みにくくなってしまい、また普通の回路図の慣習に反することになってしまいます。

これらの非表示となっている電源ピンを表示させたい場合は、メインメニュー “設定” → “回路図エディタオプション” をたどるか、左ツールバー(オプションツールバー)の images/icons/hidden_pin.png アイコンをクリックして、“非表示ピンの表示” オプションをチェックします。

Eeschema は、同じ名前の全ての非表示の電源ピンを自動的に接続します。異なる名前の非表示電源ピン(例えば、 TTL デバイスの “GND” と MOS デバイスの “VSS” )を接続することが必要になることもあるでしょう。; このような場合に電源ポートシンボルを使います。

ラベルを利用して電源ピンを接続することは推奨されません。ラベルは “局所的 (local)” な接続機能しか無く、非表示の電源ピンは接続されません。

以下の図は、電源ポートの接続例です。

Power ports example

この例では、GND と VSS、VCC と VDD が接続されています。

2つの PWR_FLAG シンボルがあります。これは、2つの電源ポート VCC と GND が本当に電源(出力)へと接続されていることを示します。これら2つのフラグがない場合、ERCは Warning: power port not powered という診断結果を出力します。

これらすべてのシンボルは、コンポーネントとして “power” ライブラリに収められています。

5.5.5. "No Connect" flag

このシンボルは、ERC チェック時に不要な警告を出さないようにするために役立ちます。ERC で接続忘れの空きピンを確実に見つけることができます。

If pins must really remain unconnected, it is necessary to place a "No Connect" flag (tool No connection icon ) on these pins. These symbols do not have any influence on the generated netlists.

5.6. 回路図作成に関する補足

5.6.1. テキストコメント

It can be useful (to aid in understanding the schematic) to place annotations such as text fields and frames. Text fields (tool images/icons/add_text.png ) and Polyline (tool images/icons/add_dashed_line.png ) are intended for this use, contrary to labels and wires, which are connection elements.

図形コメントの例を以下に示します。

Frame with comment example

5.6.2. シートの表題欄(タイトルブロック)

表題欄は、 Page Settings tool “ページの設定” ツールで編集することができます。

Page settings dialog

Title block

シート数Y、シート番号X(Sheet X/Y)は自動更新されます。

5.7. キャッシュされたコンポーネントのレスキュー

デフォルトでは、Eeschema は設定されたパスに従ってライブラリからコンポーネントを読み込みます。これは古いプロジェクトを読み込む時に問題を引き起こします。: ライブラリにあるコンポーネントがプロジェクトで使われた時より後に変更されていた場合、プロジェクトのコンポーネントは自動的に新しいバージョンへと置き換えられます。新しいバージョンが互換性を失っていたり、違う方向を向いているようなことがあると、回路図の破損につながります。

しかしながら、プロジェクトの保存時にはキャッシュされたライブラリも一緒に保存されます。これにより、プロジェクトは全てのライブラリがなくても配布できます。キャッシュとシステムライブラリの両方に存在するコンポーネントを使ったプロジェクトを読み込むと、Eeschema は衝突検出のためにライブラリを調べるでしょう。発見された衝突は次のダイアログに一覧表示されます。:

Rescue conflicts dialog

この例では、元々のプロジェクトはカソードが上向きのダイオードを使っていますが、現在のライブラリはカソードが下向きのものを含んでいます。この変更はプロジェクトを台無しにします!ここで OK ボタンを押すと、古いコンポーネントのシンボルは特別な “レスキュー” ライブラリへと保存され、このシンボルを使う全てのコンポーネントは名前の衝突を避けるために変更 (rename) されます。

もし Cancel ボタンが押されると、レスキューは作成されず、Eeschema はデフォルトで全て新しいコンポーネントを読み込むでしょう。変更されなかった場合でも、前に戻ってレスキュー機能を再度実行できます。: ツールメニューから “キャッシュされたコンポーネントのレスキュー” を選んで、ダイアログを再び呼び出します。

このダイアログを表示させたくない場合は、“次回から表示しない” ボタンを押してください。デフォルトで何もせずに新しいコンポーネントを読み込むようになります。このオプションは、コンポーネントライブラリの設定で元に戻せます。(“回路図の読込み時にキャッシュ/ライブラリの衝突をチェック” ボックスをチェックする)

6. 階層回路図

6.1. はじめに

シート数が2~3枚で済まないようなプロジェクトでは、階層的表現を用いるのが一般的によい解決策となります。この種のプロジェクトを管理したい場合、次のことが必要になるでしょう:

  • 大きなサイズのシートを使用する。その場合、印刷と取り扱いの問題が生じます。

  • シートを数枚使用する。これは階層構造に至ります。

完全な回路図は、ルートシートと呼ばれるメインの回路図シートおよび階層を構成するサブシートから構成されます。さらに、設計を個別のシートにうまく分割すると可読性が改善されます。

From the root sheet, you must be able to find all sub-sheets. Hierarchical schematics management is very easy with Eeschema, thanks to an integrated "hierarchy navigator" accessible via the icon icons/hierarchy_nav_png of the top toolbar.

階層には2種類が同時に存在し得ます:1つ目は、すでに開いて使用しているような一般的に使用されているものです。2つ目は、回路図で使われるコンポーネントの実体を表すもので、実際にはコンポーネントの内部構造を記述した回路図に対応します。

この2つ目のタイプはよく集積回路 (IC) の開発で使用されます。この場合には作成中の回路図で機能ライブラリを使用しなければならないからです。

Eeschema は現在、この第2のケースに対応していません。

階層は次のようなものです:

  • 単一: 任意のシートを一度だけ使用する。

  • 複合: 任意のシートを2回以上使用する(複数のインスタンス)。

  • 平面 (Flat) : 単一の階層であるが、シート間の接続は記述されない。

Eeschema はこれらの階層を全て扱うことが可能です。

階層回路図の作成は簡単です。階層全体はルート回路図から始まるように管理され、ただ一つの回路図しかないように見えます。

次の2つの重要なステップを理解する必要があります:

  • サブシートの作成方法。

  • サブシート間の電気的な接続方法。

Navigation among sub-sheets It is very easy thanks to the navigator tool accessible via the button icons/hierarchy_nav_png on the top toolbar.

100000000000010C00000104307CA6BA_png

Each sheet is reachable by clicking on its name. For quick access, right click on a sheet name, and choose to Enter Sheet.

You can quickly reach the root sheet, or a sub-sheet thanks to the tool icons/hierarchy_cursor_png of the right toolbar. After the navigation tool has been selected:

  • Click on a sheet name to select the sheet.

  • Click elsewhere to select the Root sheet.

6.3. ローカルラベル、階層ラベル、グローバルラベル

6.3.1. プロパティ

ローカルラベル( icons/add_line_label_png ツール)は、あるシート内のみで接続される信号です。階層ラベル( icons/add_hierarchical_label_png ツール)は、あるシート内のみで接続される信号であると同時に親シートに配置された階層ピンに接続されています。

グローバルラベル( Global label icon ツール)は階層全体に渡って信号を接続しています。非表示の電源ピン( power in および power out タイプ)も全階層に渡って互いに接続されているので、グローバルラベルに似ています。

(単一または複合)階層内では、階層ラベルとグローバルラベルのどちらか、または両方を使用可能です。

6.4. 階層のヘッドライン(見出し)作成

次のことをする必要があります:

  • Place in the root sheet a hierarchy symbol called "sheet symbol".

  • ナビゲーターを使用して新規回路図(サブシート)に入り、他の回路図と同様に作成します。

  • 新しく作成した回路図(サブシート)にグローバルラベル (HLabels) を配置して2つの回路図間に電気的接続を作成します。また、シートラベル (SheetLabels) という同じ名前を持つラベルをルートシートに配置します。これらのシートラベルはルートシートのシートシンボルや標準的なコンポーネントピンのような他の回路図要素に接続されます。

6.5. シートシンボル

対角上の2点を指定して作成した矩形でサブシートを表します。

この矩形のサイズは、サブシート内のグローバルラベル (HLabels) に対応した特定のラベルや階層ピンを後で配置可能なものでなければなりません。これらのラベルは通常のコンポーネントピンに似ています。

icons/add_hierarchical_subsheet_png “階層シートの作成” ツールを選択します。

左クリックして矩形の左上角を配置します。矩形が十分な大きさとなったら再度左クリックして右下角を配置します。

この時、(階層ナビゲーターを使用し、対応する回路図に移動するために)このサブシートのファイル名とシート名の入力が要求されます。

20000008000024130000119315BBAF66_png

少なくともファイル名の入力が必要です。シート名がない場合、ファイル名がシート名として使用されます(この方法はよく行われています)。

6.6. Connections - hierarchical pins

作成したシンボル用の接続点(階層ピン)をここで作成します。

これらの接続点は通常のコンポーネントピンと似ていますが、1つの接続点だけで複数の信号からなるバスを接続できます。

次のような2つ方法があります:

  • 必要なピンをサブシート作成前に配置(手動による配置)。

  • 必要なピンおよびグローバルラベルをサブシート作成後に配置(半自動配置)。

特に好ましいのは2つ目の方法です。

手動配置:

  • icons/add_hierar_pin_png ツールを選択します。

  • ピンを配置したい階層シンボルをクリックします。

See below an example of the creation of the hierarchical pin called "CONNEXION".

1000000000000160000000CD797712D0_png

階層ラベルのプロパティ(右クリックしてコンテキストメニューの “階層ラベルの編集” を選択)を編集して,グラフィカルな属性とサイズを定義できます。後で行うことも可能です。

様々なピンシンボルが使用可能です:

  • 入力(Input)

  • 出力(Output)

  • Bidirectional

  • Tri-State

  • Passive

これらのピンシンボルは単なるグラフィカルな強調で、それ以外の役割はありません。

自動配置 :

  • icons/import_hierarchical_label_png “シート内の対応する階層ラベルからインポートされた階層ピンを入力” ツールを選択します。

  • 階層シンボルをクリックして、そこからグローバルラベルに対応するピンをインポートして対応する回路図に配置します。新しいグローバルラベルが存在する場合、つまり配置済みのピンに対応したものでないなら、階層ピンが現れます。

  • このピンを配置したい場所でクリックします。

必要なすべてのピンはエラーなく速やかに配置することが可能です。それらの向きや方向は対応するグローバルラベルと一致しています。

6.7. 接続 - 階層ラベル

作成したシートシンボルの各ピンはサブシート内の階層ラベルと一致していなければなりません。階層ラベルはラベルと似ていますが、サブシートおよびルートシート間の接続を行います。2つの相補的なラベル(ピンと HLabel )のグラフィカルな表示は似ています。階層ラベルの作成は、 icons/add_hierarchical_label_png “階層のラベル入力” ツールで行います。

以下はルートシートの例です。

20000008000041D700001D9077DCC816_png

ピン TRANSF1 と TRANSF2 がコネクタ JP3 に接続されていることに注意して下さい。

サブシート内での対応する接続は次のようになります :

20000008000041D700001D9077DCC816_png

2つの階層シート間を接続する2つの対応する階層ラベルがあるのがさらにわかります。

既述の構文 (Bus [N. .m]) に従って、2つのバスを接続する階層ラベルおよび階層ピンを使うことが可能です。

6.7.1. (単純な)ラベル、階層ラベル、グローバルラベル、非表示電源ピン

ワイヤによる接続以外に、接続を行う様々な方法について説明します。

(単純な)ラベル

単純なラベルはローカルな接続に使います。つまり、接続は配置されている回路図シートだけ制限されます。これは次の理由によります :

  • 各シートにはシート番号が存在する。

  • このシート番号はラベルに関連付けられる。

Thus, if you place the label "TOTO" in sheet n° 3, in fact the true label is "TOTO_3". If you also place a label "TOTO" in sheet n° 1 (root sheet) you place in fact a label called "TOTO_1", different from "TOTO_3". This is always true, even if there is only one sheet.

階層ラベル

単純なラベルで言えることは、階層ラベルにも当てはまります。

Thus in the same sheet, a HLabel "TOTO" is considered to be connected to a local label "TOTO", but not connected to a HLabel or label called "TOTO" in another sheet.

しかし、HLabel はルートシートに配置された階層シンボル内の対応するシートラベル・シンボルに接続されていると見なされます。

非表示電源ピン

It was seen that invisible power pins were connected together if they have the same name. Thus all the power pins declared "Invisible Power Pins" and named VCC are connected and form the equipotential VCC, whatever the sheet they are placed on.

このことは,あるサブシートに VCC ラベルを配置した場合、そのラベルが VCC ピンには接続されないということを意味します。それは、このラベルが実際には VCC_n であるからです。ここで n とはシート番号です。

この VCC ラベルを同電位 VCC に実際に接続したいなら、VCC 電源ポートによって明示的に非表示電源ピンへ接続する必要があります。

6.7.2. グローバルラベル

同一名のグローバルラベルは、全ての階層に渡って互いに接続されています。

(vcc … のような電源ラベルはグローバルラベルです)

6.8. 複合階層

一例を示します。同じ回路図が2回使用されています(2つのインスタンス)。2つのシートのファイル名が同じなので (“other_sheet.sch”) 、2つのシートは同じ回路図を共有します。しかし、シート名は異なっていなければなりません。

10000000000001C6000001CAAC972C0B_png

6.9. 平面階層

シート間の接続を作らずに(平面階層 (flat hierarchy) )、シートを多数使うプロジェクトの作成が可能です。それには次のルールを順守して下さい:

  • ルートシートを作成し、他のすべてのシートをそれに含めます。ルートシートはシート間のリンクとして機能します。

  • 明示的な接続はまったく必要ありません。

  • シート間のすべての接続には、階層ラベルではなくグローバルラベルを使用します。

ルートシートの例を以下に示します。

10000000000002C800000134F8E86C51_png

2ページあり、それらはグローバルラベルで接続されています。

100000000000020B000001B70A60DECC_png

1000000000000272000001C015CA854E_png

Look at global labels.

100000000000009B00000079AC689E05_png

7. 自動アノテーション

7.1. はじめに

“回路図のアノテーション” ツールを用いることで、回路図中のコンポーネントに自動的にリファレンス(参照番号)を割り当てることができます。複数ユニットを持つコンポーネントについては,使用パッケージ数が最小となるように部品番号を割り当てます。アノテーションツールは、アイコン icons_annotate_png をクリックすることで利用できます。以下に “回路図のアノテーション” のメインウィンドウを示します。

annotate-dialog_img

次のように、さまざまな利用方法があります。:

  • 全てのコンポーネントをアノテート (「既存のアノテーションをリセット(R)」を選択)

  • 既存の複数ユニットを持つコンポーネント内の順番を入れ替えないで、全てのコンポーネントをアノテート。(「既存のアノテーションをリセット、ただし複数ユニットを持つ部品はキープ(E)」を選択)。

  • 新しく追加したコンポーネントのみをアノテート(「既存のアノテーションをキープ(K)」を選択)。

  • 全階層をアノテート (「全ての回路図,階層を使用(E)」を選択)。

  • 現在のシートのみをアノテート (「現在のページのみ使用(P)」を選択)。

'既存のアノテーションをリセット、ただし複数ユニットを持つ部品はキープ'オプションは、複数ユニットを持つコンポーネント内の全ての関連性を保存します。これは、もし U2A と U2B があったなら、それぞれ U1A と U1B へと番号が振られることはあっても、 U1A と U2A、または U2B と U2A とはならないということです。これは、ピングループを確実に維持したい時、配置するのに都合がいいように定義した子部品がある時、に役立ちます。

「アノテーションの順番」オプションでは、それぞれのシート内での番号の振り方を指定することができます。

特別な場合を除いて、以前のアノテーション結果を変更しない場合は、プロジェクト全体(全てのシート)と新しいコンポーネントが自動アノテーションの対象となります。

「アノテーションの選択」オプションでは、リファレンス(参照番号)の計算方法を指定します。:

  • 回路図中の最初の空き番号から使用する:コンポーネントは(各部品記号につき)1からリファレンスが振られます。前回のアノテーションをキープする場合は、使われていない番号から利用されます。

  • シートの Ref 番号を *100 から開始し、最初の空き番号から使用する:シート1では 101 から,シート2では 201 からリファレンスが振られます。それぞれ の部品記号(UやR)が1シート内で 99 を超えてしまった場合は継続して以降の番号が振られ、例えばシート2では 200 番台の最初の空き番号から リファレンスが振られます。

  • シートの Ref 番号を *1000 から開始し、最初の空き番号から使用する:シート1では 1001 からリファレンスが振られ、シート2では 2001 からリファレンスが振られていきます。

7.2. 例

7.2.1. アノテーションの順序

2000000800003E6E0000154B2A71537E_png

部品配置後、未だリファレンスが振られていない5つの素子を例とします。

アノテーションを実行すると、以下のような結果が得られます。

100000000000022C000000B9BA2E1A94_png

コンポーネントをX位置でソートした場合:

100000000000023D000000BC05569580_png

コンポーネントをY位置でソートした場合。

アノテーションにより、74LS00 の4つのゲートが U1 パッケージにまとめられ、5番目のゲートは次の U2 へと分類されました。

7.2.2. アノテーションの選択

下記の図は、部品をシート2に配置し、「回路図中の最初の空き番号から使用する」オプションを利用してアノテーションを行ったものです。

100000000000014300000137E6B02665_png

「シートの Ref 番号を*100 から開始し、最初の空き番号から使用する」オプションを利用しアノテーションを行うと、下図のようになります。

1000000000000138000001495A2E0270_png

「シートのRef番号を*1000 から開始し、最初の空き番号から使用する」オプションを利用した場合は、下図のようになります。

1000000000000117000001359D8B03B1_png

8. Design verification with Electrical Rules Check

8.1. はじめに

The Electrical Rules Check (ERC) tool performs an automatic check of your schematic. The ERC checks for any errors in your sheet, such as unconnected pins, unconnected hierarchical symbols, shorted outputs, etc. Naturally, an automatic check is not infallible, and the software that makes it possible to detect all design errors is not yet 100% complete. Such a check is very useful, because it allows you to detect many oversights and small errors.

In fact all detected errors must be checked and then corrected before proceeding as normal. The quality of the ERC is directly related to the care taken in declaring electrical pin properties during library creation. ERC output is reported as "errors" or "warnings".

ERC dialog

8.2. ERC の使用法

アイコン ERC icon をクリックすると ERC を開始します。

Warnings are placed on the schematic elements raising an ERC error (pins or labels).

  • In this dialog window, when clicking on an error message you can jump to the corresponding marker in the schematic.

  • In the schematic right-click on a marker to access the corresponding diagnostic message.

また、ダイアログからエラーのマーカーを削除できます。(一括で全て削除されます)

8.3. ERC の例

ERC pointers

エラーが4つ見られます:

  • 2本の出力が誤接続されています(赤の矢印)。

  • 入力が2本未接続のままです(緑の矢印)。

  • 非表示電源ポートのエラーで,電源フラグがありません(上部に緑の矢印)。

8.4. 診断結果の表示

By right-clicking on a marker the pop-up menu allows you to access the ERC marker diagnostic window.

ERC pointers info

ここで、 “マーカーエラー情報” をクリックするとエラーの内容が “マーカーの情報” ウィンドウに表示されます。

1000000000000250000000D72B1E53C2_png

8.5. 電源ピンと電源フラグ

It is common to have an error or a warning on power pins, even though all seems normal. See example above. This happens because, in most designs, the power is provided by connectors that are not power sources (like regulator output, which is declared as Power out).

このためERCは、電源出力ピンを検出してこの配線を操作するということはせず、電源で駆動されていないものと判断します。

To avoid this warning you have to place a "PWR_FLAG" on such a power port. Take a look at the following example:

20000008000030E4000026DDFDF3D5E2_png

このようにすると、エラーマーカーが消えます。

大抵の場合、PWR_FLAG は GND に接続されていなければなりません。それは普通、レギュレータは電源出力として宣言された出力を持ちますが、グラウ ンドピンは電源出力ではなく(通常の属性は電源入力)、その結果、グラウンドは PWR_FLAG がなければ電源に接続されたことにはならないからです。

8.6. ルールの設定

オプション パネルで接続ルールを設定し、エラーおよび警告チェックのための電気的条件を定義します。

10000000000002810000024A2E8220E0_png

Rules can be changed by clicking on the desired square of the matrix, causing it to cycle through the choices: normal, warning, error.

8.7. ERC レポートファイル

オプションの ERC レポートの作成にチェックを付けると、ERC レポートファイルの生成と保存が可能です。ERC レポートのファイル拡張子は、.erc です。ERC レポートファイルの例を示します。

ERC control (4/1/1997-14:16:4)

***** Sheet 1 (INTERFACE UNIVERSAL)
ERC: Warning Pin input Unconnected @ 8.450, 2.350
ERC: Warning passive Pin Unconnected @ 8.450, 1.950
ERC: Warning: BiDir Pin connected to power Pin (Net 6) @ 10.100, 3.300
ERC: Warning: Power Pin connected to BiDir Pin (Net 6) @ 4.950, 1.400

>> Errors ERC: 4

9. ネットリストの作成

9.1. 概要

ネットリストはコンポーネント間の電気的接続を記述したファイルです。ネットリストのファイルには,次のものが含まれます:

  • コンポーネントのリスト。

  • The list of connections between components, called equi-potential nets.

いろいろな異なるネットリストのフォーマットが存在します。コンポーネントのリストと等電位リストが2つの別々のファイルであることもあります。回路図入力 (capture) ソフトウェアにとって、このネットリストはなくてはならないものです。それはネットリストが、次のような他の電子系 CAD ソフトウェアとのリンクとなるからです。:

  • PCB ソフトウェア。(基板設計ソフト)

  • 回路および PCB シミュレータ。

  • CPLD (および他のプログラマブル IC の)コンパイラ。

Eeschema はいくつかのネットリストのフォーマットをサポートしています。

  • Pcbnew フォーマット(プリント配線)。

  • OrCAD PCB2 フォーマット(プリント配線)。

  • CADSTAR フォーマット(プリント配線)。

  • 様々なシミュレータ用 Spice フォーマット( Spice フォーマットは他のシミュレータにも使用されます)。

9.2. ネットリストフォーマット

Netlist icon ツールを選択し、ネットリスト作成ダイアログボックスを開きます。

100000000000015B00000103C7B601A8_png

Pcbnew を選択

100000000000015C0000010342AD04EC_png

Spice を選択

それぞれのタブで希望するフォーマットを選択できます。Spice フォーマットでは、等電位の名称(その方が読みやすい)か、またはネット番号( Spice の古いバージョンは番号のみ受け付ける)のどちらかでネットリストを生成することが可能です。ネットリストボタンをクリックすると、ネットリストファイルの名前を入力するよう促されます。

大きなプロジェクトでは、ネットリストの生成に数分かかることがあります。

9.3. ネットリストの例

You can see below a schematic design using the PSPICE library:

10000000000002BE0000017EB6C97C72_png

Example of a PCBNEW netlist file:

# Eeschema Netlist Version 1.0 generee le 21/1/1997-16:51:15
(
(32E35B76 $noname C2 1NF {Lib=C}
(1 0)
(2 VOUT_1)
)
(32CFC454 $noname V2 AC_0.1 {Lib=VSOURCE}
(1 N-000003)
(2 0)
)
(32CFC413 $noname C1 1UF {Lib=C}
(1 INPUT_1)
(2 N-000003)
)
(32CFC337 $noname V1 DC_12V {Lib=VSOURCE}
(1 +12V)
(2 0)
)
(32CFC293 $noname R2 10K {Lib=R}
(1 INPUT_1)
(2 0)
)
(32CFC288 $noname R6 22K {Lib=R}
(1 +12V)
(2 INPUT_1)
)
(32CFC27F $noname R5 22K {Lib=R}
(1 +12V)
(2 N-000008)
)
(32CFC277 $noname R1 10K {Lib=R}
(1 N-000008)
(2 0)
)
(32CFC25A $noname R7 470 {Lib=R}
(1 EMET_1)
(2 0)
)
(32CFC254 $noname R4 1K {Lib=R}
(1 +12V)
(2 VOUT_1)
)
(32CFC24C $noname R3 1K {Lib=R}
(1 +12V)
(2 N-000006)
)
(32CFC230 $noname Q2 Q2N2222 {Lib=NPN}
(1 VOUT_1)
(2 N-000008)
(3 EMET_1)
)
(32CFC227 $noname Q1 Q2N2222 {Lib=NPN}
(1 N-000006)
(2 INPUT_1)
(3 EMET_1)
)
)
# End

In PSPICE format, the netlist is as follows:

* Eeschema Netlist Version 1.1 (Spice format) creation date: 18/6/2008-08:38:03

.model Q2N2222 npn (bf=200)
.AC 10 1Meg \*1.2
.DC V1 10 12 0.5


R12   /VOUT N-000003 22K
R11   +12V N-000003 100
L1   N-000003 /VOUT 100mH
R10   N-000005 N-000004 220
C3   N-000005 0 10uF
C2   N-000009 0 1nF
R8   N-000004 0 2.2K
Q3   /VOUT N-000009 N-000004 N-000004 Q2N2222
V2   N-000008 0 AC 0.1
C1   /VIN N-000008 1UF
V1   +12V 0 DC 12V
R2   /VIN 0 10K
R6   +12V /VIN 22K
R5   +12V N-000012 22K
R1   N-000012 0 10K
R7   N-000007 0 470
R4   +12V N-000009 1K
R3   +12V N-000010 1K
Q2   N-000009 N-000012 N-000007 N-000007 Q2N2222
Q1   N-000010 /VIN N-000007 N-000007 Q2N2222

.print ac v(vout)
.plot ac v(nodes) (-1,5)

.end

9.4. ネットリストについての注釈

9.4.1. ネットリスト名の注意事項

Many software tools that use netlists do not accept spaces in the component names, pins, equi-potential nets or others. Systematically avoid spaces in labels, or names and value fields of components or their pins.

In the same way, special characters other than letters and numbers can cause problems. Note that this limitation is not related to Eeschema, but to the netlist formats that can then become untranslatable to software that uses netlist files.

9.4.2. PSPICE ネットリスト

Pspice シミュレーターの場合、ネットリストの中にコマンド行 (.PROBE, .AC など ) をいくつか含める必要があります。

回路図に含まれる -pspice または -gnucap のキーワードで始まるテキスト行は、ネットリストの先頭に(キーワードがない状態で)挿入されます。

回路図に含まれる +pspice または +gnucap のキーワードで始まるテキスト行は、ネットリストの最後に(キーワードがない状態で)挿入されます。

Here is a sample using many one-line texts and one multi-line text:

100000000000021B000001BDEA9ADDBA_png

For example, if you type the following text (do not use a label!):

-PSPICE .PROBE
PROBE の行はネットリストに挿入されます。

前述の例ではこの方法でネットリストの先頭に3行、末尾に2行挿入されました。

複数行テキストを使用している場合、 +pspice または +gnucap のキーワードは1度だけ必要です:

+PSPICE .model NPN NPN
.model PNP PNP
.lib C:\Program Files\LTC\LTspiceIV\lib\cmp\standard.bjt
.backanno

4行生成されます:

.model NPN NPN
.model PNP PNP
.lib C:\Program Files\LTC\LTspiceIV\lib\cmp\standard.bjt
.backanno

また Pspice の場合、等電位の GND は0(ゼロ)という名前にしなければならないことに注意して下さい。

9.5. 他のフォーマット

他のネットリスト・フォーマットの場合には、プラグインの形でネットリストコンバーターを追加することが可能です。Eeschema はそれらのコンバーターを自動的に起動します。コンバーターの解説と例は14章にあります。

コンバーターはテキストファイル(xsl フォーマット)ですが,Python のような他の言語を使用することもできます。xsl フォーマットを使用する場合、ツール( xsltproc.exe あるいは xsltproc )は Eeschema が生成した中間ファイルとコンバーターファイルを読み込んで、出力ファイルを生成します。この場合、コンバーターファイル(シートスタイル)は非常に小さく記述が容易です。

9.5.1. ダイアログウィンドウの初期設定

You can add a new netlist plug-in via the Add Plugin button.

10000000000000DA000000C6E73B58D7_png

Here is the plug-in PadsPcb setup window:

100000000000021300000103755CDB21_png

セットアップには以下が必要です:

  • A title (for example, the name of the netlist format).

  • 起動するプラグイン。

ネットリスト生成時に、以下のことが行われます:

  1. Eeschema creates an intermediate file *.tmp, for example test.tmp.

  2. Eeschema はプラグインを実行し、test.tmp を読み込んで test.net を生成します。

9.5.2. コマンドライン・フォーマット

Here is an example, using xsltproc.exe as a tool to convert .xsl files, and a file netlist_form_pads-pcb.xsl as converter sheet style:

f:/kicad/bin/xsltproc.exe -o %O.net f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl %I

各部の意味は次の通りです:

f:/kicad/bin/xsltproc.exe

xsl ファイルを読み込み、変換するツール

-o %O.net

出力ファイル: %O で出力ファイルを定義

f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl

ファイル名コンバーター( シートスタイル,xsl フォーマット)

%I

Eeschema が生成した中間ファイル (*.tmp) で 置き換える

test.sch という名前の回路図の場合,実際のコマンドラインは次の通りです:

f:/kicad/bin/xsltproc.exe -o test.net f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl test.tmp.

9.5.3. Converter and sheet style (plug-in)

This is a very simple piece of software, because its purpose is only to convert an input text file (the intermediate text file) to another text file. Moreover, from the intermediate text file, you can create a BOM list.

When using xsltproc as the converter tool only the sheet style will be generated.

9.5.4. 中間ネットリスト・ファイル・フォーマット

See Chapter 14 for more explanations about xslproc, descriptions of the intermediate file format, and some examples of sheet style for converters.

10. プロットと印刷

10.1. はじめに

上部メニューバーの “ファイル” から “印刷 (N)” と “出図 (P)”(プロット)の両コマンドが実行可能です。

100000000000017E000001109CDAC612_png

The suported output formats are Postscript, PDF, SVG, DXF and HPGL. You can also directly print to your printer.

10.2. 出図(プロット)の共通コマンド

Plot Current Page

現在のシートのみプロットします。

Plot All Pages

allows you to plot the whole hierarchy (one print file is generated for each sheet).

10.3. Postscript のプロット

This command allows you to create PostScript files.

100000000000017A000001555B390DD5_png

The file name is the sheet name with an extension .ps. You can disable the option "Plot border and title block". This is useful if you want to create a postscript file for encapsulation (format .eps) often used to insert a diagram in a word processing software. The message window displays the file names created.

10.4. Plot in PDF

eeschema_plot_pdf.png

Allows you to create plot files using the format PDF. The file name is the sheet name with an extension .pdf.

10.5. SVG のプロット

10000000000001D8000001A61AC74D2A_png

Allows you to create plot files using the vectored format SVG. The file name is the sheet name with an extension .svg.

10.6. DXF のプロット

10000000000000FB00000191F3D6461D_png

Allows you to create plot files using the format DXF. The file name is the sheet name with an extension .dxf.

10.7. HPGL のプロット

This command allows you to create an HPGL file. In this format you can define:

  • Page size.

  • Origin.

  • Pen width (in mm).

The plotter setup dialog window looks like the following:

1000000000000196000001CC52FEA30B_png

出力ファイル名はシート名に拡張子 .plt を付加したものです。

10.7.1. シートサイズ選択

通常は “回路図の大きさ” が選択されています。この場合、ページ設定で定義されているサイズが使用され、その時のスケールは1になります。異なるサイズ( A4 ~ A0 あるいは A ~ E )を選択すると、スケールが自動的に調整されてページにフィットします。

10.7.2. オフセット調整

For all standard dimensions, you can adjust the offsets to center the drawing as accurately as possible. Because plotters have an origin point at the center or at the lower left corner of the sheet, it is necessary to be able to introduce an offset in order to plot properly.

Generally speaking:

  • シートの中央を原点とするプロッターの場合、オフセットは負の値で、シート寸法の 1/2 に設定しなければなりません。

  • For plotters having their origin point at the lower left corner of the sheet the offset must be set to 0.

To set an offset:

  • シートサイズを選択。

  • 原点を選択。

  • ( “左下の角” または “ページ中央” を選択)

上部メニューバーから “ファイル” → “印刷 (N)” を選ぶか、上部ツールバーのアイコン icons/print_button_png により、印刷プレビューや普通のプリンターでの印刷ができます。

100000000000015A000000C1CF6CC2C5_png

The "Print sheet reference and title block" option enables or disables sheet references and title block.

The "Print in black and white" option sets printing in monochrome. This option is generally necessary if you use a black and white laser printer, because colors are printed into half-tones that are often not so readable.

11. コンポーネント・ライブラリ・エディタ

11.1. コンポーネント・ライブラリに関する一般情報

コンポーネントは、図形表現、電気的接続、フィールド定義を含んだ図面要素です。回路図で使用するコンポーネントはすべてコンポーネントライブラリに保存されています。Eeschema は、ライブラリの作成、ライブラリへのコンポーネントの追加/削除、ライブラリ間でのコンポーネントの移動、ファイルへのコンポーネントのエクスポート、ファイルからのコンポーネントのインポートを行うためのコンポーネントライブラリ編集ツールを提供します。コンポーネント・ライブラリ・エディタはコンポーネント・ライブラリ・ファイルを管理するシンプルな方法を提供します。

11.2. コンポーネント・ライブラリの概要

コンポーネントライブラリは一つ以上のコンポーネントから構成されます。一般的に、コンポーネントは機能、種類、または製造者によってグループ分けされます。

コンポーネントは以下のものから構成されます。:

  • グラフィカルな型式 (design) (ライン、円、テキストフィールド)。

  • Pins which have both graphic properties (line, clock, inverted, low level active, etc ) and electrical properties (input, output, bidirectional, etc.) used by the Electrical Rules Check (ERC) tool.

  • リファレンス、値、PCB 設計用のフットプリント名などのようなテキストフィールド。

  • Aliases used to associate a common component such as a 7400 with all of its derivatives such as 74LS00, 74HC00, and 7437. All of these aliases share the same library component.

適切なコンポーネント設計には以下のことが要求されます。:

  • コンポーネントは一つ以上のパーツで構成されるように定義する。

  • コンポーネントがド・モルガン表現として知られる代替ボディスタイルを持つように定義する。

  • ライン、矩形、円、ポリゴンおよびテキストを使用して回路図シンボル(記号)を設計する。

  • グラフィック要素、名前、ピン数、電気的プロパティ(入力、出力、3ステート、電源ポートなど)を慎重に定義して、ピンを追加する。

  • Adding an alias if other components have the same symbol and pin out or removing one if the component has been created from another component.

  • Adding optional fields such as the name of the footprint used by the PCB design software and/or defining their visibility.

  • データシートへの www リンクや説明文などを付加してコンポーネントに記録する。

  • 適切な (desired) ライブラリにそれを保存する。

11.3. コンポーネント・ライブラリ・エディタの概要

コンポーネント・ライブラリ・エディタのメインウィンドウを以下に示します。よく使う機能を手早く使えるようにするための3つのツールバーとコンポーネントの閲覧/編集エリアで構成されます。ツールバーからは全てのコマンドを使うことができませんが、メニューからは使用できます。

100000000000049F000002C20FF41347_png

11.3.1. メイン・ツールバー

基本的にメインウィンドウの最上部にあるメインツールバー(以下に示します)は、ライブラリ管理ツール、取り消し/やり直しコマンド、ズームコマンドとコンポーネントプロパティから成ります。

images/ja/toolbar_libedit.png

icons/save_library_png

現在のライブラリをハードディスクに保存する。(ライブラリが 選択されていないか、選択中のライブラリに変更がない場合、 このボタンは無効です)

icons/library_png

現在のライブラリを選択する。

icons/delete_png

現在のライブラリ(ライブラリが選択されていない場合にはプロジェクトで 定義されたライブラリ)内のコンポーネントを削除する。

icons/library_browse_png

(ライブラリと編集するコンポーネントを選択するための) コンポーネントライブラリブラウザを開く。

icons/new_component_png

新規コンポーネントを作成する。

icons/import_cmp_from_lib_png

現在のライブラリから編集用にコンポーネントを読み込む。

icons/copycomponent_png

読み込んだ現在のコンポーネントから新規コンポーネントを作成する。

icons/save_part_in_mem_png

現在のコンポーネントに対する変更をメモリにのみ保存する。 (ハードディスク上のライブラリファイルは変更されません)

icons/import_png

コンポーネントを1つインポートする。

icons/export_png

現在のコンポーネントをエクスポートする。

icons/new_library_png

現在のコンポーネントを使用して新規ライブラリファイルを作成する。(注: 新しい ライブラリは自動的にプロジェクトへ追加されません)

icons/undo_png

最後の変更を元に戻す。

icons/redo_png

最後の変更をやり直す。

icons/part_properties_png

コンポーネントのプロパティを編集する。

icons/add_text_png

コンポーネントのフィールドを編集する。

icons/erc_png

コンポーネントの設計エラーをテストする。

images/icons/zoom_in.png

ズームイン。

images/icons/zoom_out.png

ズームアウト。

images/icons/zoom_redraw.png

画面の再描画。

images/icons/zoom_fit_in_page.png

コンポーネントの大きさを画面に合わせる。

icons/morgan1_png

通常のボディスタイルを表示する。(コンポーネントが代替ボディスタイルを 持っていない場合、このボタンは無効です)

icons/morgan2_png

別のボディスタイルを表示する。(コンポーネントが代替ボディスタイルを 持っていない場合、このボタンは無効です)

icons/datasheet_png

関連ドキュメントを表示する。(関連ドキュメントが定義されていない場合、 このボタンは無効です)

images/toolbar_libedit_part.png

Select the unit to display. The drop down control will be disabled if the current component is not derived from multiple units.

images/ja/toolbar_libedit_part.png

エイリアスを選択する。(エイリアスを持っていない場合、 ドロップダウンは無効です)

icons/pin2pin_png

ピンを編集する:多パーツコンポーネントおよび代替シンボルを持つ場合、 ピンの形状と位置は個別に編集

icons/pin_table_png

ピンテーブルを表示する。

11.3.2. エレメント・ツールバー

The vertical toolbar typically located on the right hand side of the main window allows you to place all of the elements required to design a component. The table below defines each toolbar button.

icons/cursor_png

Select tool. Right-clicking with the select tool opens the context menu for the object under the cursor. Left-clicking with the select tool displays the attributes of the object under the cursor in the message panel at the bottom of the main window. Double-left-clicking with the select tool will open the properties dialog for the object under the cursor.

icons/pin_png

Pin tool. Left-click to add a new pin.

icons/add_text_png

Graphical text tool. Left-click to add a new graphical text item.

icons/add_rectangle_png

Rectangle tool. Left-click to begin drawing the first corner of a graphical rectangle. Left-click again to place the opposite corner of the rectangle.

icons/add_circle_png

Circle tool. Left-click to begin drawing a new graphical circle from the center. Left-click again to define the radius of the cicle.

icons/add_arc_png

Arc tool. Left-click to begin drawing a new graphical arc item from the center. Left-click again to define the first arc end point. Left-click again to defint the second arc end point.

icons/add_polygon_png

Polygon tool. Left-click to begin drawing a new graphical polygon item in the current component. Left-click for each addition polygon line. Double-left-click to complete the polygon.

icons/anchor_png

Anchor tool. Left-click to set the anchor position of the component.

icons/import_png

ファイルからコンポーネントをインポートする。

icons/export_png

現在のコンポーネントをエクスポートする。

icons/delete_png

Delete tool. Left-click to delete an object from the current component.

11.3.3. オプション・ツールバー

基本的にメインウィンドウの左側に位置する縦のツールバーで、エディタの描画オプションのいくつかを設定できます。ツールバーの各ボタンの定義は下表のとおりです。

icons/grid_png

グリッド表示の切替。(グリッドの表示/非表示が交互に切り替わります)

icons/unit_inch_png

単位をインチに設定。

icons/unit_mm_png

単位を mm に設定。

icons/cursor_shape_png

フルスクリーンカーソルの切替。(カーソルが通常/フルスクリーンと交互に切り替わります)

11.4. ライブラリの選択および保守

The selection of the current library is possible via the icons/library_png which shows you all available libraries and allows you to select one. When a component is loaded or saved, it will be put in this library. The library name of component is the contents of its value field.

  • You must load a library in Eeschema, in order to access its contents.

  • 現在のライブラリに対して行った変更は、作業終了後にメインツールバーの icons/save_library_png をクリックして、ハードディスクへ保存することが可能です。

  • コンポーネントを現在のライブラリから削除するには icons/delete_png をクリックします。

11.4.1. コンポーネントの選択および保存

When you edit a component you are not really working on the component in its library but on a copy of it in the computer’s memory. Any edit action can be undone easily. A component may be loaded from a local library or from an existing component.

コンポーネントの選択

メインツールバーのアイコン icons/import_cmp_from_lib_png をクリックすると、利用可能なコンポーネントのリストが表示されます。そのコンポーネントは選択および読み込みが可能です。

If a component is selected by its alias, the name of the loaded component is displayed on the window title bar instead of the selected alias. The list of component aliases is always loaded with each component and can be edited. You can create a new component by selecting an alias of the current component from the images/toolbar_libedit_alias.png . The first item in the alias list is the root name of the component.
もう一つの方法として、エクスポートコマンド icons/export_png で前回保存したコンポーネントを、インポートコマンド icons/import_png により読み込むことができます。
コンポーネントの保存

After modification, a component can be saved in the current library, in a new library, or exported to a backup file.

現在のライブラリに保存するには、更新コマンド icons/save_part_in_mem_png を使用します。更新コマンドはローカルメモリ内にコンポーネントを保存するだけであるということを覚えておいて下さい。

コンポーネントを永続的に保存したい場合は、保存アイコン icons/save_library_png を使用しなければなりません。それは実際のハードディスク上のライブラリファイルに変更を加えます。

このコンポーネントで新規ライブラリを作成したい場合、NewLib コマンド icons/new_library_png を使用して下さい。またその時には、新規ライブラリ名が必要となります。

新しいライブラリは自動的に現在のプロジェクトへは追加されません。

回路図で使用したい新しいライブラリはすべて Eeschema の “設定” → “コンポーネントライブラリ” でダイアログを開いて、コンポーネント・ライブラリ・ファイルのリストへ追加しなければなりません。

Library settings

Click the icons/export_png to create a file containing only the current component. This file will be a standard library file which will contains only one component. This file can be used to import the component into another library. In fact, the create new library command and the export command are basically identical.

ライブラリ間のコンポーネントの移動

コピー元のライブラリからコピー先のライブラリに簡単にコンポーネントをコピーすることが可能です。それには次のコマンドを使用します:

  • アイコン icons/library_png をクリックしてコピー元のライブラリを選択します。

  • icons/import_cmp_from_lib_png ボタンで移動するコンポーネントを読み込みます。(そのコンポーネントが表示されます。)

  • icons/library_png ボタンでコピー先のライブラリを選択します。

  • icons/save_part_in_mem_png ボタンで現在のコンポーネントをローカルメモリに保存します。

  • icons/save_library_png ボタンでコンポーネントをハードディスク(コピー先のライブラリ)に保存する。

コンポーネントの編集の取り消し

あるコンポーネントに対して作業している時、編集中のコンポーネントというのは、ライブラリ内にある実際のコンポーネントの作業コピーです。このため、ローカルのメモリ内にそのコンポーネントを保存しない限り、再読み込みをすることで行ったすべての変更を取り消ことができます。ローカルのメモリ内に既に保存していたとしても、ハードディスク上のライブラリファイルに保存していない場合には、Eeschema を終了/再起動して、全ての変更を元に戻すことが常に可能です。

11.5. ライブラリコンポーネントの作成

11.5.1. 新規コンポーネントの作成

A new component can be created clicking the icons/new_component_png . You will be asked for a component name (this name is used as default value for the value field in the schematic editor), the reference designator (U, IC, R…), the number of units per package (for example a 7400 is made of 4 units per package) and if an alternate body style (sometimes referred to as DeMorgan) is desired. If the reference designator field is left empty, it will default to "U". These properties changed later, but it is preferable to set them correctly at the creation of the component.

1000000000000153000001795877268E_png

新しくコンポーネントを作成すると、コンポーネント・ライブラリ・エディタの画面上に次のように現れます。

100000000000030A00000205F0A88B4F_png

11.5.2. 他のコンポーネントからコンポーネントを作成

Often, the component that you want to make is similar to one already in a component library. In this case it is easy to load and modify an existing component.

  • 出発点として使うコンポーネントを読み込みます。

  • Click on the icons/copycomponent_png or modify its name by right-click on the value field and editing the text. If you chose to duplicate the current component, you will be prompted for a new component name.

  • 元の型となったコンポーネントにエイリアスがある場合、新規コンポーネントから衝突するエイリアスを削除するよう促されます。その答えがNO の場合、新規コンポーネントの作成は中止されます。コンポーネントライブラリは重複した名前またはエイリアスを持つことができません。

  • 必要に応じて新規コンポーネントを編集します。

  • icons/save_part_in_mem_png ボタンでメモリに新規コンポーネントを保存するか、または icons/new_library_png ボタンで新規ライブラリに保存します。あるいは他の既存のライブラリに新規コンポーネントを保存したい場合には、コマンド icons/library_png で保存したいライブラリを選択して、新規コンポーネントを保存します。

  • icons/save_library_png ボタンの “ディスクにライブラリを保存” コマンドでハードディスクにライブラリファイルを保存します。

11.5.3. コンポーネントプロパティの編集

Component properties should be carefully set during the component creation or alternatively they are inherited from the copied component. To change the component properties, click on the icons/part_properties_png to show the dialog below.

10000000000001B2000001509F311F99_png

It is very important to correctly set the number of units per package and if the component has an alternate symbolic representation parameters correctly because when pins are edited or created the corresponding pins for each unit will created. If you change the number of units per package after pin creation and editing, there will be additional work introduced to add the new unit pins and symbols. Nevertheless, it is possible to modify these properies at any time.

The graphic options "Show pin number" and "Show pin name" define the visibility of the pin number and pin name text. This text will be visible if the corresponding options are checked. The option "Place pin names inside" defines the pin name position relative to the pin body. This text will be displayed inside the component outline if the option is checked. In this case the "Pin Name Position Offset" property defines the shift of the text away from the body end of the pin. A value from 30 to 40 (in 1/1000 inch) is reasonable.

The example below shows a component with the "Place pin name inside" option unchecked. Notice the position of the names and pin numbers.

2000000800003D8000002550D6E11DAF_png

11.5.4. 代替シンボルをもつコンポーネント

もしコンポーネントが一つ以上の代替シンボル表現を持つなら、それらを編集するためにコンポーネントの別のシンボルを選択しなければならないでしょう。通常のシンボルを編集するには、 icons/morgan1_png をクリックします。

To edit the alternate symbol click on the icons/morgan2_png . Use the images/toolbar_libedit_part.png shown below to select the unit you wish to edit.

1000000000000456000002680D968591_png

11.6. グラフィック要素

グラフィック要素はコンポーネントの図形シンボルを表し、電気的接続の情報を含みません。この設計には次のツールが使用可能です。:

  • 始点と終点で定義されたラインとポリゴン。

  • 対角線にある2つのコーナーで定義された矩形。

  • 中心と半径で定義された円。

  • 始点と終点および中心で定義された円弧。(円弧は 0° から 180° まで描画できます。)

メインウィンドウの右側にあるエレメント・ツールバーで、コンポーネントの図形シンボル設計に必要な全てのグラフィック要素を配置できます。

11.6.1. グラフィック要素のメンバーシップ。

Each graphic element (line, arc, circle, etc.) can be defined as common to all units and/or body styles or specific to a given unit and/or body style. Element options can be quickly accessed by right-clicking on the element to display the context menu for the selected element. Below is the context menu for a line element.

20000009000056D200003432E4789F12_png

You can also double-left-click on an element to modify its properties. Below is the properties dialog for a polygon element.

100000000000012100000146E8D1DDCE_png

グラフィック要素のプロパティは次の通りです。:

  • “一般設定” の “幅 (W)” は、現在表示しているパーツにおけるライン要素の幅を定義します。

  • The "Common to all units in component" setting defines if the graphical element is drawn for each unit in component with more than one unit per package or if the graphical element is only drawn for the current unit.

  • The "Common by all body styles (DeMorgan)" setting defines if the graphical element is drawn for each symbolic representation in components with an alternate body style or if the graphical element is only drawn for the current body style.

  • “塗つぶしのスタイル” は、グラフィック要素で定義されるシンボルに対して、“塗つぶし無し (N)” / “前面色で塗りつぶし (F)” / “背景色で塗りつぶし (B)” を何れかを選択します。

11.6.2. グラフィックタイプのテキスト要素

アイコン icons/add_text_png により、グラフィックタイプのテキストを作成がすることができます。グラフィックタイプのテキストはコンポーネントが反転 (mirrored) しても影響されず常に読むことができます。グラフィックタイプのテキストはフィールドではないことに注意しましょう。

11.7. 多パーツコンポーネントと代替ボディスタイル

Components can have two symbolic representations (a standard symbol and an alternate symbol often referred to as "DeMorgan") and/or have more than one unit per package (logic gates for example). Some components can have more than one unit per package each with different symbols and pin configurations.

例として、3つの別のパーツ(コイル、スイッチ1、スイッチ2)として表現することが可能な2つのスイッチを持つリレーを考えてみましょう。 多パーツコンポーネントと代替ボディスタイルを持つコンポーネントの設計はとても柔軟に行えます。ピンまたはシンボルは、それぞれのパーツに共通または特定のパーツのみ、もしくは両方のボディスタイルに共通または特定のボディスタイルのみ、に適用できます。

デフォルトでは、ピンはそれぞれのパーツのそれぞれのシンボル表現に固有です。それは、ピンの数は各パーツで異なり、シンボル表現に依存した形状となるからです。ピンが各パーツまたは各シンボル表現で共通の場合、全てのパーツとシンボル表現に対して一度作成するだけで済みます(これは電源ピンの場合には一般的です)。これは、それぞれのパーツで共通であるようなボディスタイルのグラフィックとテキストの場合も同様です(しかし、普通は各シンボル表現で固有です)。

11.7.1. 異なったシンボル表現を持つ多パーツコンポーネントの例:

これはパッケージ毎に3つのパーツ(スイッチ1、スイッチ2、コイル)で定義されるリレーの例です。:

2000000900003094000008CA41334F3B_png

オプション: ピンはリンクしていない。別のパーツのいかなるピンとも同期せず、 各パーツごとに単独でピンを追加/編集できる。

10000000000001B20000014F8449F983_png

選択されている全てのパーツは入れ替えできない。

10000000000000FF000000A989993852_png

パーツ 1

1000000000000114000000B804ED21E4_png

パーツ 2

100000000000010C000000B26BA7AD80_png

Unit 3

同じシンボルとピン配置を持たないので、 ユニット1とユニット2は入れ替えできません。

グラフィックシンボル要素

Shown below are properties for a graphic body element. From the relay example above, the three units have different symbolic representations. Therefore, each unit was created separately and the graphical body elements must have the "Common to all units in component" disabled.

2000000900003855000027B1F162801F_png

11.8. ピンの作成および編集

You can click on the icons/pin_png to create and insert a pin. The editing of all pin properties is done by double-clicking on the pin or right-clicking on the pin to open the pin context menu. Pins must be created carefully, because any error will have consequences on the PCB design. Any pin already placed can be edited, deleted, and/or moved.

11.8.1. ピンの概要

A pin is defined by its graphical representation, its name and its "number". The pin’s "number" is defined by a set of 4 letters and / or numbers. For the Electrical Rules Check (ERC) tool to be useful, the pin’s "electrical" type (input, output, tri-state…) must also be defined correctly. If this type is not defined properly, the schematic ERC check results may be invalid.

重要な注意

  • ピン名とピン番号に空白(半角スペース (space) )を使用しないで下さい。

  • To define a pin name with an inverted signal (overline) use the ~ (tilde) character. The next ~ character will turn off the overline. For example \~FO~O would display FO O.

  • ピン名の文字数を減らしてこの信号のシンボルだけになった場合は、そのピンには名前がないと見なされます。

  • Pin names starting with #, are reserved for power port symbols.

  • A pin "number" consists of 1 to 4 letters and/ or numbers. 1,2,..9999 are valid numbers. A1, B3, Anod, Gnd, Wire, etc. are also valid.

  • Duplicate pin "numbers" cannot exist in a component.

11.8.2. ピンのプロパティ

100000000000031000000198EA7FCC88_png

ピンプロパティダイアログでピンの全ての特性を編集することができます。このダイアログは、ピンを作成したり、あるいは既存のピンをダブルクリックすると、自動的にポップアップします。このメニューで以下の定義または変更が可能です。:

  • “ピン名 (N)” と “ピン名の文字サイズ (A)”

  • “ピン番号 (U)” と “ピン番号の文字サイズ (X)”。

  • ピンの “角度 (O)” と “長さ (L)”。

  • “エレクトリックタイプ (E)” および “グラフィックスタイル (S)”。

  • “コンポーネントの全てのパーツで共通” および “全てのボディスタイル(ド・モルガン)で共有する (S)”

  • “可視化 (V)”。(電源ピンで使用される。)

11.8.3. ピンの形状(グラフィックスタイル)

Shown in the figure below are the different pin graphical styles. The choice of graphic styles does not have any influence on the pin’s electrical type.

10000000000003100000019800B8A351_png

11.8.4. ピンの電気的タイプ

電気的タイプの選択を正しく行うことは ERC ツールとって重要です。それぞれの電気的タイプを下図に示します。:

  • 双方向。入力および出力を切り替え可能な双方向ピン(例えばマイクロプロセッサのデータバス)を表します。

  • トライステート。通常の3ステート出力です。

  • パッシブ。抵抗、コネクタなどの受動コンポーネントのピンに使用されます。

  • 不特定(=指定なし)。ERCチェックが関係ない場合に使用することが可能です。

  • 電源入力。コンポーネントの電源ピンに使用されます。自動的に同じタイプの同じ名前(非表示電源ピン)の他のピンに接続されます。

  • 電源出力。レギュレータ出力用で使用されます。

  • オープンエミッタとオープンコレクタ。論理回路の出力に使われます。

  • 未接続。コンポーネントの内部接続されていないピンに使われます。

11.8.5. ピンのグローバルプロパティ

すべてのピンの長さ、あるいはテキストサイズ(名前、パーツ番号)を変更可能です。右クリックでポップアップされるピンのコンテキストメニューのグローバルコマンドを使用してこれら3つのパラメータの一つを設定します。変更したいパラメータをクリックし、新しい値を入力します。その値は現在の表現のすべてのコンポーネントピンに適用されます。

100000000000018D000001023AE0F5CF_png

11.8.6. 多パーツコンポーネントおよび代替シンボル表現におけるピンの定義

ピンの作成、編集を行う場合、多パーツコンポーネントおよび代替シンボル表現をもつコンポーネントは特に問題を含んでいます。ピンは個別のパーツ(ピン番号はパーツごとに指定される)と個別のシンボル表現(形状と位置はシンボル表現ごとに指定される)で指定されます。コンポーネントライブラリエディタは同時にこれらのピンの作成を行えます。デフォルトでは、ピンへの変更は、多パーツコンポーネントの全てのパーツと代替シンボル表現をもつコンポーネントの両方の表現に対して行われます。

これに対して、ピンの形状(グラフィックスタイル)と名前は例外です。この依存関係は多くの場合、ピンの作成、編集を容易にします。また、この依存関係はメインツールバーの icons/pin2pin_png で無効にできます(トグル動作です)。これにより完全に独立して、各パーツと個別のシンボル表現に対してピンを作成することができます。

A component can have two symbolic representations (representation known as "DeMorgan") and can be made up of more than one unit as in the case of components with logic gates. For certain components, you may want several different graphic elements and pins. Like the relay sample shown in section 11.7.1, a relay can be represented by three distinct units: a coil, switch contact 1, and switch contact 2.

多パーツコンポーネントと代替シンボル表現を持つコンポーネントの管理はとても柔軟に行えます。ピンは、全パーツで共通または各パーツで固有に設定できます。ピンはまた、両方のシンボル表現で共通または各シンボル表現で固有に設定できます。

デフォルトでは、ピンは各パーツのそれぞれの表現に固有です。それは、ピンの数は各パーツで異なり、それら(パーツ)のデザインは各シンボル表現で異なるからです。全てのパーツでピンが共通の場合は、(電源ピンのように)単に一度作成するだけで済みます。

例えば、4つの2入力 NAND ゲート 7400 の出力ピンを考えてみましょう。4つの入力と2つのシンボル表現があるので、コンポーネントの定義では8個の出力ピンを別々に定義します。新しい 7400 コンポーネントが作られると、通常シンボル表現のパーツAがライブラリエディタに表示されるでしょう。別のシンボル表現のピン形状(スタイル)を編集するには、まずツールバーのボタン icons/morgan2_png をクリックして有効にしなければなりません。各パーツのピン番号を編集するには、ドロップダウン images/ja/toolbar_libedit_alias.png を使ってパーツを選択します。

11.9. コンポーネントのフィールド

All library components are defined with four default fields. The reference designator, value, footprint assignment, and documentation file link fields are created whenever a component is created or copied. Only the reference designator and value fields are required. For existing fields, you can use the context menu commands by right-clicking on the pin. Components defined in libraries are typically defined with these four default fields. Additional fields such as vendor, part number, unit cost, etc. can be added to library components but generally this is done in the schematic editor so the additional fields can be applied to all of the components in the schematic.

11.9.1. コンポーネントフィールドの編集

To edit an existing component field, right-click on the field text to show the field context menu shown below.

200000090000154B000027E6496104E3_png

未定義フィールドの編集、新しいフィールドの追加、(追加された)オプションフィールドの削除を行うには、メインツールバーの icons/add_text_png で、次のコンポーネントプロパティ・ダイアログを開きます。

1000000000000208000002211F585317_png

フィールドはコンポーネントに関連したテキストの区画 (section) です。コンポーネントのグラフィック表示に属するテキストと混同すべきではありません。

重要な注意

  • 値フィールドのテキストを変更することは、型として使用する既存のコンポーネントを元にして新規コンポーネントを作成することに相当します。ライブラリに保存する場合、この新規コンポーネントは値フィールドに入っている名前を持ちます。

  • 空のフィールドや非表示属性を持つフィールドを編集するには、上のコンポーネントプロパティ・ダイアログを使用する必要があります。

  • The footprint is defined as an absolute footprint using the LIBNAME:FPNAME format where LIBNAME is the name of the footprint library defined in the footprint library table (see the "Footprint Library Table" section in the Pcbnew "Reference Manual") and FPNAME is the name of the footprint in the library LIBNAME.

11.10. 電源ポートシンボル

Power symbols are created the same way as normal components. It may be useful to place them in a dedicated library such as power.lib. Power symbols consist of a graphical symbol and a pin of the type "Power Invisible". Power port symbols are handled like any other component by the schematic capture software. Some precautions are essential. Below is an example of a power +5V symbol.

1000000000000438000002C20F7CD114_png

以下のステップに従ってシンボルを作成します。:

  • Add a pin of type "Power input" named +5V (important because this name will establish connection to the net +5V), with a pin number of 1 (number of no importance), a length of 0, and a "Line" "Graphic Style".

  • 小さな円とピンから円までの線分を配置します。

  • ピン上にシンボルのアンカーを置きます。

  • The component value is +5V.

  • The component reference is \#+5V. The reference text is not important except the first character which must be # to indicate that the component is a power symbol. By convention, every component in which the reference field starts with a # will not appear in the component list or in the netlist and the reference is declared as invisible.

An easier method to create a new power port symbol is to use another symbol as a model:

  • 型となるシンボルを読み込む。

  • 新規電源ポートの名前となるピン名を編集する。

  • 値フィールドを編集する(電源ポートの値を表示したい場合、ピン名と同じ名前にする)。

  • その新しいコンポーネントを保存する。

12. LibEdit - Complements

12.1. 概要

コンポーネントは、次の要素で構成されています。

  • グラフィカル表現(幾何学的な図形、テキスト)。

  • ピン。

  • ポストプロセッサで使われる関連テキスト、フィールド:ネットリスト、部品リスト。

次の2つのフィールドは初期化されます: リファレンスと定数。コンポーネントに関連したデザイン名、関連するフットプリント名、フリーフィールドであるその他フィールドは、一般に空欄のままにすることができ、回路図の編集中に追記できます。

しかしながら、コンポーネントに関連付けられたドキュメントを一緒に管理することで、コンポーネントを調べたり、ライブラリの使用やメンテナンスが容易になります。関連付けられたドキュメントは以下で構成されています:

  • 説明(コメント行)。

  • TTL CMOS NAND2 のように空白文字で区切られたキーワード行。

  • ドキュメントファイル名(例:アプリケーションノートや pdf ファイル)。

    ドキュメントファイルのデフォルトディレクトリは以下の通りです:

    kicad/share/library/doc(Windowsの場合)

    見つからない場合:

    kicad/library/doc(Windowsの場合)

    linux の場合:

    /usr/local/kicad/share/library/doc

    /usr/share/kicad/library/doc

    /usr/local/share/kicad/library/doc

キーワードにより、さまざまな選択基準に従ってコンポーネントを検索することができます。キーワードと説明は、様々なメニュー、特にライブラリからコンポーネントを選択する場合に表示されます。

コンポーネントはまた、アンカーポイントを持っています。回転やミラーはこのアンカーポイントに対して相対的に行われ、配置時にはこの点が基準位置として使用されます。このように、このアンカーを正確に配置することは大切です。

A component can have aliases, i.e. equivalent names. This allows you to considerably reduce the number of components that need to be created (for example, a 74LS00 can have aliases such as 74000, 74HC00, 74HCT00…).

管理を容易にするため、最終的にコンポーネントはライブラリ(メーカやテーマ別に分類された)として配布されます。

12.2. コンポーネントアンカーの配置

アンカーは、座標(0,0)にあり、画面上に青い軸で示されています。

10000000000003830000027F3B1EDABD_png

アンカーは、アイコン icons/anchor_png を選択し、新しくアンカーを配置したい位置を左クリックすることで再配置できます。 図は自動的に新しいアンカーポイントで再センタリングされます。

12.3. コンポーネントのエイリアス

エイリアスとは、ライブラリ内での同じコンポーネントに対応した別名のことです。類似したピン配列、表現を持つコンポーネントは、いくつかのエイリアスを持った1つのコンポーネントで表すことができます。 (例えば 7400 は 74LS00、74HC00、74LS37 というエイリアスを持ちます)

エイリアスの使用により素早く完全なライブラリを構築することができます。エイリアスを使うことで、よりライブラリをコンパクトにでき、KiCad での読み込みを容易にします。

エイリアスのリストを変更するためには、メインツールバーのアイコン icons/part_properties_png を左クリックして “コンポーネントのプロパティ” を開き、エイリアスのタブを選択する必要があります。

10000000000001B50000013E8AB145A7_png

このように希望のエイリアスを追加したり、削除することができます。ただし、現在のエイリアスは編集されているので、明示的に削除することはできません。

全てのエイリアスを削除するには、まずルートコンポーネントを選択することが必要です。エイリアスの最初のコンポーネントは、メインツールバーにあるエイリアス選択のドロップダウンリスト最上部に表示されます。

12.4. コンポーネントのフィールド

フィールドは、 icons/add_text_png ツールで編集することができます。

4つの特殊フィールド(コンポーネントに付属するテキスト)と、設定可能なユーザ・フィールドがあります。

10000000000002870000021DEC5337FC_png

特殊フィールド

  • リファレンス (Reference):部品の参照番号(の接頭辞)。

  • 定数 (Value) :ライブラリ内のコンポーネント名であり、回路図のデフォルト値フィールド。

  • フットプリント (Footprint) :基板で使用されるフットプリント名。CvPcb を使ってフットプリントのリストを設定する場合にはそれほど有用ではありませんが、CvPcb を使用しない場合には必須です。

  • データシート (Sheet) :現時点では使用されていない予約済フィールドです。

12.5. コンポーネントのプロパティ

コンポーネントのプロパティを編集するためには、メインツールバーのアイコン icons/part_properties_png を左クリックしてコンポーネントプロパティを開く必要があります。 “説明” 、 “キーワード” 、 “ドキュメントファイル名” を編集するには、 “説明” タブを開きます。

10000000000001B70000014140B7CFE4_png

“説明”はエイリアス間の違いを表す唯一のものとなるため、正しいエイリアスあるいはルートコンポーネントを確実に選択してください。“親要素からドキュメント情報をコピー” ボタンをクリックすると、現在編集しているエイリアスに対し、ルートコンポーネントからドキュメントの情報をコピーすることができます。

12.5.1. コンポーネントのキーワード

“キーワード” により、特定の選択基準(機能、技術的ファミリなど)に従って、コンポーネントを選択的な方法で検索することができます。

Eeschema の検索ツールは、大文字と小文字を区別しません。ライブラリで使われる現状もっとも多いキーワードは次のものです。

  • CMOS TTL :ロジックファミリ

  • AND2 NOR3 XOR2 INV… for the gates (AND2 = 2 inputs AND gate, NOR3 = 3 inputs NOR gate).

  • JKFF DFF… :JK あるいはD フリップフロップ

  • ADC, DAC, MUX…

  • OpenCol はオープンコレクタ出力を持つ論理ゲートです。例えば、回路図エディタ内で NAND2 OpenCol というキーワードでコンポーネントを検索すると、Eeschema はこれら2つのキーワードを持つコンポーネントのリストを表示します。

12.5.2. コンポーネントのドキュメントファイル名 (Doc)

特に ViewLib メニューおよびライブラリで表示されたコンポーネントの一覧からコンポーネントを選択する場合、様々なメニューに “説明” 、 “キーワード” 、 “データシート”(ドキュメントファイル) が表示されます。

コンポーネントプロパティの “ドキュメントファイル名” が存在する場合、回路図エディタソフト内でドキュメントファイルにアクセスが可能であり、コンポーネントを右クリックして表示されるコンテキストメニューから利用できます。

12.5.3. ドキュメントファイル (DocFileName) に関して

利用可能なドキュメントファイルは、技術文書、アプリケーション回路例です。有効なファイルは、pdf ファイル、回路図などで、使用中のコンピュータから利用できるものです。

12.5.4. CvPcb のフットプリントフィルタ

コンポーネントで使用できるフットプリントのリストを入力できます。編集するには “フットプリントフィルタ” タブを開きます。このリストは Cvpcb で(使用可能なフットプリントのみを表示するための)フィルタとして働きます。空のリストは何もフィルタしません。

10000000000001B8000001406BAFF1AF_png

ワイルドカード文字が使用できます。

S014* により、名称が SO14 で始まる全てのフットプリントを CvPcb で表示できます。

抵抗については、R? により R で始まる2文字の全てのフットプリントを示すことができます。

フィルタ有り、無しのサンプルを示します。

1000000000000205000001F7190A1FAC_png

フィルタ有り

1000000000000202000001F61A671096_png

フィルタなし

12.6. シンボルライブラリ

頻繁に使用されるシンボルを含んだグラフィックシンボルのライブラリファイルを簡単にコンパイルすることができます。 これはコンポーネント(三角形、AND、OR、ExORゲートなどの形状)の作成や、節約と再利用に使うことができます。

これらのファイルは、.sym という拡張子を持ち、デフォルトでライブラリディレクトリ .に保存されます。シンボルは一般的にそう多くないので、 コンポーネントのようにライブラリ内には含まれません。

12.6.1. シンボルの作成、エクスポート

コンポーネントは icons/import_png ボタンで、シンボルとしてエクスポートすることができます。一般的に1つのグラフィックを作成でき、ピンがある場合には、全てのピンを削除することをお勧めします。

12.6.2. シンボルのインポート

インポートすることで、編集しているコンポーネントにグラフィックを追加することができます。 シンボルは、 Import graphic icon ボタンでインポートされます。インポートされたグラフィックは、既存のグラフィックス内で作成されたものとして追加されます。

13. ライブラリブラウザ (Viewlib)

13.1. はじめに

Viewlib allows you to quickly examine the content of libraries. Viewlib is called by the tool icons/library_browse_png or by the "place component" tool available from the right-hand side toolbar.

100000000000016D000000E7007BA5B8_png

13.2. ライブラリブラウザ - メインウィンドウ

100000000000028A000001DC54042D35_png

ライブラリの内容を確認するには、1番左端にあるリストからライブラリを選択する必要があります。利用可能なコンポーネントが左から2番目のリストに表示されます。

100000000000028B000001DD9FC13E33_png

13.3. ライブラリブラウザ・上部ツールバー

ライブラリブラウザの上部に表示されているツールバーを以下に示します。

images/ja/toolbar_viewlib.png

利用可能なコマンドは以下のとおりです。

icons/library_png

一覧より表示するライブラリ を選択します。

icons/add_component_png

一覧より表示するコンポーネント を選択します。

icons/lib_previous_png

リストで選択されている、1つ前のコンポーネントを表示します。

icons/lib_next_png

リストで選択されている、1つ次のコンポーネントを表示します。

images/icons/zoom_in.png images/icons/zoom_out.png images/icons/zoom_redraw.png images/icons/zoom_fit_in_page.png

拡大/縮小(ズーム)ツールです。

images/icons/morgan1.png images/icons/morgan2.png

(代替シンボル表現が存在する場合)表現を選択します。

images/ja/toolbar_viewlib_part.png

(代替シンボル表現が存在する場合)表現を選択します。

icons/datasheet_png

存在する場合、コンポーネントに関連したドキュメントを参照します。( Eeschema の “コンポーネントの配置” ツールから呼び出された場合のみ有効)

icons/export_png

ライブラリブラウザを閉じ、選択されたコンポーネントを Eeschema 上に配置します。 このアイコンは、ライブラリブラウザ(Viewlib)が Eeschema から呼び出された時だけ表示されます。(“コンポーネントの選択”の画面左下のシンボル表示部を左クリック)

14. カスタマイズされたネットリストと BOM (部品表)ファイルの生成

14.1. 中間ネットリスト

部品表 (BOM) ファイルとネットリストファイルは、Eeschema が生成する中間ネットリストから変換されます。

このファイルは XML フォーマットで書かれており、中間ネットリストと呼ばれています。この中間ネットリストには設計中の基板に関する大量のデータが含まれており、後処理で部品表 (BOM) やさまざまなレポートを生成することができます。

出力するファイル(部品表 (BOM) かネットリスト)次第で、中間ネットリストの利用される部分が変わってきます。

14.1.1. 回路図サンプル

Schematic sample

14.1.2. 中間ネットリストのサンプル

上記回路図に対応する中間ネットリスト(XML文法を利用しています)を以下に示します。

<?xml version="1.0" encoding="utf-8"?>
<export version="D">
  <design>
    <source>F:\kicad_aux\netlist_test\netlist_test.sch</source>
    <date>29/08/2010 20:35:21</date>
    <tool>eeschema (2010-08-28 BZR 2458)-unstable</tool>
  </design>
  <components>
    <comp ref="P1">
      <value>CONN_4</value>
      <libsource lib="conn" part="CONN_4"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E2141</tstamp>
    </comp>
    <comp ref="U2">
      <value>74LS74</value>
      <libsource lib="74xx" part="74LS74"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E20BA</tstamp>
    </comp>
    <comp ref="U1">
      <value>74LS04</value>
      <libsource lib="74xx" part="74LS04"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E20A6</tstamp>
    </comp>
    <comp ref="C1">
      <value>CP</value>
      <libsource lib="device" part="CP"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E2094</tstamp>
    </comp>
    <comp ref="R1">
      <value>R</value>
      <libsource lib="device" part="R"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E208A</tstamp>
    </comp>
  </components>
  <libparts>
    <libpart lib="device" part="C">
      <description>Condensateur non polarise</description>
      <footprints>
        <fp>SM*</fp>
        <fp>C?</fp>
        <fp>C1-1</fp>
      </footprints>
      <fields>
        <field name="Reference">C</field>
        <field name="Value">C</field>
      </fields>
      <pins>
        <pin num="1" name="~" type="passive"/>
        <pin num="2" name="~" type="passive"/>
      </pins>
    </libpart>
    <libpart lib="device" part="R">
      <description>Resistance</description>
      <footprints>
        <fp>R?</fp>
        <fp>SM0603</fp>
        <fp>SM0805</fp>
        <fp>R?-*</fp>
        <fp>SM1206</fp>
      </footprints>
      <fields>
        <field name="Reference">R</field>
        <field name="Value">R</field>
      </fields>
      <pins>
        <pin num="1" name="~" type="passive"/>
        <pin num="2" name="~" type="passive"/>
      </pins>
    </libpart>
    <libpart lib="conn" part="CONN_4">
      <description>Symbole general de connecteur</description>
      <fields>
        <field name="Reference">P</field>
        <field name="Value">CONN_4</field>
      </fields>
      <pins>
        <pin num="1" name="P1" type="passive"/>
        <pin num="2" name="P2" type="passive"/>
        <pin num="3" name="P3" type="passive"/>
        <pin num="4" name="P4" type="passive"/>
      </pins>
    </libpart>
    <libpart lib="74xx" part="74LS04">
      <description>Hex Inverseur</description>
      <fields>
        <field name="Reference">U</field>
        <field name="Value">74LS04</field>
      </fields>
      <pins>
        <pin num="1" name="~" type="input"/>
        <pin num="2" name="~" type="output"/>
        <pin num="3" name="~" type="input"/>
        <pin num="4" name="~" type="output"/>
        <pin num="5" name="~" type="input"/>
        <pin num="6" name="~" type="output"/>
        <pin num="7" name="GND" type="power_in"/>
        <pin num="8" name="~" type="output"/>
        <pin num="9" name="~" type="input"/>
        <pin num="10" name="~" type="output"/>
        <pin num="11" name="~" type="input"/>
        <pin num="12" name="~" type="output"/>
        <pin num="13" name="~" type="input"/>
        <pin num="14" name="VCC" type="power_in"/>
      </pins>
    </libpart>
    <libpart lib="74xx" part="74LS74">
      <description>Dual D FlipFlop, Set &amp; Reset</description>
      <docs>74xx/74hc_hct74.pdf</docs>
      <fields>
        <field name="Reference">U</field>
        <field name="Value">74LS74</field>
      </fields>
      <pins>
        <pin num="1" name="Cd" type="input"/>
        <pin num="2" name="D" type="input"/>
        <pin num="3" name="Cp" type="input"/>
        <pin num="4" name="Sd" type="input"/>
        <pin num="5" name="Q" type="output"/>
        <pin num="6" name="~Q" type="output"/>
        <pin num="7" name="GND" type="power_in"/>
        <pin num="8" name="~Q" type="output"/>
        <pin num="9" name="Q" type="output"/>
        <pin num="10" name="Sd" type="input"/>
        <pin num="11" name="Cp" type="input"/>
        <pin num="12" name="D" type="input"/>
        <pin num="13" name="Cd" type="input"/>
        <pin num="14" name="VCC" type="power_in"/>
      </pins>
    </libpart>
  </libparts>
  <libraries>
    <library logical="device">
      <uri>F:\kicad\share\library\device.lib</uri>
    </library>
    <library logical="conn">
      <uri>F:\kicad\share\library\conn.lib</uri>
    </library>
    <library logical="74xx">
      <uri>F:\kicad\share\library\74xx.lib</uri>
    </library>
  </libraries>
  <nets>
    <net code="1" name="GND">
      <node ref="U1" pin="7"/>
      <node ref="C1" pin="2"/>
      <node ref="U2" pin="7"/>
      <node ref="P1" pin="4"/>
    </net>
    <net code="2" name="VCC">
      <node ref="R1" pin="1"/>
      <node ref="U1" pin="14"/>
      <node ref="U2" pin="4"/>
      <node ref="U2" pin="1"/>
      <node ref="U2" pin="14"/>
      <node ref="P1" pin="1"/>
    </net>
    <net code="3" name="">
      <node ref="U2" pin="6"/>
    </net>
    <net code="4" name="">
      <node ref="U1" pin="2"/>
      <node ref="U2" pin="3"/>
    </net>
    <net code="5" name="/SIG_OUT">
      <node ref="P1" pin="2"/>
      <node ref="U2" pin="5"/>
      <node ref="U2" pin="2"/>
    </net>
    <net code="6" name="/CLOCK_IN">
      <node ref="R1" pin="2"/>
      <node ref="C1" pin="1"/>
      <node ref="U1" pin="1"/>
      <node ref="P1" pin="3"/>
    </net>
  </nets>
</export>

14.2. 新しいネットリスト形式への変換

中間ネットリストファイルに後処理のフィルタリングをすることで、部品表 (BOM) ファイルのような他形式のファイルを生成できます。この変換はテキストからテキストへの変換なので、この後処理フィルタは、Python や XSLT など、入力として XML を扱える処理系で記述できます。

XSLT はそれ自身が XML 言語で書かれる、XML ファイルの処理に最適な言語です。 xsltproc と呼ばれるフリーソフトがあり、ダウンロードしてインストールできます。xsltproc は、中間ネットリスト入力ファイルを読み込むことができ、入力を変換するためにスタイルシートを適用して、結果をファイルへ保存します。xsltproc を使用するためには、XSLTによる変換処理のためのスタイルシートが必要となります。一度 xsltproc を設定して実行すると、これら全ての変換プロセスは、Eeschema によって制御されます。

14.3. XSLT のアプローチ

XSL 変換 (XSLT) に関するドキュメントは、下記より参照することが出来ます:

http://www.w3.org/TR/xslt

14.3.1. PADS-PCB 形式ネットリストファイルの生成

PADS-PCB 形式のネットリストは、次の2つのセクションより構成されます。

  • フットプリントの一覧

  • ネットリスト:ネット情報によりグループ化されたパッド情報

以下に、中間ネットリストからpads-pcb形式へ変換するためのスタイルシートを掲載します。:

<?xml version="1.0" encoding="ISO-8859-1"?>
<!--XSL style sheet to Eeschema Generic Netlist Format to PADS netlist format
    Copyright (C) 2010, SoftPLC Corporation.
    GPL v2.

    How to use:
        https://lists.launchpad.net/kicad-developers/msg05157.html
-->

<!DOCTYPE xsl:stylesheet [
  <!ENTITY nl  "&#xd;&#xa;"> <!--new line CR, LF -->
]>

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" omit-xml-declaration="yes" indent="no"/>

<xsl:template match="/export">
    <xsl:text>*PADS-PCB*&nl;*PART*&nl;</xsl:text>
    <xsl:apply-templates select="components/comp"/>
    <xsl:text>&nl;*NET*&nl;</xsl:text>
    <xsl:apply-templates select="nets/net"/>
    <xsl:text>*END*&nl;</xsl:text>
</xsl:template>

<!-- for each component -->
<xsl:template match="comp">
    <xsl:text> </xsl:text>
    <xsl:value-of select="@ref"/>
    <xsl:text> </xsl:text>
    <xsl:choose>
        <xsl:when test = "footprint != '' ">
            <xsl:apply-templates select="footprint"/>
        </xsl:when>
        <xsl:otherwise>
            <xsl:text>unknown</xsl:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:text>&nl;</xsl:text>
</xsl:template>

<!-- for each net -->
<xsl:template match="net">
    <!-- nets are output only if there is more than one pin in net -->
    <xsl:if test="count(node)>1">
        <xsl:text>*SIGNAL* </xsl:text>
        <xsl:choose>
            <xsl:when test = "@name != '' ">
                <xsl:value-of select="@name"/>
            </xsl:when>
            <xsl:otherwise>
                <xsl:text>N-</xsl:text>
                <xsl:value-of select="@code"/>
            </xsl:otherwise>
        </xsl:choose>
        <xsl:text>&nl;</xsl:text>
        <xsl:apply-templates select="node"/>
    </xsl:if>
</xsl:template>

<!-- for each node -->
<xsl:template match="node">
    <xsl:text> </xsl:text>
    <xsl:value-of select="@ref"/>
    <xsl:text>.</xsl:text>
    <xsl:value-of select="@pin"/>
    <xsl:text>&nl;</xsl:text>
</xsl:template>

</xsl:stylesheet>

xsltproc を実行し得られた、PADS-PCB 用のネットリストファイルを以下に示します。:

*PADS-PCB*
*PART*
P1 unknown
U2 unknown
U1 unknown
C1 unknown
R1 unknown
*NET*
*SIGNAL* GND
U1.7
C1.2
U2.7
P1.4
*SIGNAL* VCC
R1.1
U1.14
U2.4
U2.1
U2.14
P1.1
*SIGNAL* N-4
U1.2
U2.3
*SIGNAL* /SIG_OUT
P1.2
U2.5
U2.2
*SIGNAL* /CLOCK_IN
R1.2
C1.1
U1.1
P1.3

*END*

この変換は、次のコマンドラインにより実行することができます:

kicad\\bin\\xsltproc.exe -o test.net kicad\\bin\\plugins\\netlist_form_pads-pcb.xsl test.tmp

14.3.2. CADSTAR 形式のネットリストファイルの生成

CADSTAR 形式のネットリストは、下記の2セクションで構成されています。

  • フットプリントの一覧

  • ネットリスト:ネット情報によりグループ化されたパッド情報

以下に変換するためのスタイルシートを掲載します。:

<?xml version="1.0" encoding="ISO-8859-1"?>
<!--XSL style sheet to Eeschema Generic Netlist Format to CADSTAR netlist format
    Copyright (C) 2010, Jean-Pierre Charras.
    Copyright (C) 2010, SoftPLC Corporation.
    GPL v2.

<!DOCTYPE xsl:stylesheet [
  <!ENTITY nl  "&#xd;&#xa;"> <!--new line CR, LF -->
]>

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" omit-xml-declaration="yes" indent="no"/>

<!-- Netlist header -->
<xsl:template match="/export">
    <xsl:text>.HEA&nl;</xsl:text>
    <xsl:apply-templates select="design/date"/>  <!-- Generate line .TIM <time> -->
    <xsl:apply-templates select="design/tool"/>  <!-- Generate line .APP <eeschema version> -->
    <xsl:apply-templates select="components/comp"/>  <!-- Generate list of components -->
    <xsl:text>&nl;&nl;</xsl:text>
    <xsl:apply-templates select="nets/net"/>          <!-- Generate list of nets and connections -->
    <xsl:text>&nl;.END&nl;</xsl:text>
</xsl:template>

 <!-- Generate line .TIM 20/08/2010 10:45:33 -->
<xsl:template match="tool">
    <xsl:text>.APP "</xsl:text>
    <xsl:apply-templates/>
    <xsl:text>"&nl;</xsl:text>
</xsl:template>

 <!-- Generate line .APP "eeschema (2010-08-17 BZR 2450)-unstable" -->
<xsl:template match="date">
    <xsl:text>.TIM </xsl:text>
    <xsl:apply-templates/>
    <xsl:text>&nl;</xsl:text>
</xsl:template>

<!-- for each component -->
<xsl:template match="comp">
    <xsl:text>.ADD_COM </xsl:text>
    <xsl:value-of select="@ref"/>
    <xsl:text> </xsl:text>
    <xsl:choose>
        <xsl:when test = "value != '' ">
            <xsl:text>"</xsl:text> <xsl:apply-templates select="value"/> <xsl:text>"</xsl:text>
        </xsl:when>
        <xsl:otherwise>
            <xsl:text>""</xsl:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:text>&nl;</xsl:text>
</xsl:template>

<!-- for each net -->
<xsl:template match="net">
    <!-- nets are output only if there is more than one pin in net -->
    <xsl:if test="count(node)>1">
    <xsl:variable name="netname">
        <xsl:text>"</xsl:text>
        <xsl:choose>
            <xsl:when test = "@name != '' ">
                <xsl:value-of select="@name"/>
            </xsl:when>
            <xsl:otherwise>
                <xsl:text>N-</xsl:text>
                <xsl:value-of select="@code"/>
        </xsl:otherwise>
        </xsl:choose>
        <xsl:text>"&nl;</xsl:text>
        </xsl:variable>
        <xsl:apply-templates select="node" mode="first"/>
        <xsl:value-of select="$netname"/>
        <xsl:apply-templates select="node" mode="others"/>
    </xsl:if>
</xsl:template>

<!-- for each node -->
<xsl:template match="node" mode="first">
    <xsl:if test="position()=1">
       <xsl:text>.ADD_TER </xsl:text>
    <xsl:value-of select="@ref"/>
    <xsl:text>.</xsl:text>
    <xsl:value-of select="@pin"/>
    <xsl:text> </xsl:text>
    </xsl:if>
</xsl:template>

<xsl:template match="node" mode="others">
    <xsl:choose>
        <xsl:when test='position()=1'>
        </xsl:when>
        <xsl:when test='position()=2'>
           <xsl:text>.TER     </xsl:text>
        </xsl:when>
        <xsl:otherwise>
           <xsl:text>         </xsl:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:if test="position()>1">
        <xsl:value-of select="@ref"/>
        <xsl:text>.</xsl:text>
        <xsl:value-of select="@pin"/>
        <xsl:text>&nl;</xsl:text>
    </xsl:if>
</xsl:template>

</xsl:stylesheet>

CADSTAR 形式の出力ファイルです。

.HEA
.TIM 21/08/2010 08:12:08
.APP "eeschema (2010-08-09 BZR 2439)-unstable"
.ADD_COM P1 "CONN_4"
.ADD_COM U2 "74LS74"
.ADD_COM U1 "74LS04"
.ADD_COM C1 "CP"
.ADD_COM R1 "R"


.ADD_TER U1.7 "GND"
.TER     C1.2
         U2.7
         P1.4
.ADD_TER R1.1 "VCC"
.TER     U1.14
         U2.4
         U2.1
         U2.14
         P1.1
.ADD_TER U1.2 "N-4"
.TER     U2.3
.ADD_TER P1.2 "/SIG_OUT"
.TER     U2.5
         U2.2
.ADD_TER R1.2 "/CLOCK_IN"
.TER     C1.1
         U1.1
         P1.3

.END

14.3.3. OrCAD PCB2 形式ネットリストファイルの生成

このフォーマットは、フットプリントの一覧のみで構成されています。それぞれのフットプリントは接続されるネットの情報を含みます。

変換を行うためのスタイルシートファイルを、以下に示します。

<?xml version="1.0" encoding="ISO-8859-1"?>
<!--XSL style sheet to Eeschema Generic Netlist Format to CADSTAR netlist format
    Copyright (C) 2010, SoftPLC Corporation.
    GPL v2.

    How to use:
        https://lists.launchpad.net/kicad-developers/msg05157.html
-->

<!DOCTYPE xsl:stylesheet [
  <!ENTITY nl  "&#xd;&#xa;"> <!--new line CR, LF -->
]>

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" omit-xml-declaration="yes" indent="no"/>

<!--
    Netlist header
    Creates the entire netlist
    (can be seen as equivalent to main function in C
-->
<xsl:template match="/export">
    <xsl:text>( { Eeschema Netlist Version 1.1  </xsl:text>
    <!-- Generate line .TIM <time> -->
<xsl:apply-templates select="design/date"/>
<!-- Generate line eeschema version ... -->
<xsl:apply-templates select="design/tool"/>
<xsl:text>}&nl;</xsl:text>

<!-- Generate the list of components -->
<xsl:apply-templates select="components/comp"/>  <!-- Generate list of components -->

<!-- end of file -->
<xsl:text>)&nl;*&nl;</xsl:text>
</xsl:template>

<!--
    Generate id in header like "eeschema (2010-08-17 BZR 2450)-unstable"
-->
<xsl:template match="tool">
    <xsl:apply-templates/>
</xsl:template>

<!--
    Generate date in header like "20/08/2010 10:45:33"
-->
<xsl:template match="date">
    <xsl:apply-templates/>
    <xsl:text>&nl;</xsl:text>
</xsl:template>

<!--
    This template read each component
    (path = /export/components/comp)
    creates lines:
     ( 3EBF7DBD $noname U1 74LS125
      ... pin list ...
      )
    and calls "create_pin_list" template to build the pin list
-->
<xsl:template match="comp">
    <xsl:text> ( </xsl:text>
    <xsl:choose>
        <xsl:when test = "tstamp != '' ">
            <xsl:apply-templates select="tstamp"/>
        </xsl:when>
        <xsl:otherwise>
            <xsl:text>00000000</xsl:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:text> </xsl:text>
    <xsl:choose>
        <xsl:when test = "footprint != '' ">
            <xsl:apply-templates select="footprint"/>
        </xsl:when>
        <xsl:otherwise>
            <xsl:text>$noname</xsl:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:text> </xsl:text>
    <xsl:value-of select="@ref"/>
    <xsl:text> </xsl:text>
    <xsl:choose>
        <xsl:when test = "value != '' ">
            <xsl:apply-templates select="value"/>
        </xsl:when>
        <xsl:otherwise>
            <xsl:text>"~"</xsl:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:text>&nl;</xsl:text>
    <xsl:call-template name="Search_pin_list" >
        <xsl:with-param name="cmplib_id" select="libsource/@part"/>
        <xsl:with-param name="cmp_ref" select="@ref"/>
    </xsl:call-template>
    <xsl:text> )&nl;</xsl:text>
</xsl:template>

<!--
    This template search for a given lib component description in list
    lib component descriptions are in /export/libparts,
    and each description start at ./libpart
    We search here for the list of pins of the given component
    This template has 2 parameters:
        "cmplib_id" (reference in libparts)
        "cmp_ref"   (schematic reference of the given component)
-->
<xsl:template name="Search_pin_list" >
    <xsl:param name="cmplib_id" select="0" />
    <xsl:param name="cmp_ref" select="0" />
        <xsl:for-each select="/export/libparts/libpart">
            <xsl:if test = "@part = $cmplib_id ">
                <xsl:apply-templates name="build_pin_list" select="pins/pin">
                    <xsl:with-param name="cmp_ref" select="$cmp_ref"/>
                </xsl:apply-templates>
            </xsl:if>
        </xsl:for-each>
</xsl:template>


<!--
    This template writes the pin list of a component
    from the pin list of the library description
    The pin list from library description is something like
          <pins>
            <pin num="1" type="passive"/>
            <pin num="2" type="passive"/>
          </pins>
    Output pin list is ( <pin num> <net name> )
    something like
            ( 1 VCC )
            ( 2 GND )
-->
<xsl:template name="build_pin_list" match="pin">
    <xsl:param name="cmp_ref" select="0" />

    <!-- write pin numner and separator -->
    <xsl:text>  ( </xsl:text>
    <xsl:value-of select="@num"/>
    <xsl:text> </xsl:text>

    <!-- search net name in nets section and write it: -->
    <xsl:variable name="pinNum" select="@num" />
    <xsl:for-each select="/export/nets/net">
        <!-- net name is output only if there is more than one pin in net
             else use "?" as net name, so count items in this net
        -->
        <xsl:variable name="pinCnt" select="count(node)" />
        <xsl:apply-templates name="Search_pin_netname" select="node">
            <xsl:with-param name="cmp_ref" select="$cmp_ref"/>
            <xsl:with-param name="pin_cnt_in_net" select="$pinCnt"/>
            <xsl:with-param name="pin_num"> <xsl:value-of select="$pinNum"/>
            </xsl:with-param>
        </xsl:apply-templates>
    </xsl:for-each>

    <!-- close line -->
    <xsl:text> )&nl;</xsl:text>
</xsl:template>

<!--
    This template writes the pin netname of a given pin of a given component
    from the nets list
    The nets list description is something like
      <nets>
        <net code="1" name="GND">
          <node ref="J1" pin="20"/>
              <node ref="C2" pin="2"/>
        </net>
        <net code="2" name="">
          <node ref="U2" pin="11"/>
        </net>
    </nets>
    This template has 2 parameters:
        "cmp_ref"   (schematic reference of the given component)
        "pin_num"   (pin number)
-->

<xsl:template name="Search_pin_netname" match="node">
    <xsl:param name="cmp_ref" select="0" />
    <xsl:param name="pin_num" select="0" />
    <xsl:param name="pin_cnt_in_net" select="0" />

    <xsl:if test = "@ref = $cmp_ref ">
        <xsl:if test = "@pin = $pin_num">
        <!-- net name is output only if there is more than one pin in net
             else use "?" as net name
        -->
            <xsl:if test = "$pin_cnt_in_net>1">
                <xsl:choose>
                    <!-- if a net has a name, use it,
                        else build a name from its net code
                    -->
                    <xsl:when test = "../@name != '' ">
                        <xsl:value-of select="../@name"/>
                    </xsl:when>
                    <xsl:otherwise>
                        <xsl:text>$N-0</xsl:text><xsl:value-of select="../@code"/>
                    </xsl:otherwise>
                </xsl:choose>
            </xsl:if>
            <xsl:if test = "$pin_cnt_in_net &lt;2">
                <xsl:text>?</xsl:text>
            </xsl:if>
        </xsl:if>
    </xsl:if>

</xsl:template>

</xsl:stylesheet>

OrCAD PCB2 形式の出力ファイルです。

( { Eeschema Netlist Version 1.1  29/08/2010 21:07:51
eeschema (2010-08-28 BZR 2458)-unstable}
 ( 4C6E2141 $noname P1 CONN_4
  (  1 VCC )
  (  2 /SIG_OUT )
  (  3 /CLOCK_IN )
  (  4 GND )
 )
 ( 4C6E20BA $noname U2 74LS74
  (  1 VCC )
  (  2 /SIG_OUT )
  (  3 N-04 )
  (  4 VCC )
  (  5 /SIG_OUT )
  (  6 ? )
  (  7 GND )
  (  14 VCC )
 )
 ( 4C6E20A6 $noname U1 74LS04
  (  1 /CLOCK_IN )
  (  2 N-04 )
  (  7 GND )
  (  14 VCC )
 )
 ( 4C6E2094 $noname C1 CP
  (  1 /CLOCK_IN )
  (  2 GND )
 )
 ( 4C6E208A $noname R1 R
  (  1 VCC )
  (  2 /CLOCK_IN )
 )
)
*

14.3.4. Eeschema プラグイン・インタフェイス

中間ネットリストの変換は Eeschema の中で自動的に実行させることができます。

ダイアログウィンドウの初期化

One can add a new netlist plug-in user interface tab by clicking on the Add Plugin button.

10000000000000FC000000C867B9348F_png

PADS-PCB タブの設定は、下記のようになります:

100000000000026D000001272BA6B200_png

プラグインの設定パラメータ

Eeschema のプラグイン設定ダイアログでは、下記の情報が必要になります:

  • タイトル: ネットリストフォーマットの名前など

  • 変換を行うためのコマンドライン

ネットリストボタンをクリックすると、次のように実行されます。

Eeschema は test.xml.* のように、中間ネットリスト .xml を生成します。 2. Eeschema は test.xml を読み込むことでプラグインを実行し、test.net を生成します。

コマンドラインからのネットリストファイルの生成

xsltproc.exe を利用して中間ネットリストへスタイルシートを適用する場合、下記のコマンドにより xsltproc.exe が実行されます。

xsltproc.exe -o <output filename> < style-sheet filename> <input XML file to convert>

Windows 環境で KiCad を利用している場合のコマンドラインは以下のようになります。

f:/kicad/bin/xsltproc.exe -o "%O" f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl "%I"

Linux環境の場合のコマンドを以下に示します。

xsltproc -o "%O" /usr/local/kicad/bin/plugins/netlist_form_pads-pcb.xsl "%I"

netlist_form_pads-pcb.xsl には、適用するスタイルシートのファイル名が入ります。このスタイルシートのファイル名をダブルクオーテーション (") で囲むのを忘れないようにしてください。これにより、Eeschema による変換後のスペースの使用を許容します。

コマンドラインフォーマットはファイル名のパラメータを受け付けます:

サポートしているフォーマットパラメータを下記に示します:

  • %B ⇒ 選択された出力ファイルのパスとファイル名から、パスと拡張子を除いたもの。

  • %I ⇒ 現在の入力ファイル(中間ネットリストファイル)の完全なパスとファイル名。

  • %O ⇒ ユーザが選んだ出力ファイルの完全なパスとファイル名。

%I は実際の中間ネットリストファイル名へ置換されます。

%O は実際の出力ファイル名へ置換され、最終的なネットリストファイルとなります。

コマンドラインフォーマット: xsltproc の例

xsltproc のコマンドラインフォーマットは、下記のようになります:

<path of xsltproc> xsltproc <xsltproc parameters>

under Windows.

f:/kicad/bin/xsltproc.exe -o "%O" f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl "%I"

under Linux:

xsltproc -o "%O" /usr/local/kicad/bin/plugins/netlist_form_pads-pcb.xsl "%I"

上記は、xsltproc が Windows 環境下で kicad/bin 以下にインストールされていると仮定したものです。

14.3.5. BOM (部品表)の生成

中間ネットリストファイルは、使用されているコンポーネント全ての情報を含んでいるため、ここから BOM(部品表)を生成することができます。以下に BOM(部品表)を生成させるための、Windows (Linux) 環境下でのプラグイン設定ウィンドウを示します:

bom-netlist-tab_png

bom2csv.xsl のパスは、システムによって異なります。現状で最適な BOM (部品表)を生成する XSLT スタイルシートは、ここでは bom2csv.xsl とします。

14.4. コマンドラインフォーマット: python スクリプトの例

python を使用した場合のコマンドラインフォーマットは、下記のようになります:

python <script file name> <input filename> <output filename>

Wiindows環境の場合:

python *.exe f:/kicad/python/my_python_script.py "%I" "%O"

under Linux:

python /usr/local/kicad/python/my_python_script.py "%I" "%O"

(あなたの PC に python がインストールされている必要があります。)

14.5. 中間ネットリストファイルの構造

ネットリストファイルの例を次に示します。

<?xml version="1.0" encoding="utf-8"?>
<export version="D">
  <design>
    <source>F:\kicad_aux\netlist_test\netlist_test.sch</source>
    <date>29/08/2010 21:07:51</date>
    <tool>eeschema (2010-08-28 BZR 2458)-unstable</tool>
  </design>
  <components>
    <comp ref="P1">
      <value>CONN_4</value>
      <libsource lib="conn" part="CONN_4"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E2141</tstamp>
    </comp>
    <comp ref="U2">
      <value>74LS74</value>
      <libsource lib="74xx" part="74LS74"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E20BA</tstamp>
    </comp>
    <comp ref="U1">
      <value>74LS04</value>
      <libsource lib="74xx" part="74LS04"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E20A6</tstamp>
    </comp>
    <comp ref="C1">
      <value>CP</value>
      <libsource lib="device" part="CP"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E2094</tstamp>
    <comp ref="R1">
      <value>R</value>
      <libsource lib="device" part="R"/>
      <sheetpath names="/" tstamps="/"/>
      <tstamp>4C6E208A</tstamp>
    </comp>
  </components>
  <libparts/>
  <libraries/>
  <nets>
    <net code="1" name="GND">
      <node ref="U1" pin="7"/>
      <node ref="C1" pin="2"/>
      <node ref="U2" pin="7"/>
      <node ref="P1" pin="4"/>
    </net>
    <net code="2" name="VCC">
      <node ref="R1" pin="1"/>
      <node ref="U1" pin="14"/>
      <node ref="U2" pin="4"/>
      <node ref="U2" pin="1"/>
      <node ref="U2" pin="14"/>
      <node ref="P1" pin="1"/>
    </net>
    <net code="3" name="">
      <node ref="U2" pin="6"/>
    </net>
    <net code="4" name="">
      <node ref="U1" pin="2"/>
      <node ref="U2" pin="3"/>
    </net>
    <net code="5" name="/SIG_OUT">
      <node ref="P1" pin="2"/>
      <node ref="U2" pin="5"/>
      <node ref="U2" pin="2"/>
    </net>
    <net code="6" name="/CLOCK_IN">
      <node ref="R1" pin="2"/>
      <node ref="C1" pin="1"/>
      <node ref="U1" pin="1"/>
      <node ref="P1" pin="3"/>
    </net>
  </nets>
</export>

14.5.1. 一般的なネットリストファイルの構造

中間ネットリストファイルは、次の5つのセクションで構成されています。

  • ヘッダーセクション

  • コンポーネントセクション

  • ライブラリパーツセクション

  • ライブラリセクション

  • ネットセクション

このファイルは <export> タグで囲まれたものとなります。

<export version="D">
...
</export>

14.5.2. ヘッダーセクション

このヘッダは <design> タグで囲まれます。

<design>
<source>F:\kicad_aux\netlist_test\netlist_test.sch</source>
<date>21/08/2010 08:12:08</date>
<tool>eeschema (2010-08-09 BZR 2439)-unstable</tool>
</design>

このセクションはコメントセクションとして捉えることができます。

14.5.3. コンポーネントセクション

このコンポーネントセクションは <components> タグで囲まれたものとなります。

<components>
<comp ref="P1">
<value>CONN_4</value>
<libsource lib="conn" part="CONN_4"/>
<sheetpath names="/" tstamps="/"/>
<tstamp>4C6E2141</tstamp>
</comp>
</components>

このセクションには、回路図中で使用されているコンポーネントの一覧が含まれます。それぞれのコンポーネントは、次のように記載されます。:

<comp ref="P1">
<value>CONN_4</value>
<libsource lib="conn" part="CONN_4"/>
<sheetpath names="/" tstamps="/"/>
<tstamp>4C6E2141</tstamp>
</comp>

libsource

そのコンポーネントが含まれているライブラリ名

part

ライブラリ中に登録されているコンポーネント名

sheetpath

階層内のシートのパス(回路図階層全体の中で、その回路図シートの位置を 明確にするために利用される)

tstamps (time stamps)

回路図ファイルのタイムスタンプ

tstamp (time stamp)

コンポーネントのタイムスタンプ

コンポーネントのタイムスタンプに関する注意

ネットリスト(つまり基板上)のコンポーネントを識別する際、タイムスタンプ情報はコンポーネントに固有の情報となります。一方で、KiCad はコンポーネントを基板上の対応するフットプリントから識別する方法を補助的に用意しています。これは、回路図プロジェクト中のコンポーネントを再アノテーションできるようにし、コンポーネントとフットプリント間の結びつき情報を消失しないようにするためのものです。

タイムスタンプは、それぞれのコンポーネントや回路図プロジェクト内のシートにおいて固有の識別子です。しかしながら、複雑な階層構造内で同じシートが複数回参照される場合、同じタイムスタンプを持つコンポーネントが存在することになってしまいます。

このような複雑な階層構造を持つシートでは、シートのパス情報を利用して固有の識別子を持ちます。コンポーネントは、“そのシートのパス+タイムスタンプ” を固有の識別子として持ちます。

14.5.4. ライブラリパーツ・セクション

このライブラリパーツセクションは、<libparts>タグで囲まれたものとなり、このセクションは回路図ライブラリの情報を定義するものとなります。このセクションは、次のものを含みます:

  • <fp>で定義されるフットプリント名(名前にはワイルドカードも使われます)

  • <fields>で定義されるフィールド

  • <pins>で定義されるピンリスト

<libparts>
<libpart lib="device" part="CP">
  <description>Condensateur polarise</description>
  <footprints>
    <fp>CP*</fp>
    <fp>SM*</fp>
  </footprints>
  <fields>
    <field name="Reference">C</field>
    <field name="Valeur">CP</field>
  </fields>
  <pins>
    <pin num="1" name="1" type="passive"/>
    <pin num="2" name="2" type="passive"/>
  </pins>
</libpart>
</libparts>

<pin num=“1” type=“passive”/> のような行は、ピンの電気的な種類を定義するものです。有効なピンの種類は、次のものがあります。

Input

通常の入力

Output

通常の出力

Bidirectional

入力または出力

Tri-state

バスの入出力

Passive

受動部品のピン

Unspecified

不明な種類

Power input

コンポーネントの電源入力

Power output

レギュレータ IC のような部品の電源出力

Open collector

アナログコンパレータでよくみられるオープンコレクタ出力

Open emitter

ロジック IC でみられるオープンエミッタ出力

Not connected

回路図上でオープン(未接続)とすべきピン

14.5.5. ライブラリ・セクション

ライブラリセクションは<libraries>タグで囲まれたものとなります。このセクションはプロジェクトから利用されているライブラリ情報を含みます。

<libraries>
  <library logical="device">
    <uri>F:\kicad\share\library\device.lib</uri>
  </library>
  <library logical="conn">
    <uri>F:\kicad\share\library\conn.lib</uri>
  </library>
</libraries>

14.5.6. ネット・セクション

The nets section has the delimiter <nets>. This section contains the "connectivity" of the schematic.

<nets>
  <net code="1" name="GND">
    <node ref="U1" pin="7"/>
    <node ref="C1" pin="2"/>
    <node ref="U2" pin="7"/>
    <node ref="P1" pin="4"/>
  </net>
  <net code="2" name="VCC">
    <node ref="R1" pin="1"/>
    <node ref="U1" pin="14"/>
    <node ref="U2" pin="4"/>
    <node ref="U2" pin="1"/>
    <node ref="U2" pin="14"/>
    <node ref="P1" pin="1"/>
  </net>
</nets>

このセクションでは、回路図上の全てのネットを羅列します。

ネット情報の例を次に示します。

<net code="1" name="GND">
  <node ref="U1" pin="7"/>
  <node ref="C1" pin="2"/>
  <node ref="U2" pin="7"/>
  <node ref="P1" pin="4"/>
</net>

net code

ネットの内部的な識別番号

name

ネット名

node

ネットに接続されるピン

14.6. xsltproc に関する追加情報

次の Web ページを参照してください: http://xmlsoft.org/XSLT/xsltproc.html

14.6.1. はじめに

xsltproc は XSLT スタイルシートを XML 文書に適用するためのコマンドラインツールです。これは GNOME プロジェクトの一環として開発され、GNOME デスクトップ環境が無くても利用することが可能です。

xsltproc はスタイルシート名と適用するファイル名をオプションとし、コマンドラインより起動されます。標準入力を利用する場合、ファイル名には – 記号を利用します。

スタイルシートが XML 文書内に含まれている場合、コマンドラインでスタイルシート名を指示する必要はありません。xsltproc は自動的にスタイルシートを検出し利用します。標準では、出力が 標準出力(stdout) となっています。ファイルとして結果を出力したい場合には、 -o オプションを利用します。

14.6.2. 概要

xsltproc [[-V] | [-v] | [-o *file* ] | [--timing] | [--repeat] |
[--debug] | [--novalid] | [--noout] | [--maxdepth *val* ] | [--html] |
[--param *name* *value* ] | [--stringparam *name* *value* ] | [--nonet] |
[--path *paths* ] | [--load-trace] | [--catalogs] | [--xinclude] |
[--profile] | [--dumpextensions] | [--nowrite] | [--nomkdir] |
[--writesubtree] | [--nodtdattr]] [ *stylesheet* ] [ *file1* ] [ *file2* ]
[ *....* ]

14.6.3. コマンドラインオプション

-V 又は --version

利用している libxml と libxslt のバージョン情報を表示します。

-v 又は --verbose

xsltproc がスタイルシートとドキュメントを処理する各段階でメッセージを出力します。

-o 又は --output file

<ファイル名>で指定されたファイルへ結果を出力します。「チャンク」などとして知られているように、複数出力したい場合は -o ディレクトリ名/ として指定したディレクトリへファイルを出力します。この場合、ディレクトリは予め作成しておく必要があります。

--timing

スタイルシートの構文解析、ドキュメントの構文解析、スタイルシートの適用、結果の保存にかかった時間を表示します。ミリ秒の単位で表示されます。

--repeat

タイミングテストの為に、変換を20回繰り返し実行します。

--debug

デバッグの為に、変換されたドキュメントの XML ツリーを出力します。

--novalid

ドキュメントの DTD の読み込みをスキップします。

--noout

結果を出力しません。

--maxdepth <値>

libxsltの無限ループを防ぐため、テンプレートの最大スタック深度を調整します。デフォルトは500 です。

--html

HTML ファイルを入力ファイルとします。

--param <パラメータ名><値>

スタイルシート中の、パラメータで指定された<パラメータ名> name および<値> value の処理を行いません。パラメータ名と値のペアは、最大 32 個まで指定することができます。値をノードの識別ではなく、文字列として処理したい場合は、--stringparam オプションを利用してください。

--stringparam <パラメータ名> <値>

<パラメータ名> name と<値> value で指定された値について、ノードの識別ではなく文字列として扱うようにします。(注:これら文字列は utf-8 エンコードされている必要があります。)

--nonet

DTDのエンティティやドキュメントをインターネットから取得しません。

--path <パス>

DTDやエンティティ、ドキュメントの読み込みに、 <パス> で指定されたファイルのリスト(半角スペースやカンマで区切られる)を使用します。

--load-trace

処理中に読み込まれた全てのドキュメントを、標準エラー出力 (stderr) へ出力します。

--catalogs

SGML_CATALOG_FILES 内で指定された SGML カタログを外部エンティティの解決に利用します。標準では、xsltproc は XML_CATALOG_FILES で指定された場所を探します。XML_CATALOG_FILES が定義されていない場合、/etc/xml /catalog を利用します。

--xinclude

Xincludeの仕様に基づき、入力ドキュメントの処理を行います。Xincludeの詳細は、次を参照してください:http://www.w3.org/TR/xinclude/

--profile --norman

スタイルシートのそれぞれのパーツの処理時に、プロファイル情報の詳細を出力します。これはスタイルシートのパフォーマンスを最適化するために利用できます。

--dumpextensions

登録済みの拡張子のリストを標準出力 (stdout) へ出力します。

--nowrite

ファイルやリソースへの書き込みを行いません。

--nomkdir

ディレクトリを作成しません。

--writesubtree <パス>

<パス> で指定されたパス内のファイルのみ書込します。

--nodtdattr

ドキュメント内DTDの標準アトリビュートを適用しません。

14.6.4. Xsltproc の戻り値

xsltproc はスクリプトからの呼び出し時などに利用しやすいよう、戻り値でステータスを返します。

0: 通常

1: 引数なし

2: パラメータが多すぎる

3: 不明なオプション

4: スタイルシートの構文解析に失敗 (parse error)

5: スタイルシート内にエラー

6: ドキュメントのひとつにエラー

7: 未サポートの xsl : 出力メソッド

8: 文字列パラメータがクオートとダブルクオートの両方を含んでいる

9: 内部処理エラー

10: 中断シグナル (CTRL+C など) により処理を終了

11: 出力ファイルに書き込めない

14.6.5. xsltproc に関する追加情報

libxml web ページ: http://www.xmlsoft.org/

W3C XSLTページ: http://www.w3.org/TR/xslt