【编程思想】【设计模式】【其他模式】blackboard
Python版
https://github.com/faif/python-patterns/blob/master/other/blackboard.py
#!/usr/bin/env python
# -*- coding: utf-8 -*- """
@author: Eugene Duboviy <eugene.dubovoy@gmail.com> | github.com/duboviy In Blackboard pattern several specialised sub-systems (knowledge sources)
assemble their knowledge to build a possibly partial or approximate solution.
In this way, the sub-systems work together to solve the problem,
where the solution is the sum of its parts. https://en.wikipedia.org/wiki/Blackboard_system
""" import abc
import random class Blackboard(object): def __init__(self):
self.experts = []
self.common_state = {
'problems': 0,
'suggestions': 0,
'contributions': [],
'progress': 0 # percentage, if 100 -> task is finished
} def add_expert(self, expert):
self.experts.append(expert) class Controller(object): def __init__(self, blackboard):
self.blackboard = blackboard def run_loop(self):
while self.blackboard.common_state['progress'] < 100:
for expert in self.blackboard.experts:
if expert.is_eager_to_contribute:
expert.contribute()
return self.blackboard.common_state['contributions'] class AbstractExpert(object): __metaclass__ = abc.ABCMeta def __init__(self, blackboard):
self.blackboard = blackboard @abc.abstractproperty
def is_eager_to_contribute(self):
raise NotImplementedError('Must provide implementation in subclass.') @abc.abstractmethod
def contribute(self):
raise NotImplementedError('Must provide implementation in subclass.') class Student(AbstractExpert): @property
def is_eager_to_contribute(self):
return True def contribute(self):
self.blackboard.common_state['problems'] += random.randint(1, 10)
self.blackboard.common_state['suggestions'] += random.randint(1, 10)
self.blackboard.common_state['contributions'] += [self.__class__.__name__]
self.blackboard.common_state['progress'] += random.randint(1, 2) class Scientist(AbstractExpert): @property
def is_eager_to_contribute(self):
return random.randint(0, 1) def contribute(self):
self.blackboard.common_state['problems'] += random.randint(10, 20)
self.blackboard.common_state['suggestions'] += random.randint(10, 20)
self.blackboard.common_state['contributions'] += [self.__class__.__name__]
self.blackboard.common_state['progress'] += random.randint(10, 30) class Professor(AbstractExpert): @property
def is_eager_to_contribute(self):
return True if self.blackboard.common_state['problems'] > 100 else False def contribute(self):
self.blackboard.common_state['problems'] += random.randint(1, 2)
self.blackboard.common_state['suggestions'] += random.randint(10, 20)
self.blackboard.common_state['contributions'] += [self.__class__.__name__]
self.blackboard.common_state['progress'] += random.randint(10, 100) if __name__ == '__main__':
blackboard = Blackboard() blackboard.add_expert(Student(blackboard))
blackboard.add_expert(Scientist(blackboard))
blackboard.add_expert(Professor(blackboard)) c = Controller(blackboard)
contributions = c.run_loop() from pprint import pprint
pprint(contributions) ### OUTPUT ###
# ['Student',
# 'Student',
# 'Scientist',
# 'Student',
# 'Scientist',
# 'Student',
# 'Scientist',
# 'Student',
# 'Scientist',
# 'Student',
# 'Scientist',
# 'Professor']
Python转载版
【编程思想】【设计模式】【其他模式】blackboard的更多相关文章
- 面向对象编程思想(前传)--你必须知道的javascript
在写面向对象编程思想-设计模式中的js部分的时候发现很多基础知识不了解的话,是很难真正理解和读懂js面向对象的代码.为此,在这里先快速补上.然后继续我们的面向对象编程思想-设计模式. 什么是鸭子类型 ...
- 面向对象编程思想(前传)--你必须知道的javascript(转载)
原文地址:http://www.cnblogs.com/zhaopei/p/6623460.html阅读目录 什么是鸭子类型 javascript的面向对象 封装 继承 多态 原型 this指向 ...
- Java编程思想重点笔记(Java开发必看)
Java编程思想重点笔记(Java开发必看) Java编程思想,Java学习必读经典,不管是初学者还是大牛都值得一读,这里总结书中的重点知识,这些知识不仅经常出现在各大知名公司的笔试面试过程中,而 ...
- PHP设计模式-策略模式 转
策略模式(Strategy Pattern) 策略模式是对象的行为模式,用意是对一组算法的封装.动态的选择需要的算法并使用. 策略模式指的是程序中涉及决策控制的一种模式.策略模式功能非常强大,因为这个 ...
- .NET设计模式: 工厂模式
.NET设计模式: 工厂模式(转) 转自:http://www.cnblogs.com/bit-sand/archive/2008/01/25/1053207.html .NET设计模式(1): ...
- 面向对象编程思想(OOP)
本文我将从面向对象编程思想是如何解决软件开发中各种疑难问题的角度,来讲述我们面向对象编程思想的理解,梳理面向对象四大基本特性.七大设计原则和23种设计模式之间的关系. 软件开发中疑难问题: 软件复杂庞 ...
- java编程思想
Java编程思想,Java学习必读经典,不管是初学者还是大牛都值得一读,这里总结书中的重点知识,这些知识不仅经常出现在各大知名公司的笔试面试过程中,而且在大型项目开发中也是常用的知识,既有简单的概念理 ...
- 设计模式 --迭代器模式(Iterator)
能够游走于聚合内的每一个元素,同时还可以提供多种不同的遍历方式. 基本概念: 就是提供一种方法顺序访问一个聚合对象中的各个元素,而不是暴露其内部的表示. 使用迭代器模式的优点: 遍历集合或者数 ...
- Java编程思想总结笔记The first chapter
总觉得书中太啰嗦,看完总结后方便日后回忆,本想偷懒网上找别人的总结,无奈找不到好的,只好自食其力,尽量总结得最好. 第一章 对象导论 看到对象导论觉得这本书 目录: 1.1 抽象过程1.2 每个对象 ...
- javascript设计模式——组合模式
前面的话 在程序设计中,有一些和“事物是由相似的子事物构成”类似的思想.组合模式就是用小的子对象来构建更大的对象,而这些小的子对象本身也许是由更小的“孙对象”构成的.本文将详细介绍组合模式 宏命令 宏 ...
随机推荐
- SpringBoot热部署(7)
1.引入热部署依赖包 <dependency> <groupId>org.springframework.boot</groupId> <artifactId ...
- 在线编辑Word——插入图表
在Word中可插入图表,配合使用表格能够更加全方位的展示数据的可信度并增加数据的可读性.本文将通过使用在线编辑器 Spire.Cloud Word 演示如何来插入图表,并设置相关格式化操作.具体步骤如 ...
- Linux Mem (目录)
1.用户态相关: 1.1.用户态进程空间的创建 - execve() 详解 1.2.用户态进程空间的映射 - mmap()详解 1.3.分页寻址(Paging/MMU)机制详解 2.内核态相关: 2. ...
- mysql-5.7.30安装
1.由于在线安装受制于网络环境,所以选择tar包编译安装. 首先去mysql镜像站下载mysql-5.7.30-linux-glibc2.5-x86_64.tar.gz2.上传到linux服 ...
- codeql初探
CodeQL初探 环境搭建 基于Windows 基于Mac 下载codeql https://github.com/github/codeql-cli-binaries/releases/latest ...
- 【JAVA】编程(1)---计算器
作业要求: 制作一个简易计算器,支持加,减,乘,除,取余五则运算:支持小数运算:一次运行支持无限次运算:可以人为控制程序的结束: import java.util.*; public class 计算 ...
- Java学习(二十)
今天学习了Java中的package和import 在包中写了一点作为练习 如果把Test02放到别的包,就需要import到别的包,就像这样,Test02在HelloWorld包 如果删掉impor ...
- React-Router示例(重定向与withRouter)
1.withRouter作用:把不是通过路由切换过来的组件中,将react-router 的 history.location.match 三个对象传入props对象上 默认情况下必须是经过路由匹 ...
- Linux基础四:软件包管理
四.软件包管理器: 1.概念 红帽有两款软件包管理器,分别是rpm和yum. 1.rpm软件包管理器 -> 用来安装单个包 -> .rpm文件 红帽的安装包文件,都放在Packag ...
- [loj6118]鬼牌
枚举最终所有牌的大小$i$,对于最终所有牌大小都为$i$的情况,令其贡献为步数,否则令其贡献为0,记$F$为期望贡献(即所有情况概率*贡献之和),答案即为$\sum_{i=1}^{m}F$ 显然,$F ...