使用 JavaScript 编写优化算法 (1)
之前一直用Python来写优化算法,为了增强 JS 的熟练程度,开始将原有的代码改写成 JS。采用的工具包括 node.js + Grunt + nodeunit + github + npm + travis-ci。
最初的版本采用过程式的方式实现,没有采用面向对象或事件驱动的模式。
#!/usr/bin/env node --harmony
// Random Search
"use strict";
var util = require("util");
function objective_function(v) {
return v.map(function(x) {
return x*x;
}).reduce(function(a, b) {
return a+b;
});
}
function random_vector(min_max) {
return min_max.map(function(x) {
return x[0] + (x[1] - x[0]) * Math.random();
});
}
function search(search_space, max_iteration) {
var best = {};
for (var iteration = 0; iteration < max_iteration; iteration++) {
var candidate = {
'vector': random_vector(search_space)
};
candidate['cost'] = objective_function(candidate['vector']);
//console.log(candidate);
if (iteration === 0 || candidate['cost'] < best['cost']) {
best = candidate;
}
console.log(' > iteration=' + (iteration+1) + ', best=' + best['cost']);
}
return best;
}
function generate_array(element, repeat) {
return new Array(repeat+1).join(1).split('').map(function(){return element;});
}
function run () {
var problem_size = 2;
var search_space = generate_array([-5, 5], problem_size);
var max_iteration = 100;
var best = search(search_space, max_iteration);
console.log("Done. Best Solution: " + util.inspect(best));
}
exports.objective_function = objective_function;
exports.random_vector = random_vector;
exports.generate_array = generate_array;
exports.search = search;
exports.run = run;
调用方式很简单。
var rs = require('clever_algorithms_js').random_search;
rs.run();
单元测试:
var random_search = require('../../lib/stochastic/random_search');
exports['objective'] = function (test) {
test.equal(random_search.objective_function([1, 2]), 5);
test.done();
};
exports['random_vector'] = function (test) {
var rv = random_search.random_vector([[1, 2], [2, 3]]);
test.equal(rv.length, 2);
test.ok(1 <= rv[0] && rv[0] <= 2);
test.ok(2 <= rv[1] && rv[1] <= 3);
test.done();
};
exports['generate_array'] = function (test) {
var a = random_search.generate_array([-5, 5], 2);
test.equal(a.length, 2);
test.deepEqual(a, [[-5,5], [-5,5]]);
test.done();
};
exports['search'] = function (test) {
var problem_size = 2,
search_space = random_search.generate_array([-5, 5], problem_size),
max_iter = 100;
var best = random_search.search(search_space, max_iter);
test.notEqual(best, {});
test.ok(-5 <= best['cost'] && best['cost'] <= 5);
test.done();
};
如果采用CoffeeScript进行改写的话,代码会更简洁一些:
# Random Search
util = require("util");
objective_function = (v) ->
v.reduce (x,y) -> x*x + y*y
random_vector = (min_max) ->
min_max.map (rx) -> rx[0] + (rx[1] - rx[0]) * Math.random()
generate_array = (element, repeat) ->
(element for [1..repeat])
search = (search_space, max_iteration) ->
best = {}
for iteration in [0..max_iteration-1]
candidate = {
'vector': random_vector(search_space)
}
candidate['cost'] = objective_function(candidate['vector'])
best = candidate if iteration == 0 || candidate['cost'] < best['cost']
console.log ' > iteration=' + (iteration+1) + ' best=' + best['cost'];
best
run = () ->
problem_size = 2
search_space = generate_array([-5, 5], problem_size)
max_iteration = 100
best = search(search_space, max_iteration)
console.log "Done. Best Solution: " + util.inspect(best);
return
exports.objective_function = objective_function;
exports.random_vector = random_vector;
exports.generate_array = generate_array;
exports.search = search;
exports.run = run;
编译出的JavaScript代码,看起来是这个样子:
(function() {
var generate_array, objective_function, random_vector, run, search, util;
util = require("util");
objective_function = function(v) {
return v.reduce(function(x, y) {
return x * x + y * y;
});
};
random_vector = function(min_max) {
return min_max.map(function(rx) {
return rx[0] + (rx[1] - rx[0]) * Math.random();
});
};
generate_array = function(element, repeat) {
var _i, _results;
_results = [];
for (_i = 1; 1 <= repeat ? _i <= repeat : _i >= repeat; 1 <= repeat ? _i++ : _i--) {
_results.push(element);
}
return _results;
};
search = function(search_space, max_iteration) {
var best, candidate, iteration, _i, _ref;
best = {};
for (iteration = _i = 0, _ref = max_iteration - 1; 0 <= _ref ? _i <= _ref : _i >= _ref; iteration = 0 <= _ref ? ++_i : --_i) {
candidate = {
'vector': random_vector(search_space)
};
candidate['cost'] = objective_function(candidate['vector']);
if (iteration === 0 || candidate['cost'] < best['cost']) {
best = candidate;
}
console.log(' > iteration=' + (iteration + 1) + ' best=' + best['cost']);
}
return best;
};
run = function() {
var best, max_iteration, problem_size, search_space;
problem_size = 2;
search_space = generate_array([-5, 5], problem_size);
max_iteration = 100;
best = search(search_space, max_iteration);
console.log("Done. Best Solution: " + util.inspect(best));
};
exports.objective_function = objective_function;
exports.random_vector = random_vector;
exports.generate_array = generate_array;
exports.search = search;
exports.run = run;
}).call(this);
[1] https://www.npmjs.org/package/clever_algorithms_js
[2] https://github.com/fox000002/clever_algorithms_js
使用 JavaScript 编写优化算法 (1)的更多相关文章
- 使用Golang编写优化算法 (1)
动手写点东西是学习新知识很重要的一个阶段.之前用 Python 和 JavaScript 实现优化算法,现在用 Golang 来实现.语法上略有不爽,某些C语言的思维又回来了. - Golang 用 ...
- JavaScript是如何工作的02:深入V8引擎&编写优化代码的5个技巧
概述 JavaScript引擎是执行 JavaScript 代码的程序或解释器.JavaScript引擎可以实现为标准解释器,或者以某种形式将JavaScript编译为字节码的即时编译器. 以为实现J ...
- JavaScript工作机制:V8 引擎内部机制及如何编写优化代码的5个诀窍
概述 JavaScript引擎是一个执行JavaScript代码的程序或解释器.JavaScript引擎可以被实现为标准解释器,或者实现为以某种形式将JavaScript编译为字节码的即时编译器. 下 ...
- JavaScript内存优化
JavaScript内存优化 相对C/C++ 而言,我们所用的JavaScript 在内存这一方面的处理已经让我们在开发中更注重业务逻辑的编写.但是随着业务的不断复杂化,单页面应用.移动HTML5 应 ...
- 前端开发周报: CSS 布局方式方式与JavaScript数据结构和算法
前端开发周报:CSS 布局方式与JavaScript动画库 1.常见 CSS 布局方式详见: 一些常见的 CSS 布局方式梳理,涉及 Flex 布局.Grid 布局.圣杯布局.双飞翼布局等.http: ...
- JavaScript性能优化篇js优化
JavaScript性能优化篇js优化 随着Ajax越来越普遍,Ajax引用的规模越来越大,Javascript代码的性能越来越显得重要,我想这就是一个很典型的例子,上面那段代码因为会被频繁使用, ...
- javascript数据结构与算法---列表
javascript数据结构与算法---列表 前言:在日常生活中,人们经常要使用列表,比如我们有时候要去购物时,为了购物时东西要买全,我们可以在去之前,列下要买的东西,这就要用的列表了,或者我们小时候 ...
- 摘:JavaScript性能优化小知识总结
原文地址:http://www.codeceo.com/article/javascript-performance-tips.html JavaScript的性能问题不容小觑,这就需要我们开发人员在 ...
- artDialog是一个基于javascript编写的对话框组件,它拥有精致的界面与友好的接口
artDialog是一个基于javascript编写的对话框组件,它拥有精致的界面与友好的接口 自适应内容 artDialog的特殊UI框架能够适应内容变化,甚至连外部程序动态插入的内容它仍然能自适应 ...
随机推荐
- HGOI NOIP模拟4 题解
NOIP国庆模拟赛Day5 题解 T1 马里奥 题目描述 马里奥将要参加 NOIP 了,他现在在一片大陆上,这个大陆上有着许多浮空岛,并且其中一座浮空岛上有一个传送门,马里奥想要到达传送门从而前往 N ...
- 【bzoj4012】 HNOI2015—开店
http://www.lydsy.com/JudgeOnline/problem.php?id=4012 (题目链接) 题意 一棵树,每条边有正边权,每个点的点权非负.若干组询问,强制在线,每次查询点 ...
- 各种蕴含算法思想的DP - 1
study from: https://www.cnblogs.com/flashhu/p/9480669.html 1.前缀和 https://www.luogu.org/problemnew/sh ...
- Tomcat权威指南-读书摘要系列7
配置 conf目录下的主要配置文件 server.xml Tomcat主配置文件 web.xml servlet与其他适用于整个Web应用程序设置的配置文件,必须符合servlet规范的标准格式 to ...
- python教程1:Python基础之数据类型和变量、字符串和编码
视频链接:http://www.bilibili.com/video/av10730372/ 我是在Linux下玩python的,Linux下默认安装python,直接打个pyhon3就好了,pyth ...
- Java大话设计模式
设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...
- Linux命令(三)远程登录
- alloffthelights使用方法
官网上的demo没有用,因为官网用的jquery是谷歌的CDN,download下来的demo也没有用,因为demo的路径下少了jquery.所以自己写demo的时候要把jquery和alloffth ...
- .NET面试题系列(三)排序算法
冒泡排序 , , , , , 7, 2, 4 }; //外层循环控制排序趟数 ; i < arr.Length - ; i++) { //内层循环控制每一趟排序多少次 ; j < arr. ...
- jQuery下ajax事件的简单分析
昨天写了一篇关于监视页面动态生成元素问题的文章,引起了一些小小的争议,不过我从中学到了很多.文章在这,<jQuery下实现等待指定元素加载完毕>当然 动态生成的节点元素 分很多种情况,这里 ...