-
Notifications
You must be signed in to change notification settings - Fork 331
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
CIP-0122? | Logical operations over BuiltinByteString #806
CIP-0122? | Logical operations over BuiltinByteString #806
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks @kozross, looks great - please keep us updated in PR comments about how the path-to-active progresses. 🙏
@michaelpj @zliu41 can you review this? I've added to the agenda for introduction at the next CIP Editor meeting: https://hackmd.io/@cip-editors/88
@michaelpj @zliu41 comment would be appreciated |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good work as usual! I'm basically happy with this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@kozross excellent response to this at the CIP Editors' Meeting on Tuesday of this week. Editors (cc @Ryun1 @Crypto2099) will look to responses to points from @michaelpj's #806 (review) to see what to do next.
re: my #806 (review) about Path to Active, it looks good to me now... althrough if you think those bulleted items might progress intermittently I would suggest turning them into tickboxes.
Co-authored-by: Robert Phair <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good as of ef3ecb9 & will invite other editors to confirm.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was looking at this while I was reviewing the implementation and added a few comments about fairly superficial things, most of which don't need any response. I didn't check things like the details of the semantics: I'll try to come back and review it more thoroughly later.
CIP-0122/CIP-0122.md
Outdated
* Ignore the bytes of the longer argument whose indexes would not be valid for | ||
the shorter argument, then perform the operation as if on matching-length | ||
arguments. We call this _truncation semantics_. | ||
* Fail with an error whenever argument lengths don't match. We call this |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One advantage of failing is that you'd find out immediately if something's the wrong length. When padding/truncation happens automatically a single input of the wrong length in a long chain of calculations will propagate through to the very end and it might be difficult to work out where the problem originated. That's just a comment however: I'm not going to insist that the choice made here is the wrong one.
CIP-0122/CIP-0122.md
Outdated
|
||
### Bit setting | ||
|
||
`writeBits` in our description takes a change list argument, allowing |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this is a good choice! I'd initially assumed that you'd have to do these things a bit at a time, and the resource bounds on on-chain scripts would really reduce the usefulness in that case. Allowing a list of updates is a neat solution to that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! I came at it from the point of memory use: if you're forced to copy something 10 times to change 10 bits, this is quite bad in a setting where you have limited resources.
CIP-0122/CIP-0122.md
Outdated
## Abstract | ||
|
||
We describe the semantics of a set of logical operations for Plutus | ||
`BuiltinByteString`s. Specifically, we provide descriptions for: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A very pedantic comment: in Plutus Core the types are called bytestring
, integer
, and so on: see the Plutus Core specification. BuiltinByteString
, BuiltinInteger
etc are Haskell types in PlutusTx, which are not the same thing, and may not be meaningful to implementers of other languages targeting Plutus Core. I don't think it's necessary to change the notation though, since it's pretty clear what's going on (and I think the same notation was used in the integer/bytestring conversion CIP and nobody noticed). It might also be argued that the document should use the Plutus Core syntax ((con bytestring #123456)
and so on) but that would require a lot of work and would just make the document much less readable. I think the mapping between the Haskell-type notation here and the lower-level syntax for Plutus Core should be pretty clear.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Now I'm wondering what "Plutus" really means in this document. Our names are a bit confusing and strictly there's no such thing as Plutus: there are only (typed and untyped) Plutus Core and the Haskell thing called PlutusTx. There's a suggestion that we should reduce confusion by reserving the name "Plutus" for the thing that runs on the chain (ie, untyped Plutus Core) and rename PlutusTx to something else. I don't know when (or if) that's likely to happen though.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a good point more generally: some clarity in what terms we use in CIPs would be good to have, similar to how something like RFC-2119 specifies what certain words mean exactly and standardizes their use.
Co-authored-by: Ryan <[email protected]>
82f80e6
to
7597213
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@kozross we were ready to merge this at tonight's CIP meeting but first we need you to change the proposal document name from the current CIP-0122.md
to README.md
.
@rphair - done. Sorry for the confusion on my part. |
This CIP describes several operations over bits, including AND, OR and XOR, as well as indexing, setting, and clearing, operating on
BuiltinByteString
. Additionally, it provides a 'replication' operation to produce aBuiltinByteString
of a given length full of identical bytes.Human-readable form