Technical solution to eliminate desync in single-player sessions
" If it is deterministic, it means that someone can figure out exactly how many tries it will take me to 6-link my item in this instance that I just created. So what will you do to prevent me from simply recreating instances until I notice that the deterministic "RNG-sequence" states that the it will take me 100 tries or less to 6-link in this instance? Edit: To stop this, you either have to forbid that any crafting is done in a such client-sided instance, or you need to at the very least let the server decide the RNG outcome for each try and not the client. This message was delivered by GGG defence force. Last edited by mazul#2568 on Nov 18, 2013, 12:55:47 AM
|
|
"What is the server supposed to do when it desyncs from you? When Stephen Colbert was killed by HYDRA's Project Insight in 2014, the comedy world lost a hero. Since his life model decoy isn't up to the task, please do not mistake my performance as political discussion. I'm just doing what Steve would have wanted.
|
|
" Hypothetically, this could be possible, and that's my objection to the OP's suggestion. However, it is not as simple as you suggest. The RNG state could be set up to be modified by many in-game actions: application of orbs (not just fusings), movement by the player, time passed, etc. On the other hand, if you have to rely on security through obscurity you're asking for trouble. IGN: SplitEpimorphism
|
|
Putting any hacking/cheating thoughts aside: While this might diminish desync (since checking for things like character-enemy collision would be faster) wouldn't this make loading screens way longer than they already are?
"I see now that the circumstances of one's birth are irrelevant; it's what you do with the gift of life that determines who you are." - Mewtwo
|
|
Syrioforel, thank you for the support on this. I believe you have an accurate understanding of my approach.
As it stands, the client is already transmitting a large amount of data to the server, and the server is forced to send the game state. I believe that my approach would eliminate a large amount of this data transmission because the server would never need to respond with game state. They could likely cut their costs significantly by reducing this required bandwidth. The snapshot could also be highly compressed as well. Besides, this sort of logging is what allows 'replays' and other features in games. Any game out there which has simulated replays is using a similar snapshot system (like many RTS games). You could reverse engineer the seed, but this would have virtually no benefit because any action would roll the next number. As long as loot is generated on the server, you wouldn't be able to do anything useful even if you had complete recognition of the seed's state. |
|
" The point of the OP's suggestion is that there is no sync performed at all. Data is uploaded and checked at the end of a session (instance, whatever unit of time you like), and then replayed later and verified. There's no sync to be kept. IGN: SplitEpimorphism
|
|
" I don't see why that would be the case. IGN: SplitEpimorphism
|
|
" It shouldn't. The snapshot can be streamed during play to the server, it does not need to be uploaded all at once. |
|
" But the client would have full authority to reorder the actions any way it pleases in order to optimize the outcome for the player, as long as it followed the PRNG sequence. |
|
" Crafting like this should be kept on the server. I am only talking about using a deterministic authoritative client during combat/seeding of an instance. |
|