00:53:12 oh I suppose so 02:04:46 I just re-read the latest ristretto draft specifically looking for what is required and what is forbidden. Here are the highlights. 02:05:01 External ristretto functions: Decode, Encode, Equals, One-way map. 02:05:12 Implementations MUST NOT define any external ristretto255 or decaf448 interface as operating on arbitrary curve points. 02:05:21 Implementations MUST NOT construct group elements except via decoding and the one-way map. 02:06:17 Internal representations MUST NOT be compared in any other way than [the provided algorithm] 02:06:30 Implementations MAY also perform byte comparisons on encodings for an equivalent, although less efficient, result. 02:06:47 It is RECOMMENDED that implementations do not perform a decoding and encoding operation for each group operation, as it is inefficient and unnecessary. Implementations SHOULD instead provide an opaque type to hold the internal representation through multiple operations. 02:07:20 Implementations are allowed to apply any optimization strategy to the internal representations... 04:08:13 tevador> It's still better to have a design that supports more rather than less because we're unlikely to have a second chance to do a complete overhaul of addresses. When the proposal is complete, I will also add a "minimal implementation" specs that can ignore all of the extra features. >>> yeah, i assume this is how it will go. the first presentation on network will just be a different monero address.... except well you need to also 04:08:13 include the existing base functionality, so something equivalent to integrated addresses .. whatever tier that is 04:11:09 is it possible to roll jamtis out using the current RingCT machinery? this straddles research / dev, but I think a concern (no idea how valid, just throwin spaghetti on the wall) is that we're doing jamtis *and* seraphis all at the same time, because seraphis needs something new 04:11:53 i mean, because it sounds like something like jamtis would be beneficial even without seraphis, seraphis just gives us an excuse by way of being a necessity to change the addressing stuffs 04:13:59 and, in the case that seraphis runs into some major whoopsie during the next year and needs to cook for a few more years (i mean, obviously not wanting that to happen), should we wait for jamtis? or does jamtis require a new engine 04:41:21 jamtis only works with seraphis (it could probably work with lelantus-spark as well) 04:44:57 dang 05:11:37 "jamtis only works with seraphis..." <- What does RingCT need that jamtis cannot provide? 12:51:16 So, is the idea that view tags will remain one byte forever? Or is the plan to have an easily adaptable size that can change with changing needs? 13:00:52 Different key image construction 13:04:11 View tags could increase in size, but the performance gain is negligible. Jamtis scanning services would be more efficient with larger tags because users would have to download less data, but the scanning service would have a much more accurate view into your tx history. 13:04:32 So I doubt view tags will ever get larger 13:07:01 I'd be curious to know how view tags interfere with ring signatures and heuristics from change outputs. 13:07:42 That is, with a naive outlook, I think view tags might partly break the privacy ring signatures offer. 13:08:07 Not for a single tx, but for a tx history where a change output gets respent, etc. 13:08:23 I don't know how to go about checking though. 13:09:29 Is there a performance comparison for "scan N outputs" vs "scan N outputs with view tags" to see how much faster view tags are in practice ? 13:09:56 (or at least in "simulated" practice) 13:51:24 jberman has done simulations on the real-world gains for view-tags, will try to find. 14:15:59 moneromooo: we already discussed this, change outputs will have a new definition in jamtis to mitigate linking 14:17:29 "View tags could increase in size..." <- I am trying to understand how the performance gain is neglible from a future proofing perspective. With each additional bit on the view tag, the set of matches should halve in size. Is that correct? 14:18:22 If the set of results grows faster than light client performance, there will eventually be performance issues. 14:33:13 Yes there are fewer matches, but the cost of a match vs fail is only like 1.25x - 2.5x. If your rate of matches is 1/256, you can’t gain more than ~1% further speed up with larger view tags. 15:00:53 So... instead of T*N time to scan N outputs, you get T * N / 256 + 255 * T/2 * N / 256, roughly ? 15:01:09 (/2 being around 1.25x - 2.5x) 15:01:31 ie, you still need about half the time to reject ? 15:02:14 I was thinking of bandwidth, not computation. How long will it take a light wallet to download the set of potential matches? Will that growth outstrip light wallet performance gains? 15:12:52 hypothetically let's say it's dynamic: more transactions, bigger viewtag, more granular light wallets... consider what happens if a surreptitious lightwallet service launches a flood attack. Not only do they gain knowledge of their own outputs, which can be used to eliminate decoys from ring sigs, but they also gain information about their own users visa vie higher resolution viewtags. Anyway, considering light wallets work fine for 15:12:53 the most part without view tags right now, I'm not too worried about about future performance with viewtags. 15:14:46 I think most users will have a CPU bottleneck rather than a download speed bottleneck. I do not have hard numbers though. 15:15:40 I'd imagine some suers it's CPU some bandwidth but I also not hard numbers just personal experience 15:17:04 btw what if any work was done to settle on 1 byte? I understand 2 bytes isn't useful, but maybe 7 bits, or 9, Idk 15:18:07 LyzaL: Wouldnt flooding transactions be prohibitively expensive? You would have to double the total number of transaction in the blockchain with view tags to justify adding 1 bit to the view tag. 15:20:24 not as expensive as you might think, according to research, and you gain a lot more by doing it than just the viewtag. It effectively would make FloodXMR slightly more effective for an attacker that also ran a lightwallet service, I think 15:20:42 moneromooo: yes, although I think it’s actually like [T*.6 - T*.75] 15:22:07 1 byte is a standard size, that’s all 15:24:07 wernervasquez[m]: if bandwidth becomes an issue for light wallets in the future, then we can revisit view tag size. That probably won’t happen for a long time. 15:27:55 Light wallets have to download all key images anyway, which should require more data than view tag matches on average. A view tag match is ~4-6 x 32 bytes and a key image is ~32 bytes, so on average ~1/64th of the data downloaded by light wallets is outputs. 15:28:09 In jamtis* 15:28:45 Although tevador’s idea to use a bloom filter instead of downloading key images might change that equation 15:50:11 So a rough approximation is that the maximum speedup you can get is ~3x, correct ? 15:57:46 No, it’s 40% 15:58:23 And only for 2-out tx 16:00:24 Oh sorry. x1.5 then. 16:01:55 isthmus[m]: do you have an opinion on what damage can a third party being able to pigeonhole users into 256 bins do ? 16:03:23 People allowing themselves to be fingerprinted would have x256 scanning speedup, right ? 16:04:13 Hmm, more like ~x170 since they'd get the x1.5 even if they did not. 16:04:42 x170 is very significant, x1.5 isn't. Mixed emotions... 16:28:38 I have no idea what you are talking about 16:31:49 Which line(s) ? 16:33:29 All of it 16:33:41 Hrm. OK: 16:34:22 "x1.5" -> if the speedup for "matching" outputs is 40%, then speedup is about x1.5 roughly. 16:35:55 "isthmus" -> I was asking about the "strenght" of an attack based on an adversary being able to know "outputs A and B do not belong to the same account" for a good amount of accounts, since a good amount of users will presumably allow themselves to be fingerprinted for the speedup gain. 16:36:39 "People..." -> I was asking whether the speedup you get if you get fingerprinted is really about x256. This seems likely since you only get 1/256 outputs to scan. 16:37:13 "x170" -> the very rough speedup you'd get from: x1.5 base (you scan all yourself) and x256 (you let an adversary prescan for you). 16:37:26 Does that clear it up ? 16:40:07 Light wallets don't have to do any scanning (aside from change and self-spends), they just need to do bytewise matches with their subaddress table. 16:42:42 In general, it should be assumed that a scanning service will know all the non-change/self-spend outputs you receive, and can narrow down change/self-spend outputs to 1/256 of the output set. The only way to hide non-change/self-spends is to use a unique address with a semi-trusted party. 16:43:30 non-change/non-self-spend* 17:32:27 So, if Alice receives money from Bob several times (same address), the third party daemon knows all these outputs are to the same address, rather than all go to an address with hte same view tag ? 17:33:22 So basically no privacy in exchange for... ok, really good speedup. 17:34:53 (no privacy for received outs at least) 17:37:35 So third party daemons can basically split the output set between people who like privacy and people who don't care, even for future outputs. 17:37:44 (right ?) 17:38:24 So there is massive incentive for people who don't care about privacy to shrink the privacy pool for others. 17:38:57 (and we can assume TPDs will be run by assholes, like we've seen with public access daemons) 17:42:03 Currently TPDs don't know which outputs are owned by their users (or should not, there used to be a timing vuln for this, so it's always possible there's a remnant or another). 17:43:45 That is, assuming I understand "bytewise matches with their subaddress table", which I take to mean "the TPD calculates that value, and since it's a bytewise match, it implies two sends to that address mean the TPD also cals the same value". 17:45:01 This scanning ability is to replace what MyMonero does, not what remote nodes do. 17:45:43 So you think people who use TPDs now would not switch to these new third party scanning types ? 17:46:27 ? I am making a technical statement, not speculating. M 17:48:57 The problem is we either get a cryptonote-style view key that gives remote scanners deep insight into user finances, or this view-tag based approach that hides as much as possible while still being useful enough that people don’t fall back to the super-power-view-key approach. 17:49:40 Well, I thought the view tag was "pigeonhole in one of 256 buckets", but from the above, it seems it allows much more. 17:50:05 (I might be wrong here ?) 17:50:20 Well I’d encourage you to go read the material on this, because I can’t explain it here 17:51:32 I think I'm burnt out enough on monero not to, at least for now. I'll shut up then. 17:55:12 I could see a lot of people switching away from remote nodes to this, potentially. Seems like a reasonable concern despite what the intent is 17:55:28 the intent of the proposal I mean 17:56:28 I think the upshot is there would be a bunch of different service providers in that case 17:56:36 spreading the info 18:19:04 random idea: https://github.com/monero-project/research-lab/issues/96 18:25:10 tevador: you can only make a tx input with a real key image, ie only a real spend works 18:38:39 moneromooo: Ok there are two things here. 1) view tags let a scanner efficiently discard 255/256 outputs (~25-40% faster than usual). 2) the scanner computes a nominal spend key for the 1/256th output. In jamtis, the scanner would send all view-tag matches with nominal spend keys to the light wallet, which would match those nominal spend keys against their subaddress spend keys to find real spends. If A) the scanner 18:38:39 knows user addresses then they can immediately recognize outputs send to those addresses, B) if multiple outputs are sent to the same address then there will be duplicate nominal spend keys. Change and self-spends are hidden from scanners by using a hidden nominal spend key. To find change and self-spends, the light wallet looks in all txs that contain the wallet’s key images and manually checks their outputs 18:38:39 (actually, just the outputs that the remote scanner flagged as view tag matches, since those are the only available outputs to the light wallet - if change-out view tags were hidden from remote scanners then the light wallet would have no way to efficiently obtain the outputs of those txs without leaking much more info to the remote service). The tricks to hide change outputs done work in cryptonote because your view 18:38:39 key must be able to identify all owned outputs. Jamtis has a key hierarchy that splits out some viewing authority into a separate key that the scanning service can use. 18:41:50 Oh, maybe a three-key address could allow cryptonote to hide change outs as well... 18:42:44 Anyway the standard cryptonote address scheme doesn’t allow it 18:56:43 UkoeHB: if you have a zero-amount commitment C = r G then r Hp(C) is a valid key image and the LSAG will validate AFAICS 19:02:02 oh I see now 19:04:15 yes I suppose that would work 19:29:56 "UkoeHB: if you have a zero-..." <- I think it is a promising idea. 20:11:52 I guess the only issue I see is that dummy inputs add a lot more to the TX size that dummy outputs thanks to ring sigs. but for sure seems worth exploring 20:17:14 I guess the optimal configuration would be something like 6/16 20:18:02 that woule be around 5 KB in size 21:11:14 Just a short independent notice: I've just integrated the preliminary version of optimization to the blockchain prediction. I will be releasing it about in the middle of next week. 21:11:14 Which coincidentally matches the above message :) 21:15:55 blockchain prediction? 21:16:32 UkoeHB: Actually - prediction of whatever series you put in. 21:16:58 I just don't like to speak in 100% abstract way. 21:19:28 In this case, but current test data are the number of transactions in a discrete timestep. 22:18:10 did someone say dummy inputs.... 22:54:41 "did someone say dummy inputs...." <- It looks pretty promising.