Blade action count replenishes more consistently

This commit is contained in:
Olivier Gagnon 2021-09-07 13:15:27 -04:00
parent faa6f75027
commit f7adadd671
9 changed files with 64 additions and 36 deletions

File diff suppressed because one or more lines are too long

@ -1,2 +1,2 @@
!function(n){function t(t){for(var e,i,f=t[0],c=t[1],l=t[2],p=0,s=[];p<f.length;p++)i=f[p],u[i]&&s.push(u[i][0]),u[i]=0;for(e in c)Object.prototype.hasOwnProperty.call(c,e)&&(n[e]=c[e]);for(a&&a(t);s.length;)s.shift()();return r.push.apply(r,l||[]),o()}function o(){for(var n,t=0;t<r.length;t++){for(var o=r[t],e=!0,f=1;f<o.length;f++){var c=o[f];0!==u[c]&&(e=!1)}e&&(r.splice(t--,1),n=i(i.s=o[0]))}return n}var e={},u={1:0},r=[];function i(t){if(e[t])return e[t].exports;var o=e[t]={i:t,l:!1,exports:{}};return n[t].call(o.exports,o,o.exports,i),o.l=!0,o.exports}i.m=n,i.c=e,i.d=function(n,t,o){i.o(n,t)||Object.defineProperty(n,t,{enumerable:!0,get:o})},i.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},i.t=function(n,t){if(1&t&&(n=i(n)),8&t)return n;if(4&t&&"object"==typeof n&&n&&n.__esModule)return n;var o=Object.create(null);if(i.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:n}),2&t&&"string"!=typeof n)for(var e in n)i.d(o,e,function(t){return n[t]}.bind(null,e));return o},i.n=function(n){var t=n&&n.__esModule?function(){return n.default}:function(){return n};return i.d(t,"a",t),t},i.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},i.p="";var f=window.webpackJsonp=window.webpackJsonp||[],c=f.push.bind(f);f.push=t,f=f.slice();for(var l=0;l<f.length;l++)t(f[l]);var a=c;r.push([769,0]),o()}({706:function(n,t,o){},708:function(n,t,o){},710:function(n,t,o){},712:function(n,t,o){},714:function(n,t,o){},716:function(n,t,o){},718:function(n,t,o){},720:function(n,t,o){},722:function(n,t,o){},724:function(n,t,o){},726:function(n,t,o){},728:function(n,t,o){},730:function(n,t,o){},732:function(n,t,o){},734:function(n,t,o){},736:function(n,t,o){},738:function(n,t,o){},740:function(n,t,o){},742:function(n,t,o){},744:function(n,t,o){},746:function(n,t,o){},748:function(n,t,o){},750:function(n,t,o){},752:function(n,t,o){},754:function(n,t,o){},756:function(n,t,o){},758:function(n,t,o){},760:function(n,t,o){},762:function(n,t,o){},764:function(n,t,o){},766:function(n,t,o){},769:function(n,t,o){"use strict";o.r(t);o(768),o(766),o(764),o(762),o(760),o(758),o(756),o(754),o(752),o(750),o(748),o(746),o(744),o(742),o(740),o(738),o(736),o(734),o(732),o(730),o(728),o(726),o(724),o(722),o(720),o(718),o(716),o(714),o(712),o(710),o(708),o(706)}});
!function(n){function t(t){for(var e,i,f=t[0],c=t[1],l=t[2],p=0,s=[];p<f.length;p++)i=f[p],u[i]&&s.push(u[i][0]),u[i]=0;for(e in c)Object.prototype.hasOwnProperty.call(c,e)&&(n[e]=c[e]);for(a&&a(t);s.length;)s.shift()();return r.push.apply(r,l||[]),o()}function o(){for(var n,t=0;t<r.length;t++){for(var o=r[t],e=!0,f=1;f<o.length;f++){var c=o[f];0!==u[c]&&(e=!1)}e&&(r.splice(t--,1),n=i(i.s=o[0]))}return n}var e={},u={1:0},r=[];function i(t){if(e[t])return e[t].exports;var o=e[t]={i:t,l:!1,exports:{}};return n[t].call(o.exports,o,o.exports,i),o.l=!0,o.exports}i.m=n,i.c=e,i.d=function(n,t,o){i.o(n,t)||Object.defineProperty(n,t,{enumerable:!0,get:o})},i.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},i.t=function(n,t){if(1&t&&(n=i(n)),8&t)return n;if(4&t&&"object"==typeof n&&n&&n.__esModule)return n;var o=Object.create(null);if(i.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:n}),2&t&&"string"!=typeof n)for(var e in n)i.d(o,e,function(t){return n[t]}.bind(null,e));return o},i.n=function(n){var t=n&&n.__esModule?function(){return n.default}:function(){return n};return i.d(t,"a",t),t},i.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},i.p="";var f=window.webpackJsonp=window.webpackJsonp||[],c=f.push.bind(f);f.push=t,f=f.slice();for(var l=0;l<f.length;l++)t(f[l]);var a=c;r.push([770,0]),o()}({707:function(n,t,o){},709:function(n,t,o){},711:function(n,t,o){},713:function(n,t,o){},715:function(n,t,o){},717:function(n,t,o){},719:function(n,t,o){},721:function(n,t,o){},723:function(n,t,o){},725:function(n,t,o){},727:function(n,t,o){},729:function(n,t,o){},731:function(n,t,o){},733:function(n,t,o){},735:function(n,t,o){},737:function(n,t,o){},739:function(n,t,o){},741:function(n,t,o){},743:function(n,t,o){},745:function(n,t,o){},747:function(n,t,o){},749:function(n,t,o){},751:function(n,t,o){},753:function(n,t,o){},755:function(n,t,o){},757:function(n,t,o){},759:function(n,t,o){},761:function(n,t,o){},763:function(n,t,o){},765:function(n,t,o){},767:function(n,t,o){},770:function(n,t,o){"use strict";o.r(t);o(769),o(767),o(765),o(763),o(761),o(759),o(757),o(755),o(753),o(751),o(749),o(747),o(745),o(743),o(741),o(739),o(737),o(735),o(733),o(731),o(729),o(727),o(725),o(723),o(721),o(719),o(717),o(715),o(713),o(711),o(709),o(707)}});
//# sourceMappingURL=engineStyle.bundle.js.map

26
dist/vendor.bundle.js vendored

File diff suppressed because one or more lines are too long

@ -40,7 +40,6 @@ export interface IActionParams {
isStealth?: boolean;
isKill?: boolean;
count?: number;
countGrowth?: number;
weights?: StatsMultiplier;
decays?: StatsMultiplier;
teamCount?: number;
@ -78,7 +77,6 @@ export class Action implements IAction {
* Growth rate is an integer and the count will increase by that integer every "cycle"
*/
count: number = getRandomInt(1e3, 25e3);
countGrowth: number = getRandomInt(1, 5);
// Weighting of each stat in determining action success rate
weights: StatsMultiplier = {
@ -122,7 +120,6 @@ export class Action implements IAction {
if (params && params.isKill) this.isKill = params.isKill;
if (params && params.count) this.count = params.count;
if (params && params.countGrowth) this.countGrowth = params.countGrowth;
if (params && params.weights) this.weights = params.weights;
if (params && params.decays) this.decays = params.decays;

@ -9,7 +9,6 @@ export class BlackOperation extends Operation {
constructor(params: IOperationParams | null = null) {
super(params);
this.count = 1;
this.countGrowth = 0;
}
// To be implemented by subtypes

@ -7,6 +7,7 @@ import { IBladeburner } from "./IBladeburner";
import { IActionIdentifier } from "./IActionIdentifier";
import { ActionIdentifier } from "./ActionIdentifier";
import { ActionTypes } from "./data/ActionTypes";
import { Growths } from "./data/Growths";
import { BlackOperations } from "./BlackOperations";
import { BlackOperation } from "./BlackOperation";
import { Operation } from "./Operation";
@ -1857,7 +1858,6 @@ export class Bladeburner implements IBladeburner {
rankGain: 0.3,
hpLoss: 0.5,
count: getRandomInt(25, 150),
countGrowth: getRandomInt(5, 75) / 10,
weights: {
hack: 0,
str: 0.05,
@ -1890,7 +1890,6 @@ export class Bladeburner implements IBladeburner {
rankGain: 0.9,
hpLoss: 1,
count: getRandomInt(5, 150),
countGrowth: getRandomInt(5, 75) / 10,
weights: {
hack: 0,
str: 0.15,
@ -1923,7 +1922,6 @@ export class Bladeburner implements IBladeburner {
rankGain: 0.6,
hpLoss: 1,
count: getRandomInt(5, 150),
countGrowth: getRandomInt(5, 75) / 10,
weights: {
hack: 0,
str: 0.2,
@ -1960,7 +1958,6 @@ export class Bladeburner implements IBladeburner {
rankGain: 2.2,
rankLoss: 0.2,
count: getRandomInt(1, 100),
countGrowth: getRandomInt(10, 40) / 10,
weights: {
hack: 0.25,
str: 0.05,
@ -1996,7 +1993,6 @@ export class Bladeburner implements IBladeburner {
rankLoss: 0.4,
hpLoss: 2,
count: getRandomInt(1, 100),
countGrowth: getRandomInt(10, 40) / 10,
weights: {
hack: 0.2,
str: 0.05,
@ -2030,7 +2026,6 @@ export class Bladeburner implements IBladeburner {
rankLoss: 0.5,
hpLoss: 2.5,
count: getRandomInt(1, 150),
countGrowth: getRandomInt(3, 40) / 10,
weights: {
hack: 0.25,
str: 0.05,
@ -2065,7 +2060,6 @@ export class Bladeburner implements IBladeburner {
rankLoss: 2.5,
hpLoss: 50,
count: getRandomInt(1, 150),
countGrowth: getRandomInt(2, 40) / 10,
weights: {
hack: 0.1,
str: 0.2,
@ -2100,7 +2094,6 @@ export class Bladeburner implements IBladeburner {
rankLoss: 2,
hpLoss: 10,
count: getRandomInt(1, 150),
countGrowth: getRandomInt(1, 20) / 10,
weights: {
hack: 0.1,
str: 0.1,
@ -2136,7 +2129,6 @@ export class Bladeburner implements IBladeburner {
rankLoss: 4,
hpLoss: 5,
count: getRandomInt(1, 150),
countGrowth: getRandomInt(1, 20) / 10,
weights: {
hack: 0.1,
str: 0.1,
@ -2211,15 +2203,29 @@ export class Bladeburner implements IBladeburner {
// Count increase for contracts/operations
for (const contract of Object.values(this.contracts) as Contract[]) {
let growthF = Growths[contract.name];
if (growthF === undefined)
throw new Error(
`growth formula for action '${contract.name}' is undefined`,
);
contract.count +=
(seconds * contract.countGrowth) /
BladeburnerConstants.ActionCountGrowthPeriod;
(seconds * growthF()) / BladeburnerConstants.ActionCountGrowthPeriod;
console.log(
(seconds * growthF()) / BladeburnerConstants.ActionCountGrowthPeriod,
);
}
for (const op of Object.values(this.operations) as Operation[]) {
const growthF = Growths[op.name];
if (growthF === undefined)
throw new Error(
`growth formula for action '${op.name}' is undefined`,
);
if (growthF !== undefined) {
op.count +=
(seconds * op.countGrowth) /
(seconds * growthF()) /
BladeburnerConstants.ActionCountGrowthPeriod;
}
}
// Chaos goes down very slowly
for (const cityName of BladeburnerConstants.CityNames) {

@ -48,7 +48,6 @@ export interface IAction {
* Growth rate is an integer and the count will increase by that integer every "cycle"
*/
count: number;
countGrowth: number;
// Weighting of each stat in determining action success rate
weights: IStatsMultiplier;

@ -0,0 +1,24 @@
import { getRandomInt } from "../../../utils/helpers/getRandomInt";
export const Growths: {
[key: string]: (() => number) | undefined;
["Tracking"]: () => number;
["Bounty Hunter"]: () => number;
["Retirement"]: () => number;
["Investigation"]: () => number;
["Undercover Operation"]: () => number;
["Sting Operation"]: () => number;
["Raid"]: () => number;
["Stealth Retirement Operation"]: () => number;
["Assassination"]: () => number;
} = {
Tracking: () => getRandomInt(5, 75) / 10,
"Bounty Hunter": () => getRandomInt(5, 75) / 10,
Retirement: () => getRandomInt(5, 75) / 10,
Investigation: () => getRandomInt(10, 40) / 10,
"Undercover Operation": () => getRandomInt(10, 40) / 10,
"Sting Operation": () => getRandomInt(3, 40) / 10,
Raid: () => getRandomInt(2, 40) / 10,
"Stealth Retirement Operation": () => getRandomInt(1, 20) / 10,
Assassination: () => getRandomInt(1, 20) / 10,
};

@ -54,7 +54,10 @@ export function findCrime(roughName: string): Crime | null {
return Crimes.GrandTheftAuto;
} else if (roughName.includes("kidnap")) {
return Crimes.Kidnap;
} else if (roughName.includes("assassinate")) {
} else if (
roughName.includes("assassinate") ||
roughName.includes("assassination")
) {
return Crimes.Assassination;
} else if (roughName.includes("heist")) {
return Crimes.Heist;