高阶函数

  • 将函数作为参数
  • 例如
    •  def sum_naturals(n):
      total, k = 0, 1
      while k <= n:
      total, k = total + k, k + 1
      return total
      def sum_cubes(n):
      total, k = 0, 1
      while k <= n:
      total, k = total + k*k*k, k + 1
      return total
      def pi_sum(n):
      total, k = 0, 1
      while k <= n:
      total, k = total + 8 / ((4*k-3) * (4*k-1)), k + 1
      return total
    • 以上三个例子中有许多共同的部分
      • def <name>(n):
        total, k = 0, 1
        while k <= n:
        total, k = total + <term>(k), k + 1
        return total
    • 高阶函数形式
    • def summation(n, term):
      total, k = 0, 1
      while k <= n:
      total, k = total + term(k), k + 1
      return total def cube(x):
      return x*x*x def sum_cubes(x):
      return summation(x,cube)
    • 函数环境
    • 黄金比例
    • def improve(update, close, guess=1):
      while not close(guess):
      guess = update(guess)
      return guess def golden_update(guess):
      return 1/guess + 1 def square_close_to_successor(guess):
      return approx_eq(guess * guess, guess + 1) def approx_eq(x, y, tolerance=1e-15):
      return abs(x - y) < tolerance improve(golden_update, square_close_to_successor)
  • 高阶函数的不足
    • 在全局环境中名称复杂
    • 每一个函数的形参个数是由限制的

函数的嵌套定义

  • 解决高阶函数存在的不足
  • def sqrt(a):
    def sqrt_update(x):
    return average(x, a/x)
    def sqrt_close(x):
    return approx_eq(x * x, a)
    return improve(sqrt_update, sqrt_close)
  • 嵌套定义中的函数作用域
    • 每一个嵌套的函数在定义函数内环境
    • #不是函数的调用处
  • 函数作用域的实现方法
    • 每一个函数都有他的父环境
    • 当函数被调用时,在其父环境中评估
  • 函数作用域的好处
    • 局部环境中的绑定不会影响全局环境
  • def square(x):
    return x * x def successor(x):
    return x + 1 def compose1(f,g):
    def h(x):
    return f(g(x))
    return h square_successor = compose1(square,successor)
    result = square_successor(12)

牛顿法

  • def newton_update(f, df):
    def update(x):
    return x - f(x) / df(x)
    return update def find_zero(f, df):
    def near_zero(x):
    return approx_eq(f(x), 0)
    return improve(newton_update(f, df), near_zero) def square_root_newton(a):
    def f(x):
    return x * x - a
    def df(x):
    return 2 * x
    return find_zero(f, df)

Currying

  • >>> def curried_pow(x):
    def h(y):
    return pow(x, y)
    return h
    >>> curried_pow(2)(3)
    8
    def curry2(f):
    """Return a curried version of the given two-argument function."""
    def g(x):
    def h(y):
    return f(x, y)
    return h
    return g
    def uncurry2(g):
    """Return a two-argument version of the given curried function."""
    def f(x, y):
    return g(x)(y)
    return f
  • 环境图

匿名函数

  • 可以看做

    •        lambda            x            :          f(g(x))
      "A function that takes x and returns f(g(x))"

函数装饰器

  • >>> def trace(fn):
    def wrapped(x):
    print('-> ', fn, '(', x, ')')
    return fn(x)
    return wrapped
    >>> @trace
    def triple(x):
    return 3 * x
    >>> triple(12)
    -> <function triple at 0x102a39848> ( 12 )
    36
    • @trace等同于
    • >>> def triple(x):
      return 3 * x
      >>> triple = trace(triple)

SICP-1.6-高阶函数的更多相关文章

  1. 【SICP归纳】2 高阶函数和数据抽象

    上一篇博文相应的是书中的第一章的一二两节,我们已经大致的有了一种构造的感觉不是么. 书中展示了非常多有趣的句法(syntax). 如今我们要让思想进一步的抽象.写这篇博客的时候并未学完整本书.更不敢说 ...

  2. c#语言-高阶函数

    介绍 如果说函数是程序中的基本模块,代码段,那高阶函数就是函数的高阶(级)版本,其基本定义如下: 函数自身接受一个或多个函数作为输入. 函数自身能输出一个函数,即函数生产函数. 满足其中一个条件就可以 ...

  3. swift 的高阶函数的使用代码

    //: Playground - noun: a place where people can play import UIKit var str = "Hello, playground& ...

  4. JavaScript高阶函数

    所谓高阶函数(higher-order function) 就是操作函数的函数,它接收一个或多个函数作为参数,并返回一个新函数. 下面的例子接收两个函数f()和g(),并返回一个新的函数用以计算f(g ...

  5. python--函数式编程 (高阶函数(map , reduce ,filter,sorted),匿名函数(lambda))

    1.1函数式编程 面向过程编程:我们通过把大段代码拆成函数,通过一层一层的函数,可以把复杂的任务分解成简单的任务,这种一步一步的分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. ...

  6. python学习道路(day4note)(函数,形参实参位置参数匿名参数,匿名函数,高阶函数,镶嵌函数)

    1.函数 2种编程方法 关键词面向对象:华山派 --->> 类----->class面向过程:少林派 -->> 过程--->def 函数式编程:逍遥派 --> ...

  7. Scala的函数,高阶函数,隐式转换

    1.介绍 2.函数值复制给变量 3.案例 在前面的博客中,可以看到这个案例,关于函数的讲解的位置,缺省. 4.简单的匿名函数 5.将函数做为参数传递给另一个函数 6.函数作为输出值 7.类型推断 8. ...

  8. Python之路 day3 高阶函数

    #!/usr/bin/env python # -*- coding:utf-8 -*- #Author:ersa """ 变量可以指向函数,函数的参数能接收变量, 那么 ...

  9. JavaScript高阶函数 map reduce filter sort

    本文是笔者在看廖雪峰老师JavaScript教程时的个人总结 高阶函数            一个函数就接收另一个函数作为参数,这种函数就称之为高阶函数          1.高阶函数之map:   ...

  10. js高阶函数

    我是一个对js还不是很精通的选手: 关于高阶函数详细的解释 一个高阶函数需要满足的条件(任选其一即可) 1:函数可以作为参数被传递 2:函数可以作为返回值输出 吧函数作为参数传递,这代表我们可以抽离一 ...

随机推荐

  1. Python实现RNN

    一般的前馈神经网络中, 输出的结果只与当前输入有关与历史状态无关, 而递归神经网络(Recurrent Neural Network, RNN)神经元的历史输出参与下一次预测. 本文中我们将尝试使用R ...

  2. ShadowBroker释放的NSA工具中Esteemaudit漏洞复现过程

    没有时间测试呢,朋友们都成功复现,放上网盘地址:https://github.com/x0rz/EQGRP 近日臭名昭著的方程式组织工具包再次被公开,TheShadowBrokers在steemit. ...

  3. 《安卓网络编程》之第八篇 安卓与服务器之间通讯JSON

    JSON是什么? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于JavaScript(Standard ECMA-262 3rd Edition ...

  4. html学习笔记 - meta link

    <!DOCTYPE html> <html lang="en"> <head> <!-- 编码格式 --> <meta cha ...

  5. java 上传3(uploadify中文api)

    jquery文件上传控件 Uploadify 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同时上传,上传进行进度显示,删除已上传文件. 要求使用jquery1.4或以上版本,fla ...

  6. size_t类型

    size_t在C语言中就有了.它是一种“整型”类型,里面保存的是一个整数,就像int, long那样.这种整数用来记录一个大小(size).size_t的全称应该是size type,就是说“一种用来 ...

  7. Spark踩坑记——从RDD看集群调度

    [TOC] 前言 在Spark的使用中,性能的调优配置过程中,查阅了很多资料,之前自己总结过两篇小博文Spark踩坑记--初试和Spark踩坑记--数据库(Hbase+Mysql),第一篇概况的归纳了 ...

  8. markdown 基础语法

    markdown 基础 你好,我是markdown文档 介绍 Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容具有一定的格式. 说的简单一点,mar ...

  9. 部署项目到weblogic时提示文件被锁,导致报错

    部署项目到weblogic中出现一个“黄叹号!”.报错如下: (1) Deployment is out of date due to changes in the underlying projec ...

  10. [asp.net mvc 奇淫巧技] 04 - 你真的会用Action的模型绑定吗?

    在QQ群或者一些程序的交流平台,经常会有人问:我怎么传一个数组在Action中接收.我传的数组为什么Action的model中接收不到.或者我在ajax的data中设置了一些数组,为什么后台还是接收不 ...