mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2024-11-26 17:43:48 +01:00
make smart supply actually kinda smart
This commit is contained in:
parent
6e670e88e2
commit
cd43f25bf5
@ -581,32 +581,28 @@ export class Industry implements IIndustry {
|
|||||||
if (warehouse === 0) continue;
|
if (warehouse === 0) continue;
|
||||||
|
|
||||||
switch (this.state) {
|
switch (this.state) {
|
||||||
case "PURCHASE":
|
case "PURCHASE": {
|
||||||
|
let totalProdRatio = 0;
|
||||||
|
for (const reqMat of Object.values(this.reqMats)) {
|
||||||
|
if (reqMat === undefined) continue;
|
||||||
|
totalProdRatio += reqMat;
|
||||||
|
}
|
||||||
/* Process purchase of materials */
|
/* Process purchase of materials */
|
||||||
for (const matName in warehouse.materials) {
|
for (const matName in warehouse.materials) {
|
||||||
if (warehouse.materials.hasOwnProperty(matName)) {
|
if (!warehouse.materials.hasOwnProperty(matName)) continue;
|
||||||
(function (matName, ind) {
|
|
||||||
const mat = warehouse.materials[matName];
|
const mat = warehouse.materials[matName];
|
||||||
let buyAmt, maxAmt;
|
let buyAmt = 0;
|
||||||
|
let maxAmt = 0;
|
||||||
if (
|
if (
|
||||||
warehouse.smartSupplyEnabled &&
|
warehouse.smartSupplyEnabled &&
|
||||||
Object.keys(ind.reqMats).includes(matName)
|
Object.keys(this.reqMats).includes(matName)
|
||||||
) {
|
) {
|
||||||
//Smart supply tracker is stored as per second rate
|
continue;
|
||||||
const reqMat = ind.reqMats[matName];
|
|
||||||
if (reqMat === undefined)
|
|
||||||
throw new Error(`reqMat "${matName}" is undefined`);
|
|
||||||
mat.buy = reqMat * warehouse.smartSupplyStore;
|
|
||||||
buyAmt =
|
|
||||||
mat.buy *
|
|
||||||
CorporationConstants.SecsPerMarketCycle *
|
|
||||||
marketCycles;
|
|
||||||
} else {
|
|
||||||
buyAmt =
|
|
||||||
mat.buy *
|
|
||||||
CorporationConstants.SecsPerMarketCycle *
|
|
||||||
marketCycles;
|
|
||||||
}
|
}
|
||||||
|
buyAmt =
|
||||||
|
mat.buy *
|
||||||
|
CorporationConstants.SecsPerMarketCycle *
|
||||||
|
marketCycles;
|
||||||
|
|
||||||
if (matName == "RealEstate") {
|
if (matName == "RealEstate") {
|
||||||
maxAmt = buyAmt;
|
maxAmt = buyAmt;
|
||||||
@ -621,12 +617,99 @@ export class Industry implements IIndustry {
|
|||||||
mat.qty += buyAmt;
|
mat.qty += buyAmt;
|
||||||
expenses += buyAmt * mat.bCost;
|
expenses += buyAmt * mat.bCost;
|
||||||
}
|
}
|
||||||
})(matName, this);
|
|
||||||
this.updateWarehouseSizeUsed(warehouse);
|
this.updateWarehouseSizeUsed(warehouse);
|
||||||
}
|
|
||||||
} //End process purchase of materials
|
} //End process purchase of materials
|
||||||
break;
|
|
||||||
|
|
||||||
|
// smart supply
|
||||||
|
const smartBuy: { [key: string]: number | undefined } = {};
|
||||||
|
for (const matName in warehouse.materials) {
|
||||||
|
if (!warehouse.materials.hasOwnProperty(matName)) continue;
|
||||||
|
if (
|
||||||
|
!warehouse.smartSupplyEnabled ||
|
||||||
|
!Object.keys(this.reqMats).includes(matName)
|
||||||
|
)
|
||||||
|
continue;
|
||||||
|
const mat = warehouse.materials[matName];
|
||||||
|
|
||||||
|
//Smart supply tracker is stored as per second rate
|
||||||
|
const reqMat = this.reqMats[matName];
|
||||||
|
if (reqMat === undefined)
|
||||||
|
throw new Error(`reqMat "${matName}" is undefined`);
|
||||||
|
mat.buy = reqMat * warehouse.smartSupplyStore;
|
||||||
|
let buyAmt =
|
||||||
|
mat.buy *
|
||||||
|
CorporationConstants.SecsPerMarketCycle *
|
||||||
|
marketCycles;
|
||||||
|
const maxAmt = Math.floor(
|
||||||
|
(warehouse.size - warehouse.sizeUsed) / MaterialSizes[matName],
|
||||||
|
);
|
||||||
|
buyAmt = Math.min(buyAmt, maxAmt);
|
||||||
|
if (buyAmt > 0) smartBuy[matName] = buyAmt;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find which material were trying to create the least amount of product with.
|
||||||
|
let worseAmt = 1e99;
|
||||||
|
for (const matName in smartBuy) {
|
||||||
|
const buyAmt = smartBuy[matName];
|
||||||
|
if (buyAmt === undefined)
|
||||||
|
throw new Error(`Somehow smartbuy matname is undefined`);
|
||||||
|
const reqMat = this.reqMats[matName];
|
||||||
|
if (reqMat === undefined)
|
||||||
|
throw new Error(`reqMat "${matName}" is undefined`);
|
||||||
|
const amt = buyAmt / reqMat;
|
||||||
|
if (amt < worseAmt) worseAmt = amt;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Align all the materials to the smallest amount.
|
||||||
|
for (const matName in smartBuy) {
|
||||||
|
const reqMat = this.reqMats[matName];
|
||||||
|
if (reqMat === undefined)
|
||||||
|
throw new Error(`reqMat "${matName}" is undefined`);
|
||||||
|
smartBuy[matName] = worseAmt * reqMat;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Calculate the total size of all things were trying to buy
|
||||||
|
let totalSize = 0;
|
||||||
|
for (const matName in smartBuy) {
|
||||||
|
const buyAmt = smartBuy[matName];
|
||||||
|
if (buyAmt === undefined)
|
||||||
|
throw new Error(`Somehow smartbuy matname is undefined`);
|
||||||
|
totalSize += buyAmt * MaterialSizes[matName];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Shrink to the size of available space.
|
||||||
|
const freeSpace = warehouse.size - warehouse.sizeUsed;
|
||||||
|
if (totalSize > freeSpace) {
|
||||||
|
for (const matName in smartBuy) {
|
||||||
|
const buyAmt = smartBuy[matName];
|
||||||
|
if (buyAmt === undefined)
|
||||||
|
throw new Error(`Somehow smartbuy matname is undefined`);
|
||||||
|
smartBuy[matName] = Math.floor(
|
||||||
|
(buyAmt * freeSpace) / totalSize,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Use the materials already in the warehouse.
|
||||||
|
for (const matName in smartBuy) {
|
||||||
|
const mat = warehouse.materials[matName];
|
||||||
|
const buyAmt = smartBuy[matName];
|
||||||
|
if (buyAmt === undefined)
|
||||||
|
throw new Error(`Somehow smartbuy matname is undefined`);
|
||||||
|
smartBuy[matName] = Math.max(0, buyAmt - mat.qty);
|
||||||
|
}
|
||||||
|
|
||||||
|
// buy them
|
||||||
|
for (const matName in smartBuy) {
|
||||||
|
const mat = warehouse.materials[matName];
|
||||||
|
const buyAmt = smartBuy[matName];
|
||||||
|
if (buyAmt === undefined)
|
||||||
|
throw new Error(`Somehow smartbuy matname is undefined`);
|
||||||
|
mat.qty += buyAmt;
|
||||||
|
expenses += buyAmt * mat.bCost;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case "PRODUCTION":
|
case "PRODUCTION":
|
||||||
warehouse.smartSupplyStore = 0; //Reset smart supply amount
|
warehouse.smartSupplyStore = 0; //Reset smart supply amount
|
||||||
|
|
||||||
|
@ -41,10 +41,6 @@ export class Warehouse {
|
|||||||
// Whether Smart Supply is enabled for this Industry (the Industry that this Warehouse is for)
|
// Whether Smart Supply is enabled for this Industry (the Industry that this Warehouse is for)
|
||||||
smartSupplyEnabled = false;
|
smartSupplyEnabled = false;
|
||||||
|
|
||||||
// Flag that indicates whether Smart Supply accounts for imports when calculating
|
|
||||||
// the amount fo purchase
|
|
||||||
smartSupplyConsiderExports = false;
|
|
||||||
|
|
||||||
// Stores the amount of product to be produced. Used for Smart Supply unlock.
|
// Stores the amount of product to be produced. Used for Smart Supply unlock.
|
||||||
// The production tracked by smart supply is always based on the previous cycle,
|
// The production tracked by smart supply is always based on the previous cycle,
|
||||||
// so it will always trail the "true" production by 1 cycle
|
// so it will always trail the "true" production by 1 cycle
|
||||||
|
Loading…
Reference in New Issue
Block a user