关于thenao.scan() fn函数参数的说明

theano.scan()原型为:

theano.scan(         fn,         sequences=None,         outputs_info=None,        non_sequences=None,         n_steps=None,
        truncate_gradient=-1,         go_backwards=False,        mode=None,        name=None,         profile=False,         allow_gc=None,         strict=False       )

fn:一个函数,要求scan的每一个步骤都需要执行这个函数,可以有多个参数,对应于scan其他几个参数,例,如下调用:

scan(fn,    sequences = [ dict(input= Sequence1, taps = [-3,2,-1]),            Sequence2,            dict(input = Sequence3, taps = 3) ],
    outputs_info = [ dict(initial = Output1, taps = [-3,-5]),               dict(initial = Output2, taps = None),               Output3 ],    non_sequences = [ Argument1, Argument2])

fn函数的参数列表为如下顺序, t表示当前迭代:

1. Sequence1[t-3]
2. Sequence1[t+2]
3. Sequence1[t-1]
4. Sequence2[t]
5. Sequence3[t+3]
6. Output1[t-3]
7. Output1[t-5]
8. Output3[t-1]
9. Argument1
10. Argument2

时间: 2024-10-27 18:19:23

关于thenao.scan() fn函数参数的说明的相关文章

jstl标签 core fmt fn函数使用参考(为第一篇的补充,更为实用)

JSTL标签 参考手册 前言 ========================================================================= JSTL标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实. JSTL全名为JavaServer Pages Standard Tag Library,目前最新的版本为1.1版.JSTL是由J

函数和函数参数

函数 函数是对程序逻辑进行结构化或过程化的一直编程方法.能将整块代码巧妙的隔离成易于管理的小块,把重复代码放到函数中而不是进行大量的拷贝--这样既能节省空间,也有助于保持一致性,因为你只需要改变单个的拷贝而无须去寻找再修改大量复制代码的拷贝. 创建函数 def语句 函数是用def语句来创建的,语法如下: def function_name(params): pass In [1]: def add(x,y): ...: print('{} + {} = {}'.format(x,y,x+y))

JavaScript进阶系列01,函数的声明,函数参数,函数闭包

本篇主要体验JavaScript函数的声明.函数参数以及函数闭包. □ 函数的声明 ※ 声明全局函数 通常这样声明函数: function doSth() { alert("可以在任何时候调用我"); } 通过这种方式声明的函数属于Window对象,可以在任何地方调用,即在doSth方法的之前和之后都可以调用. 可以在doSth方法之前调用: doSth(); function doSth() { alert("可以在任何时候调用我"); } 可以在doSth方法之

JavaScript进阶系列04,函数参数个数不确定情况下的解决方案

本篇主要体验函数参数个数不确定情况下的一个解决方案.先来看一段使用函数作为参数进行计算的实例. var calculate = function(x, y, fn) { return fn(x, y); }; var sum = function(x, y) { return x + y; }; var diff = function(x, y) { return x - y; }; var sumResult = calculate(1, 2, sum), diffResult = calcu

EL表达式中fn函数

JSTL 使用表达式来简化页面的代码,这对一些标准的方法,例如bean的getter/setter方法,请求参数或者context以及 session中的数据的访问非常方便,但是我们在实际应用中经常需要在页面调用对象的某些方法,例如我需要调用字符串的length方法来获取字符串的 长度时,在以往的开发过程中我们必须把对象先转为String类,然后在调用其length方法,这样的代码繁琐而且容易出错. 因此JSTL内置了几个用于字符串操作的方法,可以直接在表达式中使用,大大的简化了代码,提供代码的

自定义jstl fn函数fns

1.引入函数声明: jsp页面需要引入自定义fns函数声明: <%@ taglib prefix="fns" uri="/WEB-INF/tlds/fns.tld" %> (自定义的tld文件位于/WEB-INF/tlds/fns.tld) 一般需要C标签配合使用,同时引入C标签声明: <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"

EL表达式中fn函数 (转载)

JSTL 使用表达式来简化页面的代码,这对一些标准的方法,例如bean的getter/setter方法,请求参数或者context以及 session中的数据的访问非常方便,但是我们在实际应用中经常需要在页面调用对象的某些方法,例如我需要调用字符串的length方法来获取字符串的 长度时,在以往的开发过程中我们必须把对象先转为String类,然后在调用其length方法,这样的代码繁琐而且容易出错. 因此JSTL内置了几个用于字符串操作的方法,可以直接在表达式中使用,大大的简化了代码,提供代码的

查找函数参数名称

function argumentNames(fn){ //查找参数列表 var found = /^[\s\(]*function[^(]*\(\s*([^)]*?)\s*\)/.exec(fn.toString()); //分隔参数列表 return found && found[1] ? found[1].split(/,\s*/) : []; }; alert(argumentNames(function(){}).length === 0); alert(argumentName

javascript遍历数组,针对数组中每一个元素执行fn函数,并将数组索引和元素作为参数传递

遍历主要有两种方法,i++方法和in关键词法 var list = [1, 2, 3, 4, 5, 6,7,8]; //var l = list.length; for(var i in list) { console.log(list[i]); } //[Finished in 0.3s] var list = [1, 2, 3, 4, 5, 6,7,8]; //var l = list.length; for(var i = 0; i < list.length; i++) { consol