• Aucun résultat trouvé

Contrat avec paiement des coûts de stockage par le distri- distri-buteur

Coordination avec monopole du fournisseur

3.3 Contrat avec paiement des coûts de stockage par le distri- distri-buteur

3.3.1 Définition du problème

Dans cette section, nous considérons le problème de coordination où le distributeur ne modifie pas la réservation de capacité faite par le fournisseur, notée Rtpour tout t∈ {1, . . . , T }. Pour optimiser ses coûts, le distributeur peut proposer au fournisseur de prendre en charge les coûts de stockage des unités qui sont stockées au niveau du fournisseur. En effet, le fournis-seur impose au distributeur que tout le stock se fait au niveau du distributeur. En proposant au fournisseur de prendre en charge les coûts de stockage des unités qui restent en stock à son niveau, le distributeur peut avoir plus de flexibilité sur ses périodes de réapprovisionnement sans modifier le plan de production optimal du fournisseur, et ainsi diminuer son coût. Nous notons ce problème 2ULS-FP où FP signifie Fixed Production. Le contrat (xD, z) proposé par le distributeur est composé d’un nouveau plan de réapprovisionnement xDet d’un transfert d’argent z = P

thF tsF

t sur les coûts de stockage du fournisseur. Ce contrat ne dégrade pas le coût optimal du fournisseur puisque le plan de production ne sera pas remis en cause, et les coûts de stockage sont compensés par un transfert d’argent. Le coût du distributeur asso-cié à ce contrat est égal au coût du plan de réapprovisionnement xDplus le transfert d’argent z.

Définition 3.1 (Gain du distributeur)

Le gain du distributeur pour un problème de coordination P est défini par cD−cD

Poù cDest le coût du distributeur lorsque le plan de réapprovisionnement est imposé par le fournisseur et cDP est le coût du distributeur associé au contrat du problème P .

Exemple 3.2. Nous reprenons l’instance Icdéfinie dans l’exemple 3.1 p.43. Le plan de réapprovisionne-ment imposé par le fournisseur est xD= (10, 0, 0, 0, 0). Sans coordination, nous avons vu que le coût du distributeur est cD= 70. Lorsque le distributeur peut prendre en charge les coûts de stockage du fournisseur, il peut proposer au fournisseur le contrat (¯xD, z)où ¯xD = (2, 2, 2, 4, 0)impliquant que le fournisseur stocke 8 unités à la période 1, 6 unités à la période 2 et 4 unités à la période 3 (voir figure 3.2). Le transfert d’argent z correspondant au coût total de stockage du fournisseur est alors z = hFt sFt = 36et le coût total du distributeur est égal à cD

P F = 2pD1 + 2pD2 + 2pD3 + 4pD4 + z = 46. Le gain du distributeur est alors égal à cD− cD

1 2 3 4 5 1 2 3 4 5 10 4 2 2 2 8 6 4 2 2 2 2 2 2

FIGURE3.2 – Solution du problème 2ULS-FP associée à l’instance Ic.

Formulation mathématique du problème 2ULS-FP.

Déterminer un contrat (xD, z) revient à résoudre un problème 2ULS où le plan de pro-duction du fournisseur est fixé à R. Les variables de décision correspondent aux variables de décisions du problème 2ULS (voir section 1.3.2 p.14).

cP F = min cD(yD, xD, sD) +X t∈T hFtsFt (3.1) s.t. sDt−1+ xDt = dt+ sDt ∀t ∈ T , (3.2) sF t−1+ Rt= xD t + sF t ∀t ∈ T , (3.3) xD t ≤ dtTyD t ∀t ∈ T , sD0 = sDT = sF0 = sFT = 0, xDt , sDt , sFt ≥ 0 ∀t ∈ T , ytD∈ {0, 1} ∀t ∈ T

La fonction objectif (3.1) consiste à minimiser le coût total du distributeur ainsi que les coûts de stockage du fournisseur. Les contraintes (3.2) et (3.3) correspondent aux contraintes de conser-vation du flot où le plan de production du fournisseur est fixé à R.

Ce problème peut être résolu à partir de l’algorithme résolvant le problème 2ULS qui a une complexité deO(T2logT ) (Melo et Wolsey, 2010). Dans la section suivante, nous amélio-rons cette complexité en proposant un algorithme de programmation dynamique enO(T logT ) pour résoudre ce problème.

Proposition 3.1

Le gain du distributeur associé au problème 2ULS-FP peut être arbitrairement grand par rapport au cas où il n’y a pas de coordination.

Preuve. Soit M > 0. Considérons l’instanceI1 suivante (voir figure 3.3) : T = 2, d = (0, 1), fD= (M, 0), pF = (1, 2), pD

t = hD t = fF

t = 0, hF

t = 1 pour tout t∈ {1, . . . , T }. Le plan de production xFopt = R = (1, 0) est de coût optimal égal à cF

opt = 1 pour le four-nisseur. Le coût du distributeur associé au plan de réapprovisionnement xD = R est de coût cD = M . Dans le cadre du problème 2ULS-FP, la coordination entre les acteurs permet au distributeur de proposer un nouveau plan de réapprovisionnement ¯xD = (0, 1) induisant le stockage d’une unité à la période 1 au niveau du fournisseur (voir figure 3.4). Le coût du dis-tributeur est alors égal à ¯cD= 1, qui représente le coût de stockage au niveau du fournisseur. Ainsi, comme cD/¯cD= M , le gain du distributeur peut être arbitrairement grand.

Remarque. Soit cP F la valeur obtenue en résolvant à l’optimalité le modèle de programmation linéaire en nombres entiers du problème 2ULS-FP. Lorsqu’il existe un unique plan de production de coût

3.3. Contrat avec paiement des coûts de stockage par le distributeur 49 1 2 1 2 0, 1 0, 2 M, 0 0, 0 0 1 0 1 FIGURE3.3 – Instance I1. 1 2 1 2 1 1 1 0 1

FIGURE3.4 – Solution du problème 2ULS-FP où R = (1, 0).

optimal cF

opt, la valeur optimale cHdu modèle mathématique PHsuivant est égale à cP F.

cH = min cD(yD, xD, sD) + cF(yF, xF, sF) s.t. sDt−1+ xDt = dt+ sDt ∀t ∈ T , sFt−1+ xFt = xDt + sFt ∀t ∈ T , xDt ≤ dtTyDt ∀t ∈ T , xFt ≤ dtTyFt ∀t ∈ T , X t∈T (ftFyFt + ptFxFt) ≤ cFopt ∀t ∈ T , (3.4) xDt , sDt , sFt ≥ 0 ∀t ∈ T , ytD∈ {0, 1} ∀t ∈ T

En effet, R correspond à l’unique plan de production du fournisseur de coût optimal cFoptqui mini-miseP

t∈T(ftFytF+ pFtxFt). Ainsi, la contrainte (3.4) implique que le plan de production déterminé par la résolution du programme mathématique PH est égal à R. En revanche, s’il existe plusieurs plan de production de coût optimal cFopt, nous avons cH ≤ cP F. Nous pouvons remarquer que le programme mathématique PHcorrespond au problème PCS qui vise la détermination d’un contrat avec transfert d’argent sur les coûts de stockage et information complète lorsque le distributeur a le monopole (voir chapitre 2 section 2.3.3 p.31).

3.3.2 Résolution du problème 2ULS-FP

Dans cette section, nous proposons un algorithme de programmation dynamique enO(T logT ) pour résoudre le problème 2ULS-FP.

Le fournisseur détermine son plan de production optimal R en résolvant un problème ULS. Le plan de production R satisfait donc la propriété ZIO. Comme dans le problème 2ULS-FP le plan de production du fournisseur est fixé à R, une solution de ce problème vérifie également la propriété ZIO au niveau du fournisseur et du distributeur. À chaque période t telle que Rt= dtk(k≥ t), une quantité Rtest donc disponible au niveau du fournisseur pour satisfaire les demandes de la période t à la période k au niveau du distributeur. En particulier, nous avons sD

t−1 = sD

k = 0. Soit i une période telle que t≤ i ≤ k. L’idée pour résoudre ce problème est de déterminer une période j, i≤ j ≤ k, telle que la quantité dij est envoyée au niveau du distributeur à la période i et la quantité dj+1,kreste en stock au niveau du fournisseur. Le coût de stockage pour stocker dj+1,kde la période i à la période j au niveau du fournisseur est pris en charge par le distributeur.

Soient t, k deux périodes telles que 1≤ t ≤ k ≤ T et Rt= dtk. Soit i une période telle que t ≤ i ≤ k. La notation di ⊆ Rtsignifie que la demande di est couverte par Rt. Pour chaque période i∈ {t, . . . , k}, nous posons αi= t la période à laquelle di⊆ Rt.

Soit Gtle coût total minimum pour satisfaire les demandes de la période 1 à la période t connaissant la capacité de production R réservée pour le distributeur par le fournisseur. L’idée de l’algorithme est de déterminer une période k, 1 ≤ k ≤ t, telle que dkt ⊆ Rαk et les de-mandes dktsont satisfaites par une période de réapprovisionnement à la période k au niveau du distributeur. Si k > αk, les demandes dktsont restées en stock au niveau du fournisseur de la période αk à la période k− 1. Nous définissons la formule de récurrence de la manière suivante : Gt= min 1≤k≤t{Gk−1+ fkD+ pDkdkt+ t−1 X i=k hDi di+1,t+ hFαk,k−1dkt+1(dkt⊆ Rαk)} (3.5) où hF ij =Pj l=ihF

l et1(c) est égal à 0 si c est vraie et +∞ sinon. Dans l’équation (3.5), le terme fD

k + pD

kdkt+Pt−1 i=khD

i di+1,t correspond à un réapprovisionnement à la période k au niveau du distributeur pour satisfaire les demandes dkt. Le terme hFαk,k−1dktcorrespond au coût de stockage du fournisseur pour que les unités de demandes dkt soient stockées au niveau du fournisseur entre les périodes αk et k− 1 sachant que dkt est disponible à la période αk. Le terme1(dkt ⊆ Rαk) permet de déterminer si la quantité dkt est bien disponible à la période αk, i.e. si les demandes dktsont couvertes par la réservation Rαk. Une représentation des dif-férents termes de la formule de récurrence est fournie dans la figure 3.5. Une quantité d’unités Rαk est disponible à la période αk au niveau du fournisseur et peut être envoyée au niveau distributeur à partir de la période αk.

1 . . . k-1 k . . . t αk . . . k-1 k Rαk dkt dkt dkt dkt 0 dk+1,t dt 0 d1 dk−1 dk dt hF αk,k−1dkt Pt−1 i=khD i di+1,t fD k + pD kdkt Gk−1

FIGURE3.5 – Représentation du coût Gk où Rαk est disponible à la période αket dkt ⊆ Rαk sont envoyées au niveau du distributeur à la période k pour

satisfaire les demandes de la période k à t.

L’initialisation se fait en posant G0 = 0. Le coût optimal du problème 2ULS-FP est égal à GT. Le coût GT se calcule enO(T logT ) en se basant sur l’algorithme proposé par Aggarwal et Park (1993).