計算機科学のブログ

型の紹介 型クラスを使用する Enum、fromEnum関数、Eq、Ord

入門Haskellプログラミング (Will Kurt(著)、株式会社クイープ(監修、翻訳)、翔泳社)のUNIT2(型の紹介)、LESSON 14(型クラスを使用する)、14.10(練習問題)Q14-1の解答を求めてみる。

コード

lesson/app/Main.hs

module Main where

import Lib (MyData)

l :: [MyData]
l = [A .. E]

op :: (MyData -> MyData -> Bool) -> [Bool]
op f = f <$> l <*> l

p :: (MyData -> MyData -> Bool) -> IO ()
p f = print $ op f

main :: IO ()
main = do
  p (==)
  p (/=)
  p (<)
  p (<=)

lesson/src/Lib.hs

module Lib where

data MyData = A | B | C | D | E deriving (Show, Enum)

instance Eq MyData where
  (==) a b = fromEnum a == fromEnum b

instance Ord MyData where
  compare a b = compare (fromEnum a) (fromEnum b)

入出力結果(Terminal, Zsh)

% stack build
lesson> build (lib + exe)
Preprocessing library for lesson-0.1.0.0..
Building library for lesson-0.1.0.0..
Preprocessing executable 'lesson-exe' for lesson-0.1.0.0..
Building executable 'lesson-exe' for lesson-0.1.0.0..
[2 of 2] Compiling Main
Linking .stack-work/dist/x86_64-osx/Cabal-3.4.1.0/build/lesson-exe/lesson-exe ...
lesson> copy/register
Installing library in /Users/…/lesson/.stack-work/install/x86_64-osx/11bee7f1432551708036aee298c43f57d1e8b1a145053e7d2d3b07e2f4ae638f/9.0.2/lib/x86_64-osx-ghc-9.0.2/lesson-0.1.0.0-CIOIkpTgcfQI9akDJnwnSd
Installing executable lesson-exe in /Users/…/lesson/.stack-work/install/x86_64-osx/11bee7f1432551708036aee298c43f57d1e8b1a145053e7d2d3b07e2f4ae638f/9.0.2/bin
Registering library for lesson-0.1.0.0..
% stack exec lesson-exe
[True,False,False,False,False,False,True,False,False,False,False,False,True,False,False,False,False,False,True,False,False,False,False,False,True]
[False,True,True,True,True,True,False,True,True,True,True,True,False,True,True,True,True,True,False,True,True,True,True,True,False]
[False,True,True,True,True,False,False,True,True,True,False,False,False,True,True,False,False,False,False,True,False,False,False,False,False]
[True,True,True,True,True,False,True,True,True,True,False,False,True,True,True,False,False,False,True,True,False,False,False,False,True]
%