javascript rails 编程

本文提供了一系列JavaScript函数示例,包括map、select、reject等方法的实现,展示了如何通过这些函数进行数组处理,例如筛选偶数、查找唯一元素等。此外还介绍了如何使用Underscore.js库来增强JavaScript的功能。
 function map(ls,func){
var d=[];
for(var i=0;i<ls.length;i++){
d.push(func.call(this,ls[i]))
}
return d;
}
map([1,2,3],function(n){return n+1})
[2, 3, 4]



function select(ls,func){
var d=[];
for(var i=0;i<ls.length;i++){
if(func.call(this,ls[i]))
d.push(ls[i])
}
return d;
}
select([1,2,3],function(n){return n%2==0;})
2





function reject(ls,func){
var d=[];
for(var i=0;i<ls.length;i++){
if(!func.call(this,ls[i])){d.push(ls[i])}
}
return d;
}
reject([1,2,3,4,5,6],function(n){ return n%2==0})




function any(ls,func){
for(var i=0;i<ls.length;i++){
if(func.call(this,ls[i]))
return true
}
return false;
}
function truth(n){ if(n){return true}else{return false}}

any([1,0,1],truth)
true



function all(ls,func){       
for(var i=0;i<ls.length;i++){
if(!func.call(this,ls[i]))
return false;
}
return true;
}
function truth(n){ if(n){return true}else{return false}}
all([1,0,1],truth)




function max(ls,func){
var d = ls.sort(func);console.log(d); return d[0];
}
max([1,2,3,4,5,6],function(s1,s2){ if(s1.age <= s2.age){return -1}else{return 1} })

function min(ls,func){
var d = ls.sort(func);console.log(d); return d[0];
}
min([1,2,3,4,5,6],function(s1,s2){ if(s1.age > s2.age){return -1}else{return 1} })




function uniq(ls){    
var d =[];var r=[];
for(var i=0;i<ls.length;i++){ d[ls[i]] = ls[i];}
for(var field in d){r.push(d[field])};
return r;
}
uniq([1,2,3,4,5,6,1])

[1, 2, 3, 4, 5, 6]




function range(start,end,step)
{
if(arguments.length==1){end=start;start=1;step=1;}
if(!step){step=1};
var r=[];
for(var i=start;i<=end;i=i+step){r.push(i)} return r;
}
range(10)
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
range(1,10)
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
range(2,10)
[2, 3, 4, 5, 6, 7, 8, 9, 10]





function fib(n){ return n<2 ? n : arguments.callee(n-1) + arguments.callee(n-2) }




function delay(func,time,args){console.log(args);
setTimeout(function(args){
return ( function(){func.apply(this,args)} )()}
,time)};
delay(function(n){alert("yes "+n)},1000,10);





bind = function(func, obj) {
return function() {
return func.apply(obj, arguments);
};
};



当然之前写的rails 风格的代码以及有人实现,名叫 Underscore.js,
感兴趣的人可以看看
[url]http://documentcloud.github.com/underscore[/url]

其中有几个经典的用法

var fibonacci = function(n) {
return n < 2 ? n : fibonacci(n - 1) + fibonacci(n - 2);
};
var fastFibonacci = _.memoize(fibonacci);


_.mixin({
capitalize : function(string) {
return string.charAt(0).toUpperCase() + string.substring(1).toLowerCase();
}
});
_("fabio").capitalize();
=> "Fabio"


var compiled = _.template("hello: <%= name %>");
compiled({name : 'moe'});
=> "hello: moe"

var list = "<% _.each(people, function(name) { %> <li><%= name %></li> <% }); %>";
_.template(list, {people : ['moe', 'curly', 'larry']});
=> "<li>moe</li><li>curly</li><li>larry</li>"
【RIS 辅助的 THz 混合场波束斜视下的信道估计与定位】在混合场波束斜视效应下,利用太赫兹超大可重构智能表面感知用户信道与位置(Matlab代码实现)内容概要:本文围绕“IS 辅助的 THz 混合场波束斜视下的信道估计与定位”展开,重点研究在太赫兹(THz)通信系统中,由于混合近场与远场共存导致的波束斜视效应下,如何利用超大可重构智能表面(RIS)实现对用户信道状态信息和位置的联合感知与精确估计。文中提出了一种基于RIS调控的信道参数估计算法,通过优化RIS相移矩阵提升信道分辨率,并结合信号到达角(AoA)、到达时间(ToA)等信息实现高精度定位。该方法在Matlab平台上进行了仿真验证,复现了SCI一区论文的核心成果,展示了其在下一代高频通信系统中的应用潜力。; 适合人群:具备通信工程、信号处理或电子信息相关背景,熟悉Matlab仿真,从事太赫兹通信、智能反射面或无线定位方向研究的研究生、科研人员及工程师。; 使用场景及目标:① 理解太赫兹通信中混合场域波束斜视问题的成因与影响;② 掌握基于RIS的信道估计与用户定位联合实现的技术路径;③ 学习并复现高水平SCI论文中的算法设计与仿真方法,支撑学术研究或工程原型开发; 阅读建议:此资源以Matlab代码实现为核心,强调理论与实践结合,建议读者在理解波束成形、信道建模和参数估计算法的基础上,动手运行和调试代码,深入掌握RIS在高频通信感知一体化中的关键技术细节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值