3947840b05
Interpretation of a chunk in cut.1 was helped by: Yoshihiko Sarumaru <mistral@imasy.or.jp>, hrs
161 lines
4.4 KiB
Groff
161 lines
4.4 KiB
Groff
.\" %FreeBSD: src/usr.bin/units/units.1,v 1.16 2004/07/02 22:22:33 ru Exp %
|
|
.\"
|
|
.\" $FreeBSD$
|
|
.Dd July 14, 1993
|
|
.Dt UNITS 1
|
|
.Os
|
|
.Sh 名称
|
|
.Nm units
|
|
.Nd いろいろな単位の換算を行う
|
|
.Sh 書式
|
|
.Nm
|
|
.Op Fl f Ar filename
|
|
.Op Fl qv
|
|
.Op Ar from-unit to-unit
|
|
.Sh オプション
|
|
.Bl -tag -width indent
|
|
.It Fl f Ar filename
|
|
単位換算用のデータファイル名を指定します。
|
|
.It Fl q
|
|
求める単位の入力プロンプトと、
|
|
換算する単位の入力プロンプトの表示を抑制します。
|
|
.It Fl v
|
|
バージョン番号を表示します。
|
|
.It Ar from-unit to-unit
|
|
コマンドラインから直接、単位換算を行ないます。
|
|
プロンプトは表示せず、
|
|
指定した換算結果を表示し終了します。
|
|
.El
|
|
.Sh 解説
|
|
.Nm
|
|
プログラムは様々な単位で表された量を他の単位に換算します。
|
|
乗算で求められる単位の換算のみ行なえますが、
|
|
摂氏から華氏への変換などはできません。
|
|
入力プロンプトを介して、対話的に動作します。
|
|
.Bd -literal
|
|
|
|
You have: meters
|
|
You want: feet
|
|
* 3.2808399
|
|
/ 0.3048
|
|
|
|
You have: cm^3
|
|
You want: gallons
|
|
* 0.00026417205
|
|
/ 3785.4118
|
|
|
|
You have: meters/s
|
|
You want: furlongs/fortnight
|
|
* 6012.8848
|
|
/ 0.00016630952
|
|
|
|
You have: 1|2 inch
|
|
You want: cm
|
|
* 1.27
|
|
/ 0.78740157
|
|
.Ed
|
|
.Pp
|
|
単位の中で累乗を表す部分は、上の例のように `^' を用いて表すか、
|
|
あるいは単に連結して表記します。例えば `cm3' は `cm^3' と等価です。
|
|
単位の掛け算を表すには、空白、ダッシュあるいはアスタリスクを用います。
|
|
単位の割り算には `/' を用います。
|
|
掛け算は割り算より高い優先度を持ちますから、
|
|
`m/s/s' は `m/s^2' あるいは `m/s s' と同じ意味になります。
|
|
数値の割り算には縦棒(`|')を用いなければなりません。
|
|
例えば 1 メートルの半分を変換するには、`1|2 meter' と書きます。
|
|
もし `1/2 meter' と書くと、
|
|
.Nm
|
|
はそれを `0.5/meter' と解釈します。
|
|
換算できない単位型を指定すると、
|
|
.Nm
|
|
はそれに対応していない旨の
|
|
メッセージを表示し、各単位の簡略形を示します。
|
|
.Bd -literal
|
|
|
|
You have: ergs/hour
|
|
You want: fathoms kg^2 / day
|
|
conformability error
|
|
2.7777778e-11 kg m^2 / sec^3
|
|
2.1166667e-05 kg^2 m / sec
|
|
.Ed
|
|
.Pp
|
|
換算に必要な情報は、換算用データベースファイルから読み込まれます。
|
|
デフォルトのファイルには、よく用いられる単位のほとんど、
|
|
省略形、メートル法の接頭語、などの定義が含まれています。
|
|
以下のような自然定数もいくつか含まれています:
|
|
.Pp
|
|
.Bl -column -offset indent -compact "mercury"
|
|
.It "pi 円周率
|
|
.It "c 光速
|
|
.It "e 電子の電荷
|
|
.It "g 重力加速度
|
|
.It "force g と同じ
|
|
.It "mole アボガドロ数
|
|
.It "water 単位水柱の圧力
|
|
.It "mercury 単位水銀柱の圧力
|
|
.It "au 天文単位
|
|
.El
|
|
.Pp
|
|
`pound' (ポンド) は質量の単位です。
|
|
複合した単位名は連結して記述します。
|
|
`pound force' は力の単位です。
|
|
`ounce' (オンス) もまた質量の単位です。
|
|
液体のオンスは `floz' です。
|
|
英米で同じ単位の値が異なる場合、英国式単位の前に `br' を付けます。
|
|
通貨単位の場合には `belgiumfranc' や `britainpound' のように頭に国名を付けて区
|
|
別します。
|
|
単位を探す際に指定された文字列そのものが単位名として見つからない場合、
|
|
.Nm
|
|
は末尾の `s' や `es' を取り除いて再度チェックします。
|
|
.Pp
|
|
どのような単位が利用可能か、については、標準の単位ファイルを参照して
|
|
下さい。
|
|
独自の単位を追加したいなら、独自のファイルを指定できます。
|
|
単位の指定は、1 行に名前とそれに相当する量を書きます。
|
|
新しい単位は古い単位に基づいて定義し、
|
|
単位を変換していくと `!' 印を付した原始単位にたどりつく
|
|
ように注意してください。
|
|
不注意で単位定義に無限ループがあっても
|
|
.Nm
|
|
はそれを検知しません。
|
|
単位定義ファイル中において `/' で始まる行はコメントです。
|
|
.Pp
|
|
接頭語の定義も標準的な単位と同形式で行ないますが、
|
|
接頭語名の末尾にダッシュをつけます。
|
|
末尾の `s' や `es' を取り除いても、単位名として見つからない場合は、
|
|
接頭語かどうかがチェックされ、
|
|
接頭語を取り除くと有効な基本単位名となるかを調べます。
|
|
.Pp
|
|
基本的な単位を定義する簡単な単位ファイルの例を以下に示します。
|
|
.Pp
|
|
.Bl -column -offset indent -compact "minute"
|
|
.It "m !a!
|
|
.It "sec !b!
|
|
.It "micro- 1e-6
|
|
.It "minute 60 sec
|
|
.It "hour 60 min
|
|
.It "inch 0.0254 m
|
|
.It "ft 12 inches
|
|
.It "mile 5280 ft
|
|
.El
|
|
.Sh バグ
|
|
接頭語に `/' が含まれるとびっくりする結果を生みます。
|
|
.Pp
|
|
ユーザが入力する累乗部分は 1 桁でなければなりません。
|
|
必要なら何度か掛け合わせて下さい。
|
|
.Pp
|
|
数の除算には `|' を用い、シンボルの除算には `/' を用いなければなりませんが、
|
|
このような区別は不要にすべきです。
|
|
.Pp
|
|
このプログラムは、換算した表示桁数の制限がばらばらですし、
|
|
データファイルの長さにも制限があります。
|
|
.Pp
|
|
単位を格納するのにハッシュ表を用い、
|
|
単位表のロードと重複チェックの時間を軽減すべきです。
|
|
.Sh 関連ファイル
|
|
.Bl -tag -width /usr/share/misc/units.lib -compact
|
|
.It Pa /usr/share/misc/units.lib
|
|
標準単位ライブラリ
|
|
.El
|
|
.Sh 作者
|
|
.An Adrian Mariano Aq adrian@cam.cornell.edu
|