/** * Copyright (C) 2009 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.analytics.financial.model.finitedifference; import org.apache.commons.lang.Validate; import com.opengamma.analytics.math.function.Function1D; /** * Neumann boundary condition, i.e. du/dx(A,t) = f(t), where A is the boundary level, and f(t) is some specified function of time */ public class NeumannBoundaryCondition implements BoundaryCondition { private final Function1D<Double, Double> _timeValue; private final double _level; private final boolean _isLower; /** * Neumann boundary condition, i.e. du/dx(A,t) = f(t), where A is the boundary level, and f(t) is some specified function of time * @param timeValue The value of u at the boundary, i.e. du/dx(A,t) = f(t) * @param level The boundary level (A) * @param isLower True if this represents a lower boundary */ public NeumannBoundaryCondition(final Function1D<Double, Double> timeValue, final double level, final boolean isLower) { Validate.notNull(timeValue, "null timeValue"); _timeValue = timeValue; _level = level; _isLower = isLower; } public NeumannBoundaryCondition(final double fixedValue, final double level, final boolean isLower) { _timeValue = new Function1D<Double, Double>() { @Override public Double evaluate(Double x) { return fixedValue; } }; _level = level; _isLower = isLower; } @Override public double getConstant(final ConvectionDiffusionPDE1DStandardCoefficients data, final double t) { return _timeValue.evaluate(t); } @Override public double[] getLeftMatrixCondition(ConvectionDiffusionPDE1DStandardCoefficients data, PDEGrid1D grid, double t) { double[] temp; if (_isLower) { temp = grid.getFirstDerivativeForwardCoefficients(0); } else { temp = grid.getFirstDerivativeBackwardCoefficients(grid.getNumSpaceNodes() - 1); } return temp; } @Override public double getLevel() { return _level; } @Override public double[] getRightMatrixCondition(ConvectionDiffusionPDE1DStandardCoefficients data, PDEGrid1D grid, double t) { return new double[0]; } }