功能编程 – 在函数式编程中是否还有任何代数结构,而不是单一的?

栏目: 编程语言 · 发布时间: 7年前

内容简介:http://stackoverflow.com/questions/3331287/is-there-any-algebraic-structures-used-in-functional-programming-other-then-mono

我最近知道函数式编程(在Haskell和Scala中).它的功能和优雅是相当迷人.

但是当我遇到一个名叫Monoid的代数结构的Monads时,我很惊讶,很高兴看到我从数学中学到的理论知识在编程中得到了应用.

这个观察在我的脑海中引起了一个问题:组织,领域或环(参见 Algebraic Structures 为其他人)可以在编程中用于更多的抽象和代码重用目的,并实现数学相似的编程?

我知道,这个名为 Fortress 的语言(当编译器完成时,我一定会喜欢任何语言一次)在库代码中定义了这些结构.但是目前为止,我看到的仅仅是我们已经熟悉的数字类型.他们会有其他用途吗?

最好的祝福,

ciun

您可以建模许多结构.这是一个组:

class Group a where
    mult :: a -> a -> a
    identity :: a
    inverse :: a -> a

instance Group Integer where
    mult = (+)
    identity = 0
    inverse = negate

-- S_3 (group of all bijections of a 3-element set)
data S3 = ABC | ACB | BAC | BCA | CAB | CBA
instance Group S3 where
    mult ABC x = x
    ... -- some boring code
    identity = ABC
    inverse ABC = ABC
    ... -- remaining cases

-- Operations on groups. Dual:
data Dual a = Dual { getDual :: a }
instance Group a => Group (Dual a) where
    mult (Dual x) (Dual y) = Dual (mult y x)
    identity = Dual identity
    inverse (Dual x) = Dual (inverse x)

-- Product:
instance (Group a, Group b) => Group (a,b) where
    mult (x,y) (z,t) = (x `mult` z, y `mult` t)
    identity = (identity, identity)
    inverse (x,y) = (inverse x, inverse y)

现在,您可以编写多(双CAB,5)(双CBA,1)并获得结果.这将是组S3 *⨯Z中的计算.您可以添加其他组,以任何可能的方式组合它们,并与它们进行计算.

类似的事情可以通过环,字段,排序,向量空间,类别等来完成.Haskell的数字层次结构不幸的是被模仿,但是有一个 numeric prelude 尝试修复它.还有 DoCon 把它带到极限.对于类型课程(主要由类别理论推动),有 Typeclassopedia 具有大量示例和应用程序.

http://stackoverflow.com/questions/3331287/is-there-any-algebraic-structures-used-in-functional-programming-other-then-mono


以上所述就是小编给大家介绍的《功能编程 – 在函数式编程中是否还有任何代数结构,而不是单一的?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

六度分隔

六度分隔

邓肯·J·瓦茨 / 陈禹 / 中国人民大学出版社 / 2011-3 / 46.00元

正如副标题所表明的,《六度分隔:一个相互连接的时代的科学》的基本内容是介绍一门正在形成中的新科学——关于网络的一般规律的科学。有这样一门科学吗?它的内容和方法是什么?近年来,这门学科有什么实质性的进展吗?在《六度分隔:一个相互连接的时代的科学》中,作者根据自己的亲身经历娓娓道来,用讲故事的方式,对于这些问题给出了令人信服的回答 除了简要的背景和总结以外,《六度分隔:一个相互连接的时代的科学》......一起来看看 《六度分隔》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具