get rid of rollover rep

This commit is contained in:
Olivier Gagnon 2021-11-05 16:09:19 -04:00
parent ec76c2ecca
commit f8917473f8
4 changed files with 20 additions and 35 deletions

@ -39,12 +39,6 @@ export class Faction {
*/ */
playerReputation = 0; playerReputation = 0;
/**
* Reputation from the last "prestige" that was not converted to favor.
* This reputation rolls over and is used for the next favor calculation
*/
rolloverRep = 0;
constructor(name = "") { constructor(name = "") {
this.name = name; this.name = name;
} }
@ -64,31 +58,18 @@ export class Faction {
if (this.favor == null) { if (this.favor == null) {
this.favor = 0; this.favor = 0;
} }
if (this.rolloverRep == null) { this.favor += this.getFavorGain();
this.rolloverRep = 0;
}
const res = this.getFavorGain();
if (res.length !== 2) {
console.error("Invalid result from getFavorGain() function");
return;
}
this.favor += res[0];
this.rolloverRep = res[1];
} }
//Returns an array with [How much favor would be gained, how much rep would be left over] //Returns an array with [How much favor would be gained, how much rep would be left over]
getFavorGain(): number[] { getFavorGain(): number {
if (this.favor == null) { if (this.favor == null) {
this.favor = 0; this.favor = 0;
} }
if (this.rolloverRep == null) { const storedRep = Math.max(0, favorToRep(this.favor));
this.rolloverRep = 0; const totalRep = storedRep + this.playerReputation;
} const newFavor = repToFavor(totalRep);
const storedRep = Math.max(0, favorToRep(this.favor - 1)); return newFavor - this.favor;
const totalRep = storedRep + this.rolloverRep + this.playerReputation;
const newFavor = Math.floor(repToFavor(totalRep));
const newRep = favorToRep(newFavor);
return [newFavor - this.favor + 1, totalRep - newRep];
} }
/** /**

@ -9,11 +9,13 @@ export function favorToRep(f: number): number {
function fma(a: number, b: number, c: number): number { function fma(a: number, b: number, c: number): number {
return a * b + c; return a * b + c;
} }
const ex = fma(f, Math.log(51.0) - Math.log(50.0), Math.log(51.0)); const ex = fma(f - 1, Math.log(51.0) - Math.log(50.0), Math.log(51.0));
return fma(500.0, Math.exp(ex), -25000.0); const raw = fma(500.0, Math.exp(ex), -25000.0);
return Math.round(raw * 10000) / 10000; // round to make things easier.
} }
// Wolfram Alpha: 500 (50^(-n) 51^(n + 1) - 50) solve for n // Wolfram Alpha: 500 (50^(-n) 51^(n + 1) - 50) solve for n
export function repToFavor(r: number): number { export function repToFavor(r: number): number {
return -Math.log(25500 / (r + 25000)) / Math.log(51 / 50); const raw = Math.log((r + 25000) / 25500) / Math.log(1.02) + 1;
return Math.round(raw * 10000) / 10000; // round to make things easier.
} }

@ -44,7 +44,7 @@ export function Info(props: IProps): React.ReactElement {
const classes = useStyles(); const classes = useStyles();
const favorGain = props.faction.getFavorGain()[0]; const favorGain = props.faction.getFavorGain();
return ( return (
<> <>
<Typography classes={{ root: classes.noformat }}>{props.factionInfo.infoText}</Typography> <Typography classes={{ root: classes.noformat }}>{props.factionInfo.infoText}</Typography>
@ -54,15 +54,17 @@ export function Info(props: IProps): React.ReactElement {
title={ title={
<> <>
<Typography> <Typography>
You will have <Favor favor={props.faction.favor + favorGain} /> faction favor after installing an You will have <Favor favor={Math.floor(props.faction.favor + favorGain)} /> faction favor after
Augmentation. installing an Augmentation.
</Typography> </Typography>
<MathJaxContext> <MathJaxContext>
<MathJax>{"\\(\\huge{r = \\text{total faction reputation}}\\)"}</MathJax> <MathJax>{"\\(\\huge{r = \\text{total faction reputation}}\\)"}</MathJax>
</MathJaxContext> </MathJaxContext>
<MathJaxContext> <MathJaxContext>
<MathJax> <MathJax>
{"\\(\\huge{favor=\\left\\lfloor\\log_{1.02}\\left(\\frac{r+25000}{25500}\\right)\\right\\rfloor}\\)"} {
"\\(\\huge{favor=1+\\left\\lfloor\\log_{1.02}\\left(\\frac{r+25000}{25500}\\right)\\right\\rfloor}\\)"
}
</MathJax> </MathJax>
</MathJaxContext> </MathJaxContext>
</> </>
@ -96,7 +98,7 @@ export function Info(props: IProps): React.ReactElement {
} }
> >
<Typography> <Typography>
Faction Favor: <Favor favor={props.faction.favor} /> Faction Favor: <Favor favor={Math.floor(props.faction.favor)} />
</Typography> </Typography>
</Tooltip> </Tooltip>
</Box> </Box>

@ -908,7 +908,7 @@ export function NetscriptSingularity(
helper.updateDynamicRam("getCompanyFavorGain", getRamCost("getCompanyFavorGain")); helper.updateDynamicRam("getCompanyFavorGain", getRamCost("getCompanyFavorGain"));
helper.checkSingularityAccess("getCompanyFavorGain", 2); helper.checkSingularityAccess("getCompanyFavorGain", 2);
const company = getCompany("getCompanyFavorGain", companyName); const company = getCompany("getCompanyFavorGain", companyName);
return company.getFavorGain()[0]; return company.getFavorGain();
}, },
checkFactionInvitations: function (): any { checkFactionInvitations: function (): any {
helper.updateDynamicRam("checkFactionInvitations", getRamCost("checkFactionInvitations")); helper.updateDynamicRam("checkFactionInvitations", getRamCost("checkFactionInvitations"));
@ -1096,7 +1096,7 @@ export function NetscriptSingularity(
helper.updateDynamicRam("getFactionFavorGain", getRamCost("getFactionFavorGain")); helper.updateDynamicRam("getFactionFavorGain", getRamCost("getFactionFavorGain"));
helper.checkSingularityAccess("getFactionFavorGain", 2); helper.checkSingularityAccess("getFactionFavorGain", 2);
const faction = getFaction("getFactionFavorGain", name); const faction = getFaction("getFactionFavorGain", name);
return faction.getFavorGain()[0]; return faction.getFavorGain();
}, },
donateToFaction: function (name: any, amt: any): any { donateToFaction: function (name: any, amt: any): any {
helper.updateDynamicRam("donateToFaction", getRamCost("donateToFaction")); helper.updateDynamicRam("donateToFaction", getRamCost("donateToFaction"));