-
UkoeHB
I probably won’t make it to the meeting if someone else wants to take charge.
-
Rucknium[m]
I can run the meeting. Meeting in 2.5 hours
-
Rucknium[m]
-
Rucknium[m]
1) Greetings....who is here?
-
vtnerd_
hi
-
rbrunner
Hello
-
Rucknium[m]
2) Updates. What is everyone working on?
-
Rucknium[m]
Working on OSPEAD things (something to discuss today). Dr. Borggren's research project to analyze the EAE attack and churning has been fully funded:
monerofund.org/projects/eae_attack_and_churning
-
rbrunner
Nice
-
vtnerd_
zmq/rmq stuff for LWS, and some small work on bp++. If the paper audit doesn't provide me with more helpful equations, I may have to try and port the C version
-
vtnerd_
they seem to deviate from the naming schema in their one doc, so its annoying :/
-
Rucknium[m]
3) Discussion
-
xmrack[m]
Hi
-
Rucknium[m]
We have limited attendance due to MoneroKon, so this conversation can continue into next week. To get the conversation started: I am setting up the parameters for the "validation" Monte Carlo simulations to recover the real spend age distribution.
-
Rucknium[m]
I argue that OSPEAD is consistent. Consistency is an asymptotic property, i.e. the behavior of the estimator as sample size approaches infinity. Since sample size is finite, we want to make sure that our sample size is adequate for the task.
-
Rucknium[m]
I want to have one main "validation" set of parameters so I can test sample sizes and adjustments. Just change those things instead of changing parameters. When the parameters change, the target also changes, so it can get hard to compare things.
-
Rucknium[m]
My "draft" now is:
-
Rucknium[m]
There are three Decoy Selection Algorithms (DSAs):
-
Rucknium[m]
1) "wallet2". Log-gamma, shape = 19.28, rate = 1.61. 80% of rings will be constructed with this DSA.
-
Rucknium[m]
2) "unknown DSA #1". Log-triangular, min = 20 minutes, max = 1 year, mode = 1 week. 15% of rings.
-
Rucknium[m]
3) "unknown DSA #2". Uniform, min = 20 minutes, max = 1 year. 5% of rings.
-
Rucknium[m]
The real spend age distribution is the empirical distribution of Litecoin, 10th week of 2022, shifted 20 minutes to match the 10 block lock.
-
Rucknium[m]
-
Rucknium[m]
The objective is to get a close estimate of the "real spend", which is litecoin. If OSPEAD gets a close estimate, then "we ship it".
-
Rucknium[m]
Of course we don't know the true Monero real spend...that's what we are trying to estimate in the first place.
-
vtnerd_
so I guess litecoin was thought to be a better model than bitcoin?
-
Rucknium[m]
Actually, I already ran OSPEAD on these parameters and it does a pretty good job with 200,000 rings as sample size, which is about a week of blockchain data
-
xmrack[m]
I reached out to the authors of the constant time and size range proof for an update and they said.... (full message at <
libera.ems.host/_matrix/media/v3/do…fda845b8b5197d494b314e439b5945e66b7>)
-
Rucknium[m]
vtnerd_: Yes. Bitcoin has full blocks and higher fees. LTC matches Monero closer in that respect. And block discovery interval time. We could try bitcoin too. Probably the outcome would not be much different.
-
Rucknium[m]
xmrack: Thanks!
-
Rucknium[m]
I'm not sure what I should do about the fact that LTC outputs can be spent in the same block they are confirmed in. That alone accounts for about 8% of spent outputs.
-
Rucknium[m]
I shift it 20 minutes to be like Monero, but I don't think 8% of Monero outputs are spent as soon as the 10 block lock expires.
-
rbrunner
With "pretty good job", does that mean that your new OSPEAD algorithm comes close to that LTC curve? Or something else altogether that I may not understand with my rudimentary knowledge about statistics
-
Rucknium[m]
I could just eliminate all LTC spent outputs that are spent in the sample block as created.
-
Rucknium[m]
rbrunner: Yes. So if it comes close to LTC, which is known, then t will come close to XMR, which is unknown. We can measure how close it comes to LTC since we actually have the LTC real spends.
-
Rucknium[m]
it will*
-
rbrunner
So on a high and abstract level, it's something like "Given a curve, search for a formula that comes close"?
-
Rucknium[m]
Extremely high level, yes
-
rbrunner
Yeah, thought so :)
-
Rucknium[m]
Data is constructed just like the Monero blockchain
-
rbrunner
But at least that gives me a hint how to think about it, in broad terms :)
-
Rucknium[m]
For one ring:
-
Rucknium[m]
I determine what DSA I will use. It's 80% wallet2, 15% unknown #1, 5% unknown #2. This is to take into account that mulitiple DSAs are in the wild.
-
Rucknium[m]
It's it's wallet2, then I randomly and independently select 15 decoys from the log-gamma distribution. Then I select one real spend from the LTC distribution. Those 16 random draws form a ring
-
Rucknium[m]
Then I do that 200,000 more times to form 200,000 rings.
-
Rucknium[m]
Then I run OSPEAD on it to recover the LTC distribution
-
Rucknium[m]
I don't directly give it the LTC distribution since there is nothing like that on the Monero blockchain. We don't know which ring members are real spends.
-
rbrunner
Just curious, are your tools fast enough now for these simulations, so run times do not drag you down too much?
-
Rucknium[m]
It would be good to have a faster implementation. I am working on that. Now it takes about 10 minutes on 200 CPU threads for a single iteration. You want 10-100 iterations for Monte Carlo simulations if you are being not very rigorous. More if being rigorous.
-
Rucknium[m]
I have to vary sample size, adjust certain things again to test how the estimator reacts, of course.
-
Rucknium[m]
That's with about 200,000 rings
-
rbrunner
Interesting, thanks
-
Rucknium[m]
If anyone has an opinion about which distribution distance metric would be best for the distance between the LTC distribution and its OSPEAD estimate, please me know. For now I am using the Kolmogorov-Smirnov distance since it is convenient, but I am open to using something else.
-
Rucknium[m]
Anything else to discuss?
-
rbrunner
Not from me, also going to pack for MoneroKon now ...
-
Rucknium[m]
We can end the meeting here.
-
Rucknium[m]