Inventory management of goods is an integral part of logistics systems; common to various economic sectors such as industry, agriculture and trade; and independent of production volume. In general, as companies seek to minimize economic losses, studies on problems of multi-agent inventory have increased in recent years. A multi-agent inventory problem is a situation in which several agents face individual inventory problems and agree to coordinate their orders with the objective of reducing their costs. The R package Inventorymodel allows the determination of both the optimal policy for some inventory situations with deterministic demands and the allocation of costs from a game-theoretic perspective. The required calculations may be computed for any number of agents although the computational complexity of this class of problems when the involved agents enlarge is not reduced. In this work, the different possibilities that the package offers are described and some examples of usage are also demonstrated.
Often, once a product is chosen to be acquired, the seller advises that he or she does not have a unit of that product in stock. Probably, this vendor has not managed the storage of this commodity efficiently since the possibility of not being able to satisfy the demand for a product in time leads to shortages. Specific techniques may prevent situations such as this, allowing for reduction in economic losses associated with the lack of products.
Inventory is defined as the amount of goods stored by a company at a moment of time, which represents a capital investment for the purchase and maintenance of the product in stock. Each company desires having the proper inventory level to meet the needs of customers, and so they would prefer to handle it optimally. Inventory theory focuses on the design and optimization of production systems to minimize economic losses due to product shortages. However, this implies the existence of extra costs associated with different assumptions imposed on the model with an influence on the overall cost of the procedure. The consideration of the holding cost or variable cost for the transportation of a new order from a supplier to the warehouse are examples, among others, of new conditions to take into account in the models. Generally, this study focuses on a single product with fixed characteristics that companies need. Moreover, it presents new inventory situations in which a customer can switch to another supplier to get the desired product or an analogous product with similar properties. So, in an inventory system, the following must be considered:
An agent that wants to organize its inventory of a certain commodity.
A deterministic demand for a product that this agent needs over a fixed period of time.
The agent satisfies its demand through an external provider.
In some circumstances, the agent can consider the possibility of not fulfilling all the demand in time, that is, a shortage of the good is allowed.
The main goal entails determining the optimal amount of product to request and the moment in which it is requested. The balance between quantity and the number of orders is essential. Not following the optimal policy implies that fewer orders than necessary are placed or that they are placed more frequently than usual, and hence the cost of the procedure increases.
Usually, we talk about inventory management for a single company, with a single decision determining the amount required depending on the demand or, for instance, the moment in which that order must be placed. Although individually, such inventory models totally ignore the decisions made by other agents in the same circumstances, it is possible to consider situations wherein they cooperate. Sometimes, in order to obtain savings, it is possible to consider the joint action of several individuals who, independently, would face situations of inventory management of a product as described.
In a centralized inventory problem, several agents who face individual inventory problems decide to coordinate their orders to reduce costs. The determination of the optimal level of inventory involves:
formulation of an appropriate mathematical model that describes the situation of inventory (shortages, transportation costs, holding costs, etc.),
identification of the optimal policy under the cooperation of a group of individuals, and
allocation of the incurred costs among the involved agents by using, for instance, game theoretic procedures.
The analysis of cooperative multi-agent inventory problems has received much attention in recent years. The most basic models, the Economic Order Quantity (EOQ) model and the Economic Production Quantity (EPQ) model, are introduced in (Meca et al. 2003) for the cooperative case, using the Share the Ordering Costs rule (SOC rule) as a procedure to obtain allocations with interesting properties. However, other inventory problems have been treated in the literature under this approach, including those detailed below. In (Fiestras-Janeiro et al. 2012), the inventory transportation systems are defined as a new approach of the EOQ problem when individual transportation costs by a new order are taken into account. The line-rule allows us to allocate the costs generated by the joint order in these situations. This model is generalized in (Saavedra-Nieves et al. 2018), where a general function of transportation costs is considered and an extension of the line-rule is proposed. (Fiestras-Janeiro et al. 2014) describe two EOQ models with no holding costs: a basic model and a model with transportation costs. The Shapley value and the two-lines rule are the chosen allocation procedures for sharing costs in this class of situations. (Fiestras-Janeiro et al. 2015) introduce a cooperative multi-agent inventory model, where the holding costs are negligible and shortages are allowed. (Saavedra-Nieves et al. 2018a) introduce a variant of the previous model by considering that shortages are cheaper than the original product. For these models, two rules are proposed to allocate the collaborating costs. Apart from those mentioned above, (Nagarajan and Sošić 2008), (Dror and Hartman 2011), and (Fiestras-Janeiro et al. 2011) are examples of some recent surveys in this field.
This paper describes the R package Inventorymodel and its capabilities for determining the optimal policies in the mentioned inventory models under a game-theoretic approach. For each of them, an allocation procedure is implemented to share the collaborating costs. This package can be very useful when the number of involved agents increases due to the computational complexity of the calculus of all possible groups considerably increases.
The remainder of this paper is organized as follows. First, we introduce some game theoretic notations used in this class of problems. Then, we present the different inventory models included in the Inventorymodel package, describing, for each, the optimal policy and appropriate allocation rule for the collaborating costs. Usage of the package is illustrated through the analysis of different examples considered in the literature.
In this section, we introduce some necessary theoretical game terminology.
The cost games correspond to one of the most important classes of
cooperative games. They are necessary for analysing those cost
situations where
In this class of situations, some natural properties to verify are the
following. We say that
When a set of
The second criteria is represented by the stability of the allocations.
The core of
The Inventorymodel package includes functions to obtain the optimal policy in this class of situations. In particular, different scenarios with deterministic demands are considered: for example, shortages can be allowed, transportation costs can be taken into account by assuming that agents are in a line or a general route, or different costs of product during shortages are allowed.
Depending on the considered assumptions, different parameters should be
selected for modelling the problem among those described below. If a set
of agents
This section introduces the different inventory models included in our
package, which are dealt with in the literature by considering several
assumptions about them.
The EOQ model under cooperation, introduced in (Meca et al. 2003),
establishes the optimal policy for an agent
If
The EPQ model under cooperation is introduced by (Meca et al. 2003) by adding the following assumptions to those for the the EOQ model:
Each agent
Once the agents order, in a unit of time, agent
When an agent acts individually, the optimal policy is simple as well:
once the stock runs out and the maximum level of shortage is reached,
this agent places a new order. Following (Meca et al. 2003), when a
group
The cooperative inventory cost situations defined in this section are
denoted by
The SOC rule, introduced by (Meca et al. 2003), establishes
proportional allocations in situations such as detailed. Let
An inventory transportation system is an inventory situation wherein agents face a basic EOQ model. As (Fiestras-Janeiro et al. 2012) propose, the cost of a new order has two components: the first is common to all and the second is proportional to the distance between the supplier and the agent.
Let
All agents are in a same route. If
The supplier allows the formation of ordering coalitions. Given
According to (Fiestras-Janeiro et al. 2012), the average cost per cycle is
determined by
A basic EOQ system without holding costs is a model with a
deterministic demand, no holding costs, and a limited capacity of the
warehouses and shortages are not allowed. Let
We denote these systems by
Notice that the obtained cost game can be seen as an airport game (see
(Littlechild and Owen 1973), for details). For it, the Shapley value is an
excellent rule with stable allocations. Moreover, there is a simple
procedure to obtain it. By ordering in a non-decreasing order, the ratio
Below, we describe an inventory system with costs for transporting a new order.
A basic EOQ system without holding costs and with transportation costs
is an inventory situation introduced by (Fiestras-Janeiro et al. 2014),
where agents face a basic EOQ model. Let
These models are denoted by
All agents are in the same route. When a group
The supplier allows the formation of ordering coalitions. Given
The optimal policy of a group
For each system
Below, the assumption of a general transportation cost function is introduced in the previous model. (Saavedra-Nieves et al. 2018) analyse the EOQ systems without holding costs and with general transportation costs, a generalization of the basic model with transportation costs proposed in (Fiestras-Janeiro et al. 2014).
In some circumstances, it is certainly restrictive to consider that
agents are located in the same route. For instance, they can be located
in a circular route or other types of graphs, and that
Thus, this model is denoted by
For every system as the proposed, (Saavedra-Nieves et al. 2018) introduce the
following allocation. This rule proposes, for every
An EOQ system without holding costs and shortages, introduced in the
reference (Fiestras-Janeiro et al. 2015), is a multi-agent situation, where
each agent faces a continuous review inventory problem with no-holding
costs, with shortages and with a limited capacity warehouse. The
parameters associated with each
This model is denoted by
The calculus of the optimal policy in this problem consists of
calculating the minima of
The previous model considers that the initial product and shortages have the same price by a unit of commodity. In some situations, the latter cost may be significantly smaller than the initial cost, as when shortages are produced by the same agent. (Saavedra-Nieves et al. 2018a) justify and analyse this new inventory situation.
An EOQ problem without holding costs and with two acquisition costs is
a multi-agent inventory model wherein each agent faces a
continuous-review inventory problem involving the same commodity. In
this case, the considered parameters are the fixed part of the ordering
cost,
We denote this class of situations by
Authors propose another iterative procedure to obtain the optimal
inventory policy with the calculus of the minima of
In order to summarize the assumptions on the described models in this section, Table 1 relates them with the associated cost game and the allocation rule proposed for each case.
Ordering costs | Variable ordering costs | Holding costs | Shortages | Allocation rule | |
---|---|---|---|---|---|
- | - | ((2)) | SOC rule ((5)) | ||
- | ((4)) | SOC rule ((5)) | |||
- | ((6)) | Line-rule ((7)) | |||
- | - | - | ((8)) | Shapley value ((9)) | |
- | - | ((10)) | Two-lines rule ((11)) | ||
- | - | ((12)) | R-rule ((13)) | ||
- | - | ((14)) | G-rule ((15)) | ||
- | - | ((16)) | GR-rule ((17)) |
This section presents an overview of the structure of the package.
Inventorymodel is a tool for calculating the optimal policy in
several inventory situations and for allocating the collaboration costs
among the agents involved in the process. This software helps the user
to determine faster the optimal policy when the number of agents
increases. Remark that these functions only automatize the required
operations for the calculus of the optimal costs under theses scenarios
although the computational complexity still maintains.
Inventorymodel package includes several functions that enable users to determine the optimal inventory policy for the inventory models decribed in previous section. Moreover, auxiliary functions are implemented to obtain some intermediate values in the calculation. This package has as dependencies e1071 and GameTheoryAllocation packages of which takes some functions in its calculations. The last one, in a primitive version, includes some generic functions related to game-theoretic concepts. The functions incorporated in the package are briefly described in Table 2.
Function | Description |
---|---|
coalitions |
Function to obtain all possible coalitions with |
EOQ |
Function to calculate the optimal policy and costs in an EOQ model ((2)). |
EOQcoo |
Function to calculate the optimal policy and associated cost game in an EOQ model when |
EPQ |
Function to calculate the optimal policy and costs in an EPQ model ((4)). |
EPQcoo |
Function to calculate the optimal policy and associated cost game in an EPQ model when |
inventorygames |
Function to determine the associated cost game in an EOQ ((2)) or an EPQ ((4)) model. |
inventorymodelfunction |
Main function to obtain the optimal policy by selecting any model and its parameters. |
linerule |
Function to obtain the line-rule allocation ((7)) for an inventory transportation system ((6)) when a coalition |
linerulecoalitional |
Function to obtain the line-rule allocation ((7)) for an inventory transportation system ((6)) for each possible coalition. |
marginal_contribution_mean |
Intermediate auxiliary function to calculate the mean of the marginal contributions for a set of permutations. |
mct |
Function to obtain the costs in a basic EOQ system without holding costs and with transportation cost ((10)). |
mfoc |
Function to obtain the associated costs in a fixed order cost model ((8)). |
mwhc |
Function to obtain the associated costs in a model without holding costs ((14)). |
mwhc2c |
Function to obtain the associated costs in a model without holding costs and with two different costs of a product ((16)). |
mwhcct |
Function to obtain the associated costs in a basic EOQ system without holding costs and with a general transportation cost ((12)). |
shapley_mfoc |
Function to calculate the Shapley value ((9)) for the associated game in a fixed order cost model ((8)). |
SOC |
Function to obtain the allocation proposed by the SOC rule ((5)) under an EOQ/EPQ model, see ((2)) and ((4)). |
STI |
Function to obtain the optimal orders and associated cost in inventory transportation systems ((6)). |
STIcoo |
Function to obtain the optimal orders and associated cost when |
twolines |
Function to calculate the allocation proposed by the two-lines rule ((11)) in a basic EOQ system without holding costs and with transportation cost ((10)). |
Users can obtain the optimal inventory policy in each case by introducing the associated parameters to each model in the corresponding function. Table 3 describes the different options to define the inventory models included in Inventorymodel. However, not all of the mentioned options are necessary since only some of them are specific for each inventory situation. Table 4 summarizes the required arguments in the specific function associated with each inventory model. Examples of usage for the implemented functions are described in the next section.
Argument | Description |
---|---|
model |
A character string that indicates the selected model and required only in the inventorymodelfunction . The possible values are "EOQ" (EOQ), "EPQ" (EPQ), "STI" (the inventory transportation systems), "FOC" (the fixed order cost model), "MCT" (the basic EOQ system without holding costs and with transportation cost), "MWHC" (the model without holding costs and shortages), "MWHC2" (the model without holding costs and two acquisition costs), and "MWHCCT" (the EOQ system without holding costs and with general transportation costs). |
n |
An integer specifying the number of agents involved in the inventory model. It corresponds to the cardinality of the set |
a |
A real number that indicates the fixed cost per new order. |
av |
A vector of dimension n that contains, in each component, the transportation costs associated with each agent |
d |
A vector of dimension n that contains, in each component, the deterministic demands per time unit associated with each agent |
h |
A vector of dimension n that indicates, in each component, the holding costs per product unit associated with each agent |
m |
A vector of dimension n that indicates, in each component, the number of orders |
r |
A vector of dimension n that contains, in each component, the replacement rate of a product associated with each agent |
K |
A vector of dimension n that details, in each component, the warehouse capacity of the product associated with each agent |
b |
A vector of dimension n that details, in each component, the cost by shortage unit of the product associated with each agent |
c1 |
A real value with the acquisition cost of one unit of the purchased commodity. |
c2 |
A real value with the acquisition cost of one unit of the produced commodity. |
cooperation |
A variable that indicates if cooperation is considered. If it exists, cooperation=1 , else cooperation=0 . |
allocation |
A variable that indicates if the defined allocation in each case is required. If it exists, allocation=1 , else allocation=0 . |
Function | model |
n |
a |
av |
d |
h |
m |
r |
K |
b |
c1 |
c2 |
cooperation |
allocation |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
EOQ |
- | - | - | - | - | - | - | - | - | |||||
EOQcoo |
- | - | - | - | - | - | - | - | - | |||||
EPQ |
- | - | - | - | - | - | - | |||||||
EPQcoo |
- | - | - | - | - | - | - | |||||||
inventorygames |
- | - | - | - | - | - | - | |||||||
inventorymodelfunction |
||||||||||||||
linerule |
- | - | - | - | - | - | - | - | ||||||
linerulecoalitional |
- | - | - | - | - | - | - | - | ||||||
mct |
- | - | - | - | - | - | - | - | ||||||
mfoc |
- | - | - | - | - | - | - | - | - | |||||
mwhc |
- | - | - | - | - | - | - | |||||||
mwhc2c |
- | - | - | - | - | |||||||||
mwhcct |
- | - | - | - | - | - | - | |||||||
shapley_mfoc |
- | - | - | - | - | - | - | - | - | - | ||||
SOC |
- | - | - | - | - | - | - | |||||||
STI |
- | - | - | - | - | - | - | - | ||||||
STIcoo |
- | - | - | - | - | - | - | - | ||||||
twolines |
- | - | - | - | - | - | - | - | - |
Additionally, the function coalitions
takes, as a unique argument, the
integer variable n
(the number of involved agents) to calculate all
possible subsets of the set of marginal_contribution_mean
allows the calculation of the average of
the marginal contribution vectors for some indicated permutations.
Therefore, it only needs as arguments a matrix with the permutations to
study (permute
) and a vector that contains the characteristic function
with associated cost values for each possible coalition in a set of
agents costs
).
Several examples of application of the Inventorymodel package are used to illustrate its performance in the different contexts considered. After installing the package from CRAN, as an initial step a user should load the package in the R Console:
> library("Inventorymodel")
Below, in order to illustrate the performance of those functions which
determine the optimal order and the associated cost game, we consider
examples extracted from the references. In this situations, the number
of involved agents is always lesser than
This example, taken from (Meca et al. 2004), describes the EOQ problem
that surges when three airlines place joint orders. Let
1 | 2 | 3 | |
---|---|---|---|
500 | 300 | 400 | |
9.6 | 11 | 10 |
Using EOQcoo
, we obtain the optimal policy for each possible subgroup
> EOQcoo(n = 3, a = 600, d = c(500, 300, 400), h = c(9.6, 11, 10))
EOQ model
Cooperative case
Optimal order
Coalition 1 2 3 Coalitional costs
1 0 0.0000 0.0000 0.0000 0.000
2 '{ 1 }' 250.0000 0.0000 0.0000 2400.000
3 '{ 2 }' 0.0000 180.9068 0.0000 1989.975
4 '{ 3 }' 0.0000 0.0000 219.0890 2190.890
5 '{ 1,2 }' 192.4501 115.4701 0.0000 3117.691
6 '{ 1,3 }' 184.6372 0.0000 147.7098 3249.615
7 '{ 2,3 }' 0.0000 121.6327 162.1770 2959.730
8 '{ 1,2,3 }' 157.4592 94.4755 125.9673 3810.512
To evaluate the implementation in R of the EPQ model, we consider in the
previous example a replacement rate EPQcoo
in R.
> EPQcoo(n = 3, a = 600, d = c(500, 300, 400), h = c(9.6, 11, 10),
+ r = rep(600, 3), b = c(100, 150, 200))
EPQ model
Cooperative case
`Optimal order`
Coalition 1 2 3 Coalitional costs
1 0 0.0000 0.0000 0.0000 0.0000
2 '{ 1 }' 641.0928 0.0000 0.0000 935.9019
3 '{ 2 }' 0.0000 265.0557 0.0000 1358.2049
4 '{ 3 }' 0.0000 0.0000 388.8444 1234.4268
5 '{ 1,2 }' 363.7611 218.2567 0.0000 1649.4341
6 '{ 1,3 }' 387.3208 0.0000 309.8566 1549.1036
7 '{ 2,3 }' 0.0000 196.1473 261.5297 1835.3556
8 '{ 1,2,3 }' 291.2332 174.7399 232.9866 2060.2045
`Optimal shortages`
1 2 3
0.000000 0.000000 0.000000
9.359019 0.000000 0.000000
0.000000 9.054699 0.000000
0.000000 0.000000 6.172134
5.310381 7.455973 0.000000
5.654318 0.000000 4.918359
0.000000 6.700683 4.151265
4.251580 5.969377 3.698200
The output is a list which contains as a first element a data frame with optimal orders and the associated costs, and a data frame where the optimal shortages by agent are depicted for the different coalitions.
The calculation of the SOC rule ((5)) in the
abovementioned example for the EOQ problem completes this evaluation. To
conclude, we use the SOC
function to obtain this allocation (as a
numeric vector).
> SOC(n = 3, a = 600, d = c(500, 300, 400), h = c(9.6, 11, 10), model = "EOQ")
EOQ model
`Share the ordering costs rule (individually)`
1 2 3
0.000 0.000 0.000
2400.000 0.000 0.000
0.000 1989.975 0.000
0.000 0.000 2190.890
1847.521 1270.171 0.000
1772.517 0.000 1477.098
0.000 1337.960 1621.770
1511.608 1039.230 1259.673
In an obvious way, this function returns the allocation proposed by the SOC rule correspond to each possible group of agents.
To evaluate the performance of the inventory transportation systems in
R, we consider the example depicted in (Fiestras-Janeiro et al. 2012). Let
1 | 2 | 3 | |
---|---|---|---|
300 | 300 | 900 | |
90 | 80 | 20 | |
0.06 | 0.06 | 0.1 |
The function STIcoo
allows the determination of the optimal policy for
each possible
> STIcoo(n = 3, a = 200, av = c(300, 300, 900), d = c(90, 80, 20),
+ h = c(0.06, 0.06, 0.1))
`Optimal order`
1 2 3 Coalition Order cost
1 0.0000 0.000 0.0000 0 0.00000
2 1224.7449 0.000 0.0000 '{ 1 }' 73.48469
3 0.0000 1154.701 0.0000 '{ 2 }' 69.28203
4 0.0000 0.000 663.3250 '{ 3 }' 66.33250
5 891.1328 792.118 0.0000 '{ 1,2 }' 100.99505
6 1551.8080 0.000 344.8462 '{ 1,3 }' 127.59310
7 0.0000 1438.954 359.7385 '{ 2,3 }' 122.31108
8 1208.5759 1074.290 268.5724 '{ 1,2,3 }' 163.82918
Finally, we utilize the function linerule
to obtain the allocation
proposed by the line-rule when
> linerule(n = 3, a = 200, av = c(300, 300, 900), d = c(90, 80, 20),
+ h = c(0.06, 0.06, 0.1))
[1] 51.38935 46.10733 66.33250
First, we evaluate the basic EOQ system without holding costs in R by
taking the example considered in (Fiestras-Janeiro et al. 2014). There are
five farms with
|
1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
0.4 | 1.4 | 1.2 | 1.3 | 1.2 | |
4 | 10 | 8 | 8 | 6 |
By using the mfoc
function, we obtain the individual inventory costs
(as a numeric vector).
> mfoc(n = 5, a = 200, d = c(0.4, 1.4, 1.2, 1.3, 1.2), K = c(4, 10, 8, 8, 6),
+ cooperation = 0)
MFOC model
[1] 20.0 28.0 30.0 32.5 40.0
When cooperation=1
, the costs associated to each possible coalition
((8)) are depicted in a data frame.
Below, we obtain the Shapley value (as numeric
) with the previous
costs according to that described ((9)). For this, we use
the shapley_mfoc
function.
> shapley_mfoc(n = 5, a = 200, d = c(0.4, 1.4, 1.2, 1.3, 1.2),
+ K = c(4, 10, 8, 8, 6))
Shapley-Value
MFOC model
[1] 4.000000 6.000000 6.666667 7.916667 15.416667
In order to evaluate the basic EOQ system without holding costs and with
transportation costs in R, we consider the example proposed in
(Fiestras-Janeiro et al. 2014) for three farms. In this case, if
|
||||
---|---|---|---|---|
1 | 2 | 9 | 300 | 0.222 |
2 | 2 | 8 | 500 | 0.250 |
3 | 5 | 7 | 200 | 0.714 |
The function mct
allows the calculation, for each cooperation=1
, the output is a matrix; otherwise, it is a numeric
vector.
> mct(n = 3, a = 400, av = c(300, 500, 200), d = c(2, 2, 5), K = c(9, 8, 7),
+ cooperation = 1)
MCT model
Cooperative case
1 2 3 Coalition Cost
1 0 0 0 0 0.0000
2 1 0 0 '{ 1 }' 155.5556
3 0 1 0 '{ 2 }' 225.0000
4 0 0 1 '{ 3 }' 428.5714
5 1 1 0 '{ 1,2 }' 225.0000
6 1 0 1 '{ 1,3 }' 500.0000
7 0 1 1 '{ 2,3 }' 642.8571
8 1 1 1 '{ 1,2,3 }' 642.8571
For this class of problems, when twolines
:
> twolines(n = 3, a = 400, av = c(300, 500, 200), d = c(2, 2, 5), K = c(9, 8, 7))
MCT model
Cooperative case
Two-lines rule
[1] 0.0000 219.6429 423.2143
Finally, the performance of the implementation in R of the EOQ systems
without holding costs and with general transportation costs is
considered. For this, we take one example for
10 | 10 | 10 | 20 | 20 | 20 | 30 |
The function mwhcct
allows the determination of the optimal policy for
this model ((12)), and with the selected option, we obtain
the allocation the
> mwhcct(n = 3, a = 10, av = c(0, 10, 10, 10, 20, 20, 20, 30), d = c(1, 0.95,
+ 0.9), K = c(1, 1, 1), cooperation = 1, allocation = 1)
MWHC with Transportation Costs model
Cooperative case
`Optimal solution`
1 2 3 Coalition Cost
1 0 0 0 0 0.0
2 1 0 0 '{ 1 }' 20.0
3 0 1 0 '{ 2 }' 19.0
4 0 0 1 '{ 3 }' 18.0
5 1 1 0 '{ 1,2 }' 30.0
6 1 0 1 '{ 1,3 }' 30.0
7 0 1 1 '{ 2,3 }' 28.5
8 1 1 1 '{ 1,2,3 }' 40.0
`Allocation R rule`
1 2 3
13.75 13.25 13
The results are in a list which contains a data frame with optimal costs
and a vector with the allocation that the
The EOQ system without holding costs and shortages in R is evaluated
using the example taken from (Fiestras-Janeiro et al. 2015). In that case,
1 | 2 | 3 | 4 | |
---|---|---|---|---|
0.45 | 0.95 | 1.05 | 1.20 | |
15 | 15 | 10 | 12 | |
5 | 7.5 | 8 | 9 |
Using the function mwhc
, the optimal policy ((14)) in
terms of the number of orders and shortages is obtained, and the
allocation proposed for this inventory scenario is also calculated for
the case in which
> mwhc(n = 4, a = 180, b = c(15, 15, 10, 12), d = c(0.45, 0.95, 1.05, 1.2),
+ K = c(5, 7.5, 8, 9), cooperation = 0, allocation = 0)
MWHC model
`Number of orders per time unit`
[1] 0.07520921 0.10684954 0.10406757 0.11094004
Costs
[1] 14.74965 20.86510 20.89599 21.79985
`Optimal shortages`
[1] 0.9833101 1.3910067 2.0895986 1.8166538
In this case, the output corresponds to a list with components for the
orders, the costs, and the optimal shortages. When cooperation=1
, the
output is a list with the optimal policies for the different groups,
indicating the orders and the costs, and the allocation proposed by
To conclude, we analyse the EOQ problem without holding costs and with
two acquisition costs in R. For this, we consider an example from
(Saavedra-Nieves et al. 2018a) for
1 | 2 | 3 | |
---|---|---|---|
30 | 45 | 46 | |
10 | 10 | 10 | |
30 | 45 | 46 |
The function mwhc2c
allows the calculation of the optimal policy in
terms of the number of orders and shortages when all agents cooperate
((16)). Moreover, we obtain the proposed allocation in
this case.
> mwhc2c(n = 3, a = 1, b = c(10, 10, 10), d = c(30, 45, 46),
+ K = c(30, 45, 46), c1 = 3.5, c2 = 3, cooperation = 0, allocation = 0)
MWHC model
`Number of orders per time unit`
[1] 0.9505864 0.9515422 0.9515838
Costs
[1] 105.5947 157.9165 161.4046
`Optimal shortages`
[1] 1.559468 2.291648 2.340459
The output has the following structure: it is a list with the orders,
the costs and the optimal shortages. When cooperation=1
, the output
corresponds to a list with the optimal policies for the different
groups, with the associated orders and the costs in a data frame, and
the allocation proposed by
All examples dealt with in this section can be evaluated with
inventorymodelfunction
by introducing, for each case, the
corresponding character chain for the associated model and its
parameters (see Table 3 for details).
To illustrate the time required by the different functions in the R
package Inventorymodel, we performed the following simulations
with artificial data. We generated, according to a uniform distribution,
100 samples of the involved parameters in the functions included in the
package for values of
For each sample, we evaluate the available functions. All the
computations included in this paper have been performed on a personal
computer with Intel(R) Core(TM) i5-4210U and 8 GB of memory using a
single 2.40GHz CPU processor. The results of the evaluations for all
samples are depicted in Tables 12 and
13, where the values are reported in seconds.proc.time()
in R. By definition, the user time is the CPU time
charged for the execution of user instructions of the calling
process. The system time is the CPU time charged for execution by
the system on behalf of the calling process.
EOQcoo |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.02 | 0.00 |
EPQcoo |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 |
STIcoo |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.04 |
mfoc |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 |
mct |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.01 |
mwhc |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.01 |
mwhc2c |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.00 |
mwhcct |
0.00 | 0.00 | 0.00 | 0.00 | 0.00 | 0.02 | 0.00 | 0.01 |
EOQcoo |
0.00 | 0.00 | 0.34 | 0.72 | 1.00 | 2.20 | 4.35 | 9.35 |
EPQcoo |
0.00 | 0.00 | 0.26 | 0.24 | 0.63 | 1.35 | 2.72 | 5.98 |
STIcoo |
0.00 | 0.00 | 0.37 | 0.65 | 1.14 | 2.13 | 4.50 | 9.43 |
mfoc |
0.00 | 0.00 | 0.32 | 0.45 | 0.75 | 1.65 | 3.48 | 7.16 |
mct |
0.00 | 0.00 | 1.00 | 1.96 | 4.03 | 8.34 | 17.97 | 38.22 |
mwhc |
0.00 | 0.00 | 0.72 | 1.27 | 2.17 | 4.45 | 9.32 | 18.93 |
mwhc2c |
0.00 | 0.00 | 0.92 | 1.64 | 3.26 | 7.31 | 14.38 | 31.86 |
mwhcct |
0.00 | 0.00 | 0.84 | 1.76 | 3.52 | 7.27 | 15.47 | 32.79 |
We can observe that the runtime is mainly affected by the number of
agents. As we expected, as the procedure is based on the subsets of
This paper discusses the implementation in R of several procedures to calculate the optimal policy in different inventory situations from using game theory results. Mechanisms to allocate the collaborating costs among the agents have been incorporated as well. Thus, the Inventorymodel package provides R users a set of functions to determine the optimal costs in different situations defined in the literature: with holding costs, with costs by the transport of a new order, with shortages, and with different prices of a unit of purchased and produced products. When the number of agents increases, these calculations become computationally more complicated since that the number of possible groups of agents considerably enlarges. Future research and development plans for forthcoming versions of the package include the addition of new inventory models that can be dealt with in the framework presented above and the inclusion of alternative procedures in order to reduce the computational complexity present in this class of problems.
The author acknowledges the financial support of Ministerio de Economı́a y Competitividad through projects MTM2014-53395-C3-2-P and MTM2014-53395-C3-3-P and the financial support of Xunta de Galicia through the ERDF (Grupos de Referencia Competitiva) ED431C 2016-040. The author acknowledges M. Gloria Fiestras-Janeiro for her constructive comments on this paper.
Inventorymodel, e1071, GameTheoryAllocation
Cluster, Distributions, Environmetrics, MachineLearning, Psychometrics
This article is converted from a Legacy LaTeX article using the texor package. The pdf version is the official version. To report a problem with the html, refer to CONTRIBUTE on the R Journal homepage.
proc.time()
in R. By definition, the user time is the CPU time
charged for the execution of user instructions of the calling
process. The system time is the CPU time charged for execution by
the system on behalf of the calling process.[↩]Text and figures are licensed under Creative Commons Attribution CC BY 4.0. The figures that have been reused from other sources don't fall under this license and can be recognized by a note in their caption: "Figure from ...".
For attribution, please cite this work as
Saavedra-Nieves, "Inventorymodel: an R Package for Centralized Inventory Problems", The R Journal, 2018
BibTeX citation
@article{RJ-2018-023, author = {Saavedra-Nieves, Alejandro}, title = {Inventorymodel: an R Package for Centralized Inventory Problems}, journal = {The R Journal}, year = {2018}, note = {https://rjournal.github.io/}, volume = {10}, issue = {1}, issn = {2073-4859}, pages = {200-217} }