,就决定在博客里加个围棋js程序。...于是,申请了博客的js权限,美化美化我的博客。 好在js的语法像C系的,看了看,写个程序应该还是可以的。 ...围棋里,设计好基本的数据结构: //a是19X19数组,用来存放围棋,每个位置0为空,1为黑,2为白 //b是检测禁手、提子时临时使用 var a = new Array(19); var b = new...围棋的规则也没什么问题,我有篇文章(《围棋规则的计算机实现》)里专门讲围棋的规则可以看成是一个连通图遍历,如此可以判断有没有气,从而禁手、提子、打劫,乃至后面点掉死子、数子计算胜负都可以归结于连通图遍历...只是最开始的时候对js不熟,不知道怎么处理字符到整形,强迫症也没犯。
总时间限制: 1000ms内存限制: 65536kB描述围棋的棋盘上有19*19条线交织成的361个交点,黑棋和白棋可以下在交点上。我们称这些交点为“目”。...不用考虑某些棋子按照围棋规则实际上是死的,以及互相吃(打劫),双活等情况。
从 1 月底开始,PhoenixGo 以 BensonDarr(昵称「金毛」)的名义在腾讯野狐围棋平台上和全球顶尖职业棋手、围棋爱好者及各路围棋 AI 对弈,在 4 月底取得了 200 多连胜,并在福州...为了让行业内其他研究者可以在此基础上继续探索围棋 AI 的奥秘,帮助棋手更方便地研究围棋 AI 的棋路,也为了众多围棋爱好者在家用普通电脑上可以享受和职业九段交锋的乐趣,微信团队决定对外开源 PhoenixGo...对弈源码和训练模型。...经过了一周多时间的筹备,PhoenixGo 目前正式开源了对弈源码和一个 20 block 的模型。...这份源码和模型可以在单块 GPU 上提供强职业棋手的棋力,在单机多卡和多机多卡的系统上具有远超人类棋手的水平。
近日浙江乌镇的 AlphaGo 人机围棋大战打的轰轰烈烈,AlphaGo 背后的蒙特卡罗树搜索算法也炒得沸沸扬扬。今天我们介绍几个跟围棋(Go)有关的 Wolfram 演示项目。...围棋起源于中国,迄今已有数千年历史,传说为 "尧帝" 所发明,在春秋战国时已有记载。后来,"琴棋书画" 被称为中国古代的 "四艺",其中的 "棋",就指围棋。...到了现代,围棋依然是重要的中国文化符号之一,也被认为是世界上 "最复杂的棋艺"。...如果你没有安装 Mathematica,可以去官网下载免费的 CDF Player(https://www.wolfram.com/cdf-player/)来玩这个围棋游戏。...(http://demonstrations.wolfram.com/OverlappingGoGames/) 小编在网上看到大家有讨论三维围棋和球面围棋,如果你们有源代码,也欢迎与我们共享噢!
Phoenix Go是微信翻译团队开发的人工智能围棋,算是“绝艺”的小弟,它们两个都出自腾讯,可谓“同根生”。...这只金毛在野狐围棋上名气越来越大,直到世界人工智能围棋大赛在今年4月20日公布参赛阵容时候,它的身份首次公开:就是“绝艺”的自家兄弟PhoenixGo。...在世界人工智能围棋大赛半决赛,PhoenixGo和绝艺分别顺利击败Leela Zero和天算围棋,令决赛成为腾讯两兄弟的对决。...“星阵”战胜柯洁,国产AI围棋崛起 中国作为围棋的发源地,在AlphaGo诞生后的几年里也成为主要的AI围棋源头之一。...不久前,“绝艺”还成为中国围棋国家队的训练工具。 在PhoenixGo战胜绝艺的同一个赛场上,另一家国产AI围棋“星阵”战胜了柯洁。
Node.js 进程启动时,首先执行 c / c++ 代码,然后 c / c++ 加载并执行 lib/internal/bootstrap_node.js 并给予一个 process 参数( 运行上下文...) // lib/internal/bootstrap_node.js 概览 // Hello, and welcome to hacking node.js!...exports: 默认值是 {} loaded / loading: NativeModule 状态 _cache: 简单的模块缓存 _source: 模块源码资源 require():...(),源码如下: // bootstrap main module....至此 启动-js部分 已经全部完成,后续模块加载部分,见 Node.js源码解析-require背后 End 启动只是 Node.js 源码的一小部分,除此之外还有大量的内置模块和 c / c++ 源码
在Google上搜索时,我发现了impress.js的存在,与我的设想不谋而合,于是乎……不再自己造轮子,又花了两天时间熟悉使用impress.js来设计幻灯片,效果完全超越了我的预期。 ...impress.js简单来说仅仅是实现了幻灯片的转场特效的框架,虽说将单页限制在框架之内,但所有单页还是需要自己用代码设计。...花了一天探索了下impress.js源码,其实并不复杂,个人感觉收获颇丰,以下阐述我的收获。.../impress.js"> impress().init(); 源码中的init()函数,分析写在注释中 var init = function(...源码简洁明了,并不复杂,作者的本意也是构建一个基础的框架,让使用者自由发挥,正合吾意!
watch.js 源码解读 用麻雀虽小五脏俱全来描述Watch.js比较合适。“观察者”模式是我们在开发的时候经常需要用到的。...使用Watch.js那么我们就可以实现在“每当对象属性改变的时候,执行你的函数”。...虽然有很多其他的库可以实现相同的功能,但是Watch.js却可以不改变你平时书写代码的方式,并且实现属性改变的监听功能。...”修改的时候“观察者”函数会被调用 ex1.attr1 = "other value";` [try demo](http://jsfiddle.net/NbJuh/17/) Watch.js...总结 抛开watch.js的bug不谈,它还是有很多可圈可点的地方。
手写源码 手写源码才是本文的重点,前面的不过是铺垫,本文手写的目标就是自己写一个express来替换前面用到的express api,其实就是源码解析。...本文所有手写代码全部参照官方源码写成,方法名和变量名尽量与官方保持一致,大家可以对照着看,写到具体的方法时我也会贴出官方源码的地址。...express.js对应的源码看这里:github.com/expressjs/e… app.listen 上面说了,express.js只是一个空壳,真正的app在application.js里面,所以..._router = new Router(); } } 复制代码 app.listen,app.handle和methods处理方法都在application.js里面,application.js...[method] 所以我们来看下Router这个类,下面的代码是从源码中简化出来的: // router/index.js var setPrototypeOf = require('setprototypeof
第二篇文章是看了Express的基本用法,更主要的是看了下他的源码:手写Express.js源码 Express的源码还是比较复杂的,自带了路由处理和静态资源支持等等功能,功能比较全面。...从上面两个例子的代码来看,Koa跟Express有几个明显的区别: ctx替代了req和res 可以使用JS的新API了,比如async和await 手写源码 手写源码前我们看看用到了哪些API,这些就是我们手写的目标...lib/application.js这个文件就是我们经常用的Koa类,虽然我们经常叫他Koa类,但是在源码里面这个类叫做Application。...app.createContext对应的官方源码看这里:github.com/koajs/koa/b… context.js 上面的this.context其实就是来自context.js,所以我们先在...Express源码可以看我之前这篇文章:手写Express.js源码 Koa的思路看起来更清晰,Koa本身的库只是一个内核,只有中间件功能,来的请求会依次经过每一个中间件,然后再出来返回给请求者,这就是大家经常听说的
在看 jQuery 源码时,发现了这段注释: //源码5235行 /* * Helper functions for managing events -- not part of the public...Edwards' addEvent library for many of the ideas. */ jQuery.event = { } Dean Edwards 的 addEvent.js...(http://dean.edwards.name/weblog/2005/10/add-event/)库为 jQuery 的事件绑定提供了很多想法,我们就来看下 2005 年的 addEvent.js...console.log(a,'a55') //{0:'111'} b 改变属性,a 也会改变,因为 b 与 a 指向同一地址(b=a) 一、addEvent() 作用: 为目标元素绑定事件(如 click) 源码...最后: 完整代码请看https://github.com/AttackXiaoJinJin/jQueryExplain/blob/master/addEvent.js.html ----
谈到围棋AI,你是否首先想到了AlphaGo?可惜随着AlphaGo的退役,AlphaGo横扫人类棋手的几盘对局成为最后绝唱,也给人们留下悬念,围棋AI到底能进化到何种程度?...现在绝艺已经成为中国围棋队年轻棋手非常重要的训练工具,许多围棋讲解也会搬出绝艺作为助手。...最近,Facebook的人工智能研究所(FAIR)宣布开源自研的围棋AI训练模型和代码,名为ELF OpenGo。...和我们想象的不同,ELF OpenGo不使用人类棋谱与累积的围棋知识,仅使用单一类神经网络从自我对弈中学习,可以说是一位“自学成才”的围棋天才。...普通人无需了解任何人工智能知识,也能用上围棋AI。你懂的,由于不可描述的因素,这个程序需要访问外国网站才能下载。
对,就是看别人写的JS代码。文档嘛,自然是没有的。 之前也有试过看代码,但项目中N多JS文件,每个JS文件上千行,一行一行的看下来,用不了几分钟就完全晕掉了。...于是,这一次,我决定换一个方式读JS源码。 这个项目中有N个JS文件,我把入口的JS文件拿出来先看,然后我把它里面所有的函数名,都用思维导图写出来,就像这样, ?...看小说一行行看就OK,但读源码的重点,不在于要读完并理解每一行JS代码,而在于通过图表和笔记,理解系统的结构和它们之间的关系。...实际上这也是不可能的,每个大项目中上百个JS文件,每个JS文件上千行、几千行代码,这算起来就十万多行了,哪有时间让你慢慢看完。...推广来说,看项目源码,看前端各种构架的源码,它最大的好处就是可以培养自己的对于代码的“层次感”。
3.isArguments、isFunction、isString、isNumber、isDate、isRegExp、isError这些方法放到一起讲,因为这些方法的的源码实现都是放到了一个each函数中遍历每一个方法名然后实现的布尔值判定...源码: _.each(['Arguments', 'Function', 'String', 'Number', 'Date', 'RegExp', 'Error'], function(name) {...需要注意的是js数组和函数是对象,字符串和数字不是。...bb6dc3cabae6651b94f69bbd562ff370/page/2.html https://github.com/hanzichi/underscore-analysis/blob/master/underscore-1.8.3.js.../underscore-1.8.3-analysis.js http://www.css88.com/doc/underscore/#isEmpty http://www.css88.com/doc
一、前言 avalon.js的影响力愈发强劲,而作为子模块之一的mmDeferred必然成为异步调用模式学习之旅的又一站呢!...三、源码剖析 首先要了解的是mmDeferred中存在Deferred和Promise两个操作集合(两者操作同一个的数据结构实例),Promise...利用JS中变量声明自动提升(hoist)的特性,通过前置return语句将对外接口与具体实现的代码分离。 2....下面是源码 define("mmDeferred", ["avalon"], function(avalon) { var noop = function() { } function...} Deferred.nextTick = avalon.nextTick return Deferred }) 四、总结 源码中还提供了相关资料的链接
Vue.js 的源码都在 src 目录下,其目录结构如下: src ├── compiler # 编译相关 ├── core # 核心代码 ├── platforms...Vue.js 四、server Vue.js 2.0 支持了服务端渲染,所有服务端渲染相关的逻辑都在这个目录下 ?...注意:这部分代码是跑在服务端的 Node.js,不要和跑在浏览器端的 Vue.js 混为一谈 服务端渲染主要的工作是把组件渲染为服务器端的 HTML 字符串,将它们直接发送到浏览器,最后将静态标记"混合...这个目录下的代码逻辑会把 .vue 文件内容解析成一个 JavaScript 的对象 六、shared Vue.js 会定义一些工具方法,这里定义的工具方法都是会被浏览器端的 Vue.js 和服务端的...Vue.js 所共享的 ?
Hyperapp 是最近热度颇高的一款迷你 JS 框架,其源码不到 400 行,压缩 gzip 后只有 1kB,却具有相当高的完成度,拿来实现简单的 web 应用也不在话下。...源码解析 回到源码上来,由于 Hyperapp 所有的操作都在 app 函数中完成,下面就来探究一下 app 函数都做了什么。...该函数主流程相当简单,源码总计十来行,先贴在下面,后面慢慢分析: export function app(state, actions, view, container) { var map = [...我们看一下源码: function scheduleRender() { if (!...在研究其源码前,我们先看一下 Hyperapp 对 actions 中的方法制定的规范,当 state 中无嵌套对象时,总结起来大致是以下几条: 必须是一元函数(只接受一个参数) 函数返回值必须是以下几种
并且当你看过官网(http://cho45.stfuawsc.com/jsdeferred/)的新手引导后就会有种不好好学学就太可惜的感觉了,而只看API和使用指南是无法满足我对它的好奇心的,通过解读源码读透它的设计思想才是根本...本文部分内容将和《JS魔法堂:剖析源码理解Promises/A》中的内容作对比来讲解。 ..._next; }; 《JS魔法堂:剖析源码理解Promises/A》中的官网实现示例是将事件处理函数绑定到当前的Promise实例,而不是新创的Promise实例。...1000); d.canceller = function () { clearTimeout(id) }; return d; }; 刚看到该函数时我确实有点小鸡冻,我们可以将《JS...魔法堂:剖析源码理解Promises/A》的第三节“从感性领悟”下的示例,写得于现实生活的思路更贴近了。
renderEngine.renderer; //定义一个shader对象 const shader = { //名字必须字段 name: "xxx", //着色器代码中需要与js...,今天分享的内容是ShaderHelper组件中的核心CustomMaterial源码分析。...Effect的实例化 ---- texture与color的初始化比较简,但Eeffect实例化需要三个参数,看下引擎源码: //--------------CustomMaterail.js----...techniques是一个数组,我们接下来看CustomMaterial源码中是怎么创建它的。 4....小结 ---- 本篇的内容有些烧脑,特别是对于像Shawn这种从来不怎么关心底层渲染的人来说在初次读源码完全是一脸的蒙逼。我们暂且不纠结细节,从整体上理清材质系统的框架结构,请看下图: ?
领取专属 10元无门槛券
手把手带您无忧上云