A buffer represents a combination of a item and location.
It is the entity for keeping modeling inventory.
More...
#include <model.h>
Public Types | |
typedef Association< Operation, Buffer, Flow >::ListB | flowlist |
typedef TimeLine< FlowPlan > | flowplanlist |
Public Member Functions | |
virtual void | beginElement (XMLInput &, const Attribute &) |
Buffer (const string &str) | |
void | deleteOperationPlans (bool deleteLockedOpplans=false) |
virtual void | endElement (XMLInput &, const Attribute &, const DataElement &) |
size_t | extrasize () const |
Flow * | findFlow (const Operation *o, Date d) const |
virtual void | followPegging (PeggingIterator &, FlowPlan *, short, double, double) |
virtual PyObject * | getattro (const Attribute &) |
double | getCarryingCost () const |
flowplanlist & | getFlowPlans () |
const flowplanlist & | getFlowPlans () const |
const flowlist & | getFlows () const |
bool | getHidden () const |
Item * | getItem () const |
Location * | getLocation () const |
CalendarDouble * | getMaximum () const |
CalendarDouble * | getMinimum () const |
double | getOnHand (Date, Date, bool min=true) const |
double | getOnHand (Date d=Date::infinitePast) const |
Operation * | getProducingOperation () const |
virtual const MetaClass & | getType () const |
virtual int | setattro (const Attribute &, const PythonObject &) |
void | setCarryingCost (const double c) |
void | setHidden (bool b) |
void | setItem (Item *i) |
void | setLocation (Location *i) |
void | setMaximum (CalendarDouble *) |
void | setMinimum (CalendarDouble *) |
void | setOnHand (double f) |
void | setProducingOperation (Operation *o) |
virtual void | solve (Solver &s, void *v=NULL) const |
virtual void | updateProblems () |
virtual void | writeElement (XMLOutput *, const Keyword &, mode=DEFAULT) const |
virtual | ~Buffer () |
Static Public Member Functions | |
static int | initialize () |
Static Public Attributes | |
static const MetaCategory * | metadata |
Friends | |
class | Flow |
class | FlowPlan |
A buffer represents a combination of a item and location.
It is the entity for keeping modeling inventory.
Definition at line 2851 of file model.h.
typedef Association<Operation,Buffer,Flow>::ListB frepple::Buffer::flowlist |
frepple::Buffer::Buffer | ( | const string & | str | ) | [inline, explicit] |
frepple::Buffer::~Buffer | ( | ) | [virtual] |
Destructor.
Definition at line 441 of file buffer.cpp.
Called while restoring the model from an XML-file.
This is called for each element within the "this" element, for which the "this" element is immediate parent.
It is called when the open element tag is encountered.
Reimplemented from frepple::utils::HasHierarchy< Buffer >.
Definition at line 266 of file buffer.cpp.
void frepple::Buffer::deleteOperationPlans | ( | bool | deleteLockedOpplans = false |
) |
Deletes all operationplans consuming from or producing from this buffer. The boolean parameter controls whether we delete also locked operationplans or not.
Definition at line 430 of file buffer.cpp.
void frepple::Buffer::endElement | ( | XMLInput & | pIn, | |
const Attribute & | pAttr, | |||
const DataElement & | pElement | |||
) | [virtual] |
Reimplemented from frepple::Plannable.
Reimplemented in frepple::BufferProcure.
Definition at line 291 of file buffer.cpp.
size_t frepple::Buffer::extrasize | ( | ) | const [inline] |
Returns the memory size in bytes.
Reimplemented from frepple::utils::HasDescription.
void frepple::Buffer::followPegging | ( | PeggingIterator & | iter, | |
FlowPlan * | curflowplan, | |||
short | nextlevel, | |||
double | curqty, | |||
double | curfactor | |||
) | [virtual] |
This function matches producing and consuming operationplans with each other, and updates the pegging iterator accordingly.
Definition at line 459 of file buffer.cpp.
PyObject * frepple::Buffer::getattro | ( | const Attribute & | attr | ) | [virtual] |
Default getattro method.
Subclasses are expected to implement an override if the type supports gettattro.
Reimplemented from frepple::utils::PythonExtensionBase.
Reimplemented in frepple::BufferProcure.
Definition at line 709 of file buffer.cpp.
double frepple::Buffer::getCarryingCost | ( | ) | const [inline] |
flowplanlist& frepple::Buffer::getFlowPlans | ( | ) | [inline] |
const flowplanlist& frepple::Buffer::getFlowPlans | ( | ) | const [inline] |
const flowlist& frepple::Buffer::getFlows | ( | ) | const [inline] |
bool frepple::Buffer::getHidden | ( | ) | const [inline, virtual] |
Returns whether an entity is real or dummy.
Reimplemented from frepple::utils::Object.
Item* frepple::Buffer::getItem | ( | ) | const [inline] |
Location* frepple::Buffer::getLocation | ( | ) | const [inline] |
CalendarDouble* frepple::Buffer::getMaximum | ( | ) | const [inline] |
CalendarDouble* frepple::Buffer::getMinimum | ( | ) | const [inline] |
Returns minimum or maximum available material on hand in the given daterange. The third parameter specifies whether we return the minimum (which is the default) or the maximum value. The computation is INclusive the start and end dates.
Definition at line 164 of file buffer.cpp.
double frepple::Buffer::getOnHand | ( | Date | d = Date::infinitePast |
) | const |
Returns the available material on hand immediately after the given date.
Definition at line 146 of file buffer.cpp.
Operation* frepple::Buffer::getProducingOperation | ( | ) | const [inline] |
virtual const MetaClass& frepple::Buffer::getType | ( | ) | const [inline, virtual] |
This returns the type information on the object, a bit similar to the standard type_info information.
Implements frepple::utils::Object.
Reimplemented in frepple::BufferDefault, frepple::BufferInfinite, and frepple::BufferProcure.
int frepple::Buffer::initialize | ( | ) | [static] |
Initialize the class.
Reimplemented in frepple::BufferDefault, frepple::BufferInfinite, and frepple::BufferProcure.
Definition at line 49 of file buffer.cpp.
int frepple::Buffer::setattro | ( | const Attribute & | attr, | |
const PythonObject & | field | |||
) | [virtual] |
Default setattro method.
Subclasses are expected to implement an override if the type supports settattro.
Reimplemented from frepple::utils::PythonExtensionBase.
Reimplemented in frepple::BufferProcure.
Definition at line 752 of file buffer.cpp.
void frepple::Buffer::setCarryingCost | ( | const double | c | ) | [inline] |
void frepple::Buffer::setHidden | ( | bool | b | ) | [inline, virtual] |
Mark the object as hidden or not. Hidden objects are not exported and are used only as dummy constructs.
Reimplemented from frepple::utils::Object.
void frepple::Buffer::setItem | ( | Item * | i | ) | [inline] |
void frepple::Buffer::setLocation | ( | Location * | i | ) | [inline] |
void frepple::Buffer::setMaximum | ( | CalendarDouble * | cal | ) |
Updates the minimum inventory target for the buffer.
Definition at line 392 of file buffer.cpp.
void frepple::Buffer::setMinimum | ( | CalendarDouble * | cal | ) |
Updates the minimum inventory target for the buffer.
Definition at line 354 of file buffer.cpp.
void frepple::Buffer::setOnHand | ( | double | f | ) |
Update the on-hand inventory at the start of the planning horizon.
Definition at line 98 of file buffer.cpp.
void frepple::Buffer::setProducingOperation | ( | Operation * | o | ) | [inline] |
virtual void frepple::Buffer::solve | ( | Solver & | s, | |
void * | v = NULL | |||
) | const [inline, virtual] |
This method is called by solver classes. The implementation of this class simply calls the solve method on the solver class. Using the polymorphism the solver can implement seperate methods for different plannable subclasses.
Reimplemented from frepple::Solvable.
Reimplemented in frepple::BufferInfinite, and frepple::BufferProcure.
void frepple::Buffer::updateProblems | ( | ) | [virtual] |
Called to update the list of problems. The function will only be called when:
Implements frepple::HasProblems.
Definition at line 35 of file problems_buffer.cpp.
void frepple::Buffer::writeElement | ( | XMLOutput * | o, | |
const Keyword & | tag, | |||
mode | m = DEFAULT | |||
) | const [virtual] |
Reimplemented from frepple::Plannable.
Reimplemented in frepple::BufferInfinite, and frepple::BufferProcure.
Definition at line 209 of file buffer.cpp.
const MetaCategory * frepple::Buffer::metadata [static] |
Reimplemented in frepple::BufferDefault, frepple::BufferInfinite, and frepple::BufferProcure.