0
大学数学基礎解説
文献あり

大小比較関数は完全な前順序を定める

103
0
$$$$

大小比較関数と完全な前順序

プログラミング言語において、「小さい、等しい、大きい」を表す三値の比較関数を用いて、値同士の順序関係を自分で定義することがある。
たとえばJavaでは Comparator インターフェースのcompareメソッドを実装するが、このような関数が完全な前順序関係を特徴づけることを確認する。以下の性質はJavaのドキュメントを参考にした。

任意の集合$X$に対して、$f:X \times X \to \mathbf{N}$を以下の性質をもつ関数であるとする。

  • $f(x,y)\in \{-1, 0, 1\},\, \forall x,y \in X$
  • $f(x,y) = -f(y,x),\, \forall x,y \in X$
  • ($f(x,y) > 0$かつ$f(y,z)>0$)ならば$f(x,z)>0,\, \forall x,y,z \in X$
  • $f(x,y) = 0$ならば$f(x,z)=f(y,z),\, \forall x,y,z \in X$

この関数$f$$X$上の完全な前順序関係を特徴づける。すなわち、以下の条件を満たす二項関係$\preceq$を特徴づけることを示す。

  • 反射律。$x \preceq x,\, \forall x \in X$
  • 推移律。($x \preceq y$かつ$y \preceq z$)ならば$x \preceq z,\,\forall x, y, z \in X$
  • 完全性。$x \preceq y$または$y \preceq x,\,\forall x, y\in X$

比較関数から完全な前順序

$f: X \times X \to \mathbf{N}$を先の性質を満たす関数とする。$\preceq$を以下で定義する。
$$\begin{eqnarray} x \preceq y \Leftrightarrow f(x,y) \leq 0\end{eqnarray}$$

反射律を示す。$f(x,x) = -f(x,x)$より$f(x,x) = 0$。したがって$x \preceq x$

推移律を示す。$x \preceq y,\, y \preceq z$を仮定して$x \preceq z$を導く。仮定より$f(x,y)$および$f(y,z)$$-1$または$0$である。いずれか片方が$0$の場合、たとえば$f(x,y) =0$の場合、$f(x,z) = f(y,z) \leq 0$より$x \leq z$である。$f(y,z)=0$の場合も同様。いずれも$-1$の場合は$f(z,y) >0,\, f(y,x) >0$より$f(z,x) >0$、すなわち$f(x,z) = -f(z,x) < 0$より$x \leq z$である。結局いずれの場合でも$x \preceq z$である。

完全性を示す。$f(x,y) \leq 0$または$f(x,y) > 0$である。$f(x,y) \leq 0$のとき、$x \preceq y$である。$f(x,y) > 0$のとき、$f(y,x) = -f(x,y) < 0$より$y \preceq x$である。以上より$x \preceq y$または$y \preceq x$である。

完全な前順序から比較関数

完全な前順序関係$\preceq$を用いて、関数$f: X \times X \to \mathbf{N}$を以下のように定義する。
$$\begin{eqnarray} f(x,y) = \begin{cases} -1 & x \preceq y,\, \neg (y \preceq x)\\ 0 & x \preceq y,\, y \preceq x\\ 1 & y \preceq x,\, \neg (x \preceq y) \end{cases}\end{eqnarray}$$

$f(x,y)$$-1,\, 0,\, 1$のいずれかであることは明らか。

$f(x,y)=-f(y,x)$も明らか。

$f(x,y) >0$$f(y,z)>0$を仮定して$f(x,z) > 0$を導く。仮定より$y \preceq x,\, \neg (x \preceq y),\, z \preceq y$である。推移律より$z \preceq x$である。さらに$x \preceq z$を仮定すると推移律より$x \preceq y$が導かれ、これは$\neg (x \preceq y)$に矛盾するので仮定$x \preceq z$は否定される。以上より$f(x,z)=1>0$

$f(x,y)=0$と仮定する。これは$x \preceq y,\, y \preceq x$を意味するので
$$\begin{eqnarray} &x \preceq z \Rightarrow y \preceq z\ (\because 推移律)\\ &y \preceq z \Rightarrow x \preceq z\ (\because 推移律)\end{eqnarray}$$となり、$x \preceq z$$y \preceq z$は同値。同様に$z \preceq x$$z \preceq y$が同値になるから、$f(x,z)=f(y,z)$

全単射性

関数$f$から関係$\preceq$を定義し、それにもとづいて関数$f'$を定義すると$f=f'$である。

関係$\preceq \subseteq X \times X$から関数$f$を定義し、それにもとづいて関係$\preceq'$を定義すると$\preceq=\preceq'$である。

証明は省略する。

参考文献

投稿日:2021627

この記事を高評価した人

高評価したユーザはいません

この記事に送られたバッジ

バッジはありません。

投稿者

kyasmt
0
103

コメント

他の人のコメント

コメントはありません。
読み込み中...
読み込み中