Sha256: 440b35aa31caef5516f91142ef8c3ad02d27a090088ab14b6096423ae9d22279

Contents?: true

Size: 1.53 KB

Versions: 1

Compression:

Stored size: 1.53 KB

Contents

require 'spec_helper'

describe Dydx:Function do
  before(:each) do
    reset
  end

  it 'ex1' do
    expect(f(x, y)).to eq(f(x, y))
    expect(f(x, y)).to eq($f)
    expect(f(x, y).algebra).to be_nil
    expect(f(x, y).vars).to eq([:x, :y])
    expect{f(x, y, z)}.to raise_error(ArgumentError)
    expect{f(x)}.to raise_error(ArgumentError)
  end

  it 'ex2' do
    expect(f(x, y) <= x * y ).to eq(f(x, y))
    expect(f(x, y)).to eq(f(x, y))
    expect(f(x, y)).to eq($f)
    expect(f(x, y).algebra).to eq(x * y)
    expect(f(x, y)).to eq(x * y)
    expect(f(x, y)).to eq(eval(f(x, y).to_s))
    expect(f(a, b)).to eq(a * b)
    expect(f(2, x)).to eq(2 * x)
    expect(f(2, 3)).to eq(6)
    expect(f(a + b, c)).to eq((a + b) * c)
    expect(d/dx(f(x, y))).to eq(y)
    expect(d/dy(f(x, y))).to eq(x)
    expect(d/dz(f(x, y))).to eq(0)
  end

  it 'ex3' do
    f(x, y) <= x * y
    g(a, b) <= f(a + b, b)
    expect(g(a, b)).to eq((a + b) * b)
    expect(g(a, 3)).to eq(9 + 3 * a)
    expect(g(2, 3)).to eq(15)
  end

  it 'ex4' do
    f(a, b) <= (a + b) * b
    h(a, b, c) <= d/db(f(a, b))
    expect(h(a, b, c)).to eq(( a + ( 2 * b ) ))
    expect(h(a, b, c).algebra).to eq(( a + ( 2 * b ) ))
  end

  it 'ex5' do
    f(x) <= log(x)
    expect(f(e)).to eq(1)
    expect(f(0)).to eq(-oo)
    expect(f(y)).to eq(log(y))

    g(x) <= d/dx(f(x))
    expect(g(1)).to eq(1)
  end

  it 'ex6' do
    f(x) <= sin(x)
    expect(f(pi)).to eq(0)
    expect(f(pi / 2)).to eq(1)
    expect(f(y)).to eq(sin(y))

    g(x) <= d/dx(f(x))
    expect(g(pi)).to eq(-1)
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
dydx-0.1.314 spec/lib/function_spec.rb