我尝试拍摄Image PixelRGB8并将其转换为矩阵,在矩阵上进行一些卷积。第一次尝试我想将其转换为矩阵并将矩阵转换回图像。
我收到此错误:
• No instance for (Element Word8)
arising from a use of ‘matrixToImg’
• In the expression: matrixToImg $ imgToMatrix img
In an equation for ‘convImg’:
convImg img = matrixToImg $ imgToMatrix img
Failed, modules loaded: none.
这是什么意思?
这是代码。
import Codec.Picture
import Data.Matrix
import Data.Vector
import Data.Vector.Storable
import Debug.Trace
import GHC.Word
import Numeric.LinearAlgebra.Data
import Numeric.LinearAlgebra
convImg ::Image PixelRGB8 -> Image PixelRGB8
convImg img = matrixToImg $ imgToMatrix img
imgToMatrix ::Image PixelRGB8->Numeric.LinearAlgebra.Matrix Word8
imgToMatrix Image { imageWidth = w, imageHeight = h, imageData = vec } = ((3*w)><h) ( Data.Vector.Storable.toList vec)
matrixToImg::Numeric.LinearAlgebra.Matrix Word8-> Image PixelRGB8
matrixToImg matrix = Image (rows matrix `quot` 3) (cols matrix) (vectorToStorableVector (Numeric.LinearAlgebra.Data.flatten(matrix)))
where vectorToStorableVector vec= Data.Vector.Storable.fromList $ Numeric.LinearAlgebra.Data.toList vec
感谢。
答案 0 :(得分:1)
hmatrix
Element
的实例数量有限,Word8
不是其中之一。它使用的简单Integral
类型是type Z = Int64
。如果你记住Matrix Int64
所持有的是道德Word8
s,那么可以进行如下的转换。 (这与您在一些地方放置fromIntegral
的内容相同。)
import Codec.Picture
import Data.Vector
import Data.Vector.Storable
import Debug.Trace
import GHC.Word
import Numeric.LinearAlgebra.Data
import Numeric.LinearAlgebra
convImg ::Image PixelRGB8 -> Image PixelRGB8
convImg img = matrixToImg $ imgToMatrix img
imgToMatrix ::Image PixelRGB8 -> Numeric.LinearAlgebra.Matrix Z
imgToMatrix Image { imageWidth = w, imageHeight = h, imageData = vec } = ((3*w)><h) ( Data.Vector.Storable.toList $ (Data.Vector.Storable.map fromIntegral) (vec))
matrixToImg::Numeric.LinearAlgebra.Matrix Z -> Image PixelRGB8
matrixToImg matrix = Image (rows matrix `quot` 3) (cols matrix) (vectorToStorableVector (Numeric.LinearAlgebra.Data.flatten(matrix)))
where vectorToStorableVector =
Data.Vector.Storable.fromList . Prelude.map fromIntegral . Numeric.LinearAlgebra.Data.toList