Game is using pseudo-randomness but forget to warn us about it? (Full Version)

All Forums >> [New Releases from Matrix Games] >> Shadow Empire



Message


demiare -> Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 7:02:33 PM)

Recently I'd decided to cheat one stratagem for me via save/load. And discovered a few "funny" things:
0) Saves are overwritten on loading them with a different checksum, so they're altered during loading. That get my first WTF face.
1) So to check my worst guess I saved "basic" version of save in another folder on my HDD and replaced it each time after attempting to load & execute a stratagem.
2) I have DC 150 and d100+61 roll. This should mean I have 11% chance of success. Seems easy? Except I used 40 attempts and still not get it.
This is almost impossible statistically (99.05% chance to get at least single success in 40 tries).
3) During my tries I saw result 147 six times. Again - it's almost impossible statistically if game using honest d100 rolls.

Exactly same experience I have with tech discoveries - I have 5 available basic techs, two of them are power plant one. Over 12 attempts to reload save & end turn (counting only attempts that triggered tech discovery, not fruitless one!) I had ZERO power plant discoveries.
This is statistically impossible again (99.78% chance to trigger one of two power plant techs at least once in case of "honest" random).

This is insanely annoying. Why? Basic tech consist of 3 Mil and 7 Eco. Every re-balance of budget lead to massive minuses to relationships & I really need basic military techs too. So I'm forced to unlock next tech groups while lacking critical energy generation techs OR eat extreme penalties for disabling Military Research (idea of delaying military techs and spread budget 70-30 between Eco&Mil councils is not on table at all!).
In my previous tries I was lucky to have a power generating asset nearby but now I don't see any of them while I'm finishing to deal with 3rd zone (and spies unlocked 4th one to me).
Combine it with completely vague mechanism of tech discovery - as game show ZERO info how much BP I need accumulate & how high is my chance to unlock new tech...

P.S. Because of this both finds I'm no longer willing to play this game as this is third time when SE is lying to me (first one was Borealis start - game happily generate planet with no water while description is promising it & don't allow to make a snow-filled planet as restriction on max share of sea is too severe for it + even basic life is seems to be prohibited on such planets).

Sorry but I have zero understanding why game need a some kind of anti-cheat protection while AI is cheating like crazy openly and shamelessly (free roads + with a single lvl1 office & command bunker lvl1 it was capable to keep in Admin lvl with me while I was cheating "unlimited" PP myself to unlock councils ASAP and have lvl2 bunker & lvl1 office too).




zuekamo -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 7:56:02 PM)

this game needs an Ironman option to avoid the savescuming




Ekaton -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 8:13:53 PM)

Huh, that's quite interesting. Hope Vic can elaborate.




zgrssd -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 8:32:45 PM)

All games use Pseudorandom Number Generators? Or do you think the game has a connection to a wall full a Lava Lamps or something that elaborate?

What you talk about is preserving the seed. Wich is really jsut a normal thing that games do since Civilisation 2.




JamesHunt -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 8:43:18 PM)

quote:

ORIGINAL: zuekamo

this game needs an Ironman option to avoid the savescuming

Even more relevant for multiplayer as PBEM is very prone for getting exploited by cheaters backuping saves and "try-scumming" until they satisfied with their turn results. Even when RNG generation is fixed in the savegame beforehand by playing variations cheaters still achieve what they´re looking for. You often encounter those MP AARs were one was playing super-perfect which at times can raise the suspicion that this method was used.

That the save is modified during loading could indicate a safety protection against this (save could store information about loading attempts in order to expose cheaters), although backuping saves basically bypasses this as the OP did.

I remember for DC Barbarossa somebody mentioned that he believed that there is something in place to prevent brute force savescum RNG attacks and that he felt convinced restarting the game offset or reseted some of this non-randomness. Could be subjective impression although I didn´t follow this as I never was interested in playing with such methods.




Falke -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 8:47:20 PM)


1) That you had different results in all that reloading means that a RNG seed is not being saved, that would prevent a different result.
2) A Statistically calculated 99.99% chance is still not 100%- Statistically 100 coin tosses should have 50 heads and 50 tails. In reality the actual result varies between 100 heads and 100 tails.
3) If always having power tech early is such an issue, just start with L4 Tech
4) There is no need to change the relative budget, worst case just set the council to 100% Discovery which costs 2pp.This BP is not wasted as it gets used once new areas are available




Smidlee -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 8:49:32 PM)

Zgrssd is right. There is no true randomness in computer programs.




Lovenought -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 9:10:36 PM)

I don't get it? If you reload game properly (just save before a roll or end turn, then reload and do it again) you get a different result each time. I used savescumming all the time during my practice games where I needed all the help I could get.




ZiggyMaca -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 9:13:16 PM)

OP; did you restart the game between save scum testing runs? You know, I don't really care too much, I think you saying the game lied to you is... dramatic? All entertainment tricks you to some extent.




zgrssd -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/23/2020 9:51:12 PM)

quote:

ORIGINAL: demiare

Recently I'd decided to cheat one stratagem for me via save/load. And discovered a few "funny" things:
0) Saves are overwritten on loading them with a different checksum, so they're altered during loading. That get my first WTF face.
1) So to check my worst guess I saved "basic" version of save in another folder on my HDD and replaced it each time after attempting to load & execute a stratagem.
2) I have DC 150 and d100+61 roll. This should mean I have 11% chance of success. Seems easy? Except I used 40 attempts and still not get it.
This is almost impossible statistically (99.05% chance to get at least single success in 40 tries).
3) During my tries I saw result 147 six times. Again - it's almost impossible statistically if game using honest d100 rolls.

0) that is a bug I already reported. Not even sure it is actuall changing anything, but the date is updated either way.
2) The chance of failing one roll as 89%.
The chance of missing the roll 40 times in a row, is 89%^40. So 0.9% I think.
"Not impossible. Just really, really unlikely." - Trillian McMillian, Hitchhikers Guide to the Galaxy.


3) Bithday paradox. The chance for any two rolles to be same, is higher then the chance for any roll to match a specific number. You just noticed it with 147.
With chances, one of hte best indicator of faulty data is stiff to be to evenly distributed.

And that is before we get into the issue of Pseudorandom Numbers, Programming errors, seed preservation, the specific parts of your input changing the RNG, and how .NET Initializes the RNG if it got no input.

And then you never specified wich stratagem you used. Some of them use really odd rolls - like the Retirement ones. And the Ui is not always properly showing it.




diamondspider -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 12:51:20 AM)

Very interesting! I'd guess bugs.




demiare -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 2:05:23 AM)

quote:

ORIGINAL: Falke
1) That you had different results in all that reloading means that a RNG seed is not being saved, that would prevent a different result.
2) A Statistically calculated 99.99% chance is still not 100%- Statistically 100 coin tosses should have 50 heads and 50 tails. In reality the actual result varies between 100 heads and 100 tails.
3) If always having power tech early is such an issue, just start with L4 Tech
4) There is no need to change the relative budget, worst case just set the council to 100% Discovery which costs 2pp.This BP is not wasted as it gets used once new areas are available


1) Yes it's usage of seed, sorry for using wrong term. No, game can use a seed to generate a small sequence instead of single value.
2) Yes, but receiving THREE events with statistical probability less then 1%... Sure, I can be unlucky but highly doubt I'm THAT unlucky [:D].
Plus I saw here that other users had similar issues with power plant techs.
3) No, this isn't a solution. If technologies are weighted instead of being based on honest random we should know about it as it's affecting our strategic plans. Plus you know - if power plant techs are low-weighted (or even scripted to be last) then we may have OTHER unfairly delayed techs. This will again affect our development.
Will be fun to play in Civilization without ability seeing a tech tree - while it's still using it? For me it's not, especially if you aren't on "settler" difficulty :)
4) Thanks, I will try it if it will work because I was sure that all points that unable to be used would be transferred in another work - same as with research while you haven't discovered any techs.

quote:

ORIGINAL: zgrssd
2) The chance of failing one roll as 89%.
The chance of missing the roll 40 times in a row, is 89%^40. So 0.9% I think.
"Not impossible. Just really, really unlikely." - Trillian McMillian, Hitchhikers Guide to the Galaxy.
3) Bithday paradox. The chance for any two rolles to be same, is higher then the chance for any roll to match a specific number. You just noticed it with 147.


2) Failing <1% roll three times statistically is less then 1:1M. Highly improbable. But guess I would do an another try in a day or two.
3) 6 times over 40 attempts rolling a same die on d100 dice? Of course it's still possible, but highly unlikely.

quote:

ORIGINAL: zgrssd
And then you never specified wich stratagem you used. Some of them use really odd rolls - like the Retirement ones. And the Ui is not always properly showing it.


Protectorate. Description saying it's a single d100 roll against static calculated difficulty.
I know how wonky could be XdX rolls because of my D&D experience and basic education in statistic. [:)]




lloydster4 -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 3:09:57 AM)

You failed a 161 DC. Move on.

In the time it took you to compile all this data you could have been having fun or gone for a walk or done something productive.




diamondspider -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 3:19:28 AM)

That is not fair. If an 11% chance is really a 0.1% chance, it is a very serious and annoying bug that could perhaps have only been detected with a lot of testing like that. I recently had a case of getting something like 10 critical successes in a row in situations that it was around 50% just to pass it (meaning very low probability of critical), so it could be there are bugs in both directions.




demiare -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 5:37:30 AM)

Well I don't have time to repeat my experiment until tomorrow but I reloaded my save one time more. And get again 147 as result. Now it's 7 out of 41. [:D]
Now I'm almost 100% sure that game either save a seed or somehow fail to re-initialize RNG correctly.

quote:

ORIGINAL: lloydster4

You failed a 161 DC. Move on.

In the time it took you to compile all this data you could have been having fun or gone for a walk or done something productive.


I'm actually enjoying digging into math behind game. For example I'd spent more then hundred hours in Stellaris on pure experiments to determine best weapon load-out and fleet composition. [:)]

quote:

ORIGINAL: diamondspider

That is not fair. If an 11% chance is really a 0.1% chance


If you don't believe to me then zgrssd already posted a formula in his latest post here.
Chance to fail 40 times out of 40 tries is (1 - 11%)^40 = (89%)^40 = (0.89)^40 =~ 0.0094, or 0.94%.
Opposite or NOT fail 40/40 will be to get at least one success. Chance for it will be (1 - 0.94%) =~ 99.1%.




diamondspider -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 6:00:43 AM)

Was responding to prior post and agreeing with you that this is a valid point.




Vic -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 7:26:14 AM)

Ah right... yeah actually the leader relation modifier (-20 / +20 range) is implemented in a special way. It loads the dice for the actual 1d100 roll.
This means that a Relation 100 leader who gets +20 will roll 20% of the cases 100 and never below 21.

best wishes,
Vic




diamondspider -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 7:30:19 AM)

Cool. Also explains why, with a bit of luck, I got so many criticals with about 100 relation on my leader.




josefrees -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 7:30:53 AM)

I’ve played enough games where it tells me I have a 99% chance to hit and I miss that I know that 99% is not 100%




MC456 -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 12:18:56 PM)


quote:

ORIGINAL: zuekamo

this game needs an Ironman option to avoid the savescuming

Yep, this is one thing I've always suggested. Not only is it good to prevent save-scumming and give players a better sense of accomplishment, but it also allows for a more competitive experience. Telling someone you beat X_planet on the hardest difficulty doesn't mean anything when you can just re-roll all your stratagems and combat rolls.




demiare -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 2:57:56 PM)

quote:

ORIGINAL: Vic

Ah right... yeah actually the leader relation modifier (-20 / +20 range) is implemented in a special way. It loads the dice for the actual 1d100 roll.
This means that a Relation 100 leader who gets +20 will roll 20% of the cases 100 and never below 21.


Can you explain a bit further what we have now?
As I'm understand game roll d100, mod with with relation modifier while keeping resulting value between 1 and 100. Then apply skill&goverment bonuses.
But here is an important question about strategem tooltip. We can have two different situations:
A) In tooltip we see all bonuses, including +/- for relationship. So it's purely correct one, except positive or negative relationship bonus affect min & max possible value.
B) Relationship bonus isn't included in tooltip at all.

My guess that we have "B" situation and this could explain everything I'm receiving from save/load tries. So please, clarify it. [&o]




Daltesh -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/24/2020 8:06:09 PM)

I think that forcing ironman on casual players would be a bad idea. Bugs and save game corruption are real concerns.

There also seems to be some misunderstanding here about psuedorandom number generators. They typically work off a seed provided by the system clock, so the operator adds a random element to it. This is an issue if you have many thousands of people trying to get different random numbers at the same time, but for one human playing a singleplayer game (who isn't intentionally altering their system clock), a pseudorandom number generator is essentially as random as a physical die.




diamondspider -> RE: Game is using pseudo-randomness but forget to warn us about it? (6/25/2020 3:36:09 AM)

This has nothing to do with pseudo-randomness. It has to do with that the "roll" that is shown vs. the target value does not state that the leader making it can give it an additional plus or minus 20. This is a 40 delta which, on rolls that are often in the 100 range, is HUGE.

The upshot is to pay your leaders very well. There are many reasons it is important to keep basically all of your leaders near 100 relation. If it falls clear to 50, they complain and cause more and more problems, give minuses to important rolls, and provide less benefit to orgs. These are key mechanics in this game, not side-cases that have little impact.




Page: [1]

Valid CSS!




Forum Software © ASPPlayground.NET Advanced Edition 2.4.5 ANSI
0.625