在#haskell@freenode中使用lambdabot

IRC可不只是闲聊的地方,她是你随时可用的好工具。IRC中有很多Bot可以随时为你服务。这里只收集了在#haskell@freenode中使用的lambdabot。(为了不影响别人,你最好发私信: /msg lambdabot ...)

查hoogle:

ERC> @hoogle applicative

<lambdabot> Control.Applicative class Functor f => Applicative f
<lambdabot> Control.Applicative module Control.Applicative
<lambdabot> package applicative-extras


查类型:

ERC> @type (<*>)

<lambdabot> Applicative f => f (a -> b) -> f a -> f b


运算:

ERC> > map ((&&) <$> (>3) <*> (<5)) [1..9]

<lambdabot> [False,False,False,True,False,False,False,False,False]


ERC> @let a...b = [a..b]
<lambdabot> Defined.
> 1...20
<lambdabot> [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20]


大家知道do是语法糖,可用@undo还原:

ERC> @undo do { Just y <- x; z }

<lambdabot> x >>= \ a -> case a of { Just y -> z; _ -> fail ""}


查实例:

@instances Monad
<lambdabot> ArrowMonad a, ContT r m, ErrorT e m, IO, Maybe, RWST r w s m,
ReaderT r m, ST s, StateT s m, WriterT w m, []


查源码:

ERC> @src (<$>)

<lambdabot> f <$> a = fmap f a

ERC> @src foldr
<lambdabot> foldr f z [] = z
<lambdabot> foldr f z (x:xs) = f x (foldr f z xs)

ERC> @src foldl
<lambdabot> foldl f z [] = z
<lambdabot> foldl f z (x:xs) = foldl f (f z x) xs

ERC> @src Monad
<lambdabot> class Monad m where
<lambdabot> (>>=) :: forall a b. m a -> (a -> m b) -> m b
<lambdabot> (>>) :: forall a b. m a -> m b -> m b
<lambdabot> return :: a -> m a
<lambdabot> fail :: String -> m a

ERC> @source Data.List
<lambdabot> http://darcs.haskell.org/packages/base/Data/List.hs


看看是否有现成函数:
ERC> @pl fn op g k a = g a `op` k a
<lambdabot> fn = liftM2

fn 其实就是 liftM2 。 liftM2 是专门用来把二元函数提升到 Monad 中去的,而 ((->) a) 正是 Monad 的实例。


Djinn通过type signature构造函数: 

@djinn (a, b) -> c -> (b, c) ==> f (_, a) b = (a, b) 


查一个monad transformer包装的类型:

@unmtl StateT s IO a ==> s -> IO (a, s)


查网址:

ERC> @where lyah
<lambdabot> http://www.learnyouahaskell.com/

ERC> @where rwh
<lambdabot> http://www.realworldhaskell.org/blog/
  http://book.realworldhaskell.org/read/

ERC> @where wikibook
<lambdabot> http://en.wikibooks.org/wiki/Haskell

ERC> @where hackage
<lambdabot> <http://hackage.haskell.org/package/>

ERC> @where hackage-mirror
<lambdabot> remote-repo:
    hdiff.luite.com:http://hdiff.luite.com/packages/archive/

ERC> @where xmonad

<lambdabot> http://xmonad.org/


查软件包:

@hackage repa
<lambdabot> http://hackage.haskell.org/package/repa


查单词:

ERC> @wn applicative

<lambdabot> *** "applicative" wn "WordNet (r) 3.0 (2006)" [13:46]
<lambdabot> applicative
<lambdabot> adj 1: readily applicable or practical [syn: {applicative},
<lambdabot> {applicatory}]


【SCI复现】含可再生能源与储能的区域微电网最优运行:应对不确定性的解鲁棒性与非预见性研究(Matlab代码实现)内容概要:本文围绕含可再生能源与储能的区域微电网最优运行展开研究,重点探讨应对不确定性的解鲁棒性与非预见性策略,通过Matlab代码实现SCI论文复现。研究涵盖多阶段鲁棒调度模型、机会约束规划、需求响应机制及储能系统优化配置,结合风电、光伏等可再生能源出力的不确定性建模,提出兼顾系统经济性与鲁棒性的优化运行方案。文中详细展示了模型构建、算法设计(如C&CG算法、大M法)及仿真验证全过程,适用于微电网能量管理、电力系统优化调度等领域的科研与工程实践。; 适合人群:具备一定电力系统、优化理论和Matlab编程基础的研究生、科研人员及从事微电网、能源管理相关工作的工程技术人员。; 使用场景及目标:①复现SCI级微电网鲁棒优化研究成果,掌握应对风光负荷不确定性的建模与求解方法;②深入理解两阶段鲁棒优化、分布鲁棒优化、机会约束规划等先进优化方法在能源系统中的实际应用;③为撰写高水平学术论文或开展相关课题研究提供代码参考和技术支持。; 阅读建议:建议读者结合文档提供的Matlab代码逐模块学习,重点关注不确定性建模、鲁棒优化模型构建与求解流程,并尝试在不同场景下调试与扩展代码,以深化对微电网优化运行机制的理解。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值