Haskell数据类型错误PBMfile

时间:2012-05-01 21:06:43

标签: image haskell rgb ppm

我正在做作业并发生错误

我必须做一个关于现在描述的数据类型的函数

data RGBdata= RGB Int Int Int
data PBMfile= PBM Int Int [[RGBdata]]

他的节目功能

instance Show RGBdata where
 show (RGB r g b) = (show r)++" "++(show g)++" "++(show b)

instance Show PBMfile where
 show (PBM width height l) = "P3\n"++(show width)++" "++(show height)++"\n255\n"++(foldr (++) "" (map myshow l))

myshow [] = "\n"
myshow (h:t) = (show h)++" "++(myshow t)

他的加载和应用功能

cargarPBM name = readFile name >>= return . rLines . lines
rLines (_:x:_:xs)= (\[a,b]->(PBM (read a) (read b) (rLines' (read a) (concat $map words xs)))) $ words x 
rLines' _ []= []
rLines' a x= (rLine (take (a*3) x): rLines' a (drop (a*3) x))
rLine []= []
rLine (r:g:b:xs)= ((RGB (read r) (read g) (read b)):rLine xs)

aplicar funcion origen destino= cargarPBM origen >>= writeFile destino . show . funcion

当我尝试执行某项功能时,例如

negative :: PBMfile -> [Int] 
negative PBM x y z = [1,2,3]

拥抱错误

ERROR file:.\haha.hs:32 - Constructor "PBM" must have exactly 3 arguments in pattern

但PBM x y z不是3个参数?我做错了什么?

2 个答案:

答案 0 :(得分:2)

您的函数定义negative PBM x y z正在尝试对4个参数进行模式匹配,第一个参数是PBM数据构造函数。要实际模式匹配数据构造函数及其参数,您应该对它们进行分组,即negative (PBM x y z) = ...。您问题中的show定义是正确执行此操作的示例。

如需进一步阅读,请尝试http://en.wikibooks.org/wiki/Haskell/Pattern_matching#The_connection_with_constructors

答案 1 :(得分:1)

你需要括号,

negative :: PBMfile -> [Int] 
negative (PBM x y z) = [1,2,3]

否则将其解析为negative的四个参数。