AutofillNoiseInjectedData
class AutofillNoiseInjectedData : Parcelable
| kotlin.Any | |
| ↳ | android.view.autofill.AutofillNoiseInjectedData |
Represents the noise-injected version of a text field's content, generated using a differential privacy algorithm. While the Autofill providers won't be able to recover the actual text from the noise-injected data from one device, with uploads from sufficient number of devices, the Autofill providers are able to rebuild the constant, non-private parts of the text to help them improve Autofill detection's quality.
The noise injection process involves the following steps: 1. The original string is converted to a byte array using UTF-8 Encoding. The actual length of the string is hidden by padding with 0x0000 or truncating as needed. 2. Then for each bit in the byte array, random noise is introduced by "coin flipping": first we flip a coin to decide whether to change this bit. The probability is 50%. If we decide to change this bit, then we flip another coin to decide its new value. The probability is: 50% to be 1, 50% to be 0. 3. To further enhance privacy, each device may drop some of the bits after noise injection. getRetainedBitMask() tells you which bits are retained for the current payload.
With the coin flipping mechanism described above, each bit has 75% chance to report the real value, and 25% chance to report the opposite value(e.g. real value is 1, reported value is 0). This means if a bit remains the same across all devices(i.e. it's a part of a non-personalized string such as "Country"), then with a large enough amount of reports collected from different devices, then the ratio of real value among all reports should be close to 75%. In another word, if we see close to 75% of the reports show 1 then the real value of this bit should be a constant 1; if we see close to 75% of the reports show 0 then the real value of this bit should be a constant 0; all other distributions indicate this bit is not same across different devices(hence very likely to be personalized/private information), which should be discarded as noise.
Summary
| Inherited constants | |
|---|---|
| Public methods | |
|---|---|
| Int |
Describe the kinds of special objects contained in this Parcelable instance's marshaled representation. |
| Boolean |
Indicates whether some other object is "equal to" this one. |
| ByteArray |
Gets the noise-injected and bit-reduced data. |
| Byte |
Returns a bit mask indicating which bits were retained for *each byte* in the payload returned by |
| Int |
hashCode()Returns a hash code value for the object. |
| Unit |
writeToParcel(dest: Parcel, flags: Int)Flatten this object in to a Parcel. |
| Properties | |
|---|---|
| static Parcelable.Creator<AutofillNoiseInjectedData!> | |
Public methods
describeContents
fun describeContents(): Int
Describe the kinds of special objects contained in this Parcelable instance's marshaled representation. For example, if the object will include a file descriptor in the output of writeToParcel(Parcel,int), the return value of this method must include the CONTENTS_FILE_DESCRIPTOR bit.
| Return | |
|---|---|
Int |
a bitmask indicating the set of special object types marshaled by this Parcelable object instance. Value is either 0 or
|
equals
fun equals(other: Any?): Boolean
Indicates whether some other object is "equal to" this one.
The equals method implements an equivalence relation on non-null object references:
- It is reflexive: for any non-null reference value
x,x.equals(x)should returntrue. - It is symmetric: for any non-null reference values
xandy,x.equals(y)should returntrueif and only ify.equals(x)returnstrue. - It is transitive: for any non-null reference values
x,y, andz, ifx.equals(y)returnstrueandy.equals(z)returnstrue, thenx.equals(z)should returntrue. - It is consistent: for any non-null reference values
xandy, multiple invocations ofx.equals(y)consistently returntrueor consistently returnfalse, provided no information used inequalscomparisons on the objects is modified. - For any non-null reference value
x,x.equals(null)should returnfalse.
An equivalence relation partitions the elements it operates on into equivalence classes; all the members of an equivalence class are equal to each other. Members of an equivalence class are substitutable for each other, at least for some purposes.
| Parameters | |
|---|---|
obj |
the reference object with which to compare. |
| Return | |
|---|---|
Boolean |
true if this object is the same as the obj argument; false otherwise. |
getNoiseInjectedPayload
fun getNoiseInjectedPayload(): ByteArray
Gets the noise-injected and bit-reduced data. The original text has been transformed by a differential privacy algorithm, including random bit flips and removing some of the bits in every byte(getRetainedBitMask() tells you which bits are retained).
| Return | |
|---|---|
ByteArray |
A byte array representing the obfuscated text. This value cannot be null. |
getRetainedBitMask
fun getRetainedBitMask(): Byte
Returns a bit mask indicating which bits were retained for *each byte* in the payload returned by getNoiseInjectedPayload(). Bits not retained are marked as 0 in the returned payload. The same bit mask is applied to every byte in the payload.
| Return | |
|---|---|
Byte |
A byte where each bit corresponds to a bit position in a byte. If the n-th bit (0 <= n <= 7) is set, it means the n-th bit of each byte in the payload is retained. |
hashCode
fun hashCode(): Int
Returns a hash code value for the object. This method is supported for the benefit of hash tables such as those provided by java.util.HashMap.
The general contract of hashCode is:
- Whenever it is invoked on the same object more than once during an execution of a Java application, the
hashCodemethod must consistently return the same integer, provided no information used inequalscomparisons on the object is modified. This integer need not remain consistent from one execution of an application to another execution of the same application. - If two objects are equal according to the
equalsmethod, then calling thehashCodemethod on each of the two objects must produce the same integer result. - It is not required that if two objects are unequal according to the
equalsmethod, then calling thehashCodemethod on each of the two objects must produce distinct integer results. However, the programmer should be aware that producing distinct integer results for unequal objects may improve the performance of hash tables.
| Return | |
|---|---|
Int |
a hash code value for this object. |
writeToParcel
fun writeToParcel(
dest: Parcel,
flags: Int
): Unit
Flatten this object in to a Parcel.
| Parameters | |
|---|---|
dest |
Parcel: This value cannot be null. |
flags |
Int: Additional flags about how the object should be written. May be 0 or PARCELABLE_WRITE_RETURN_VALUE. Value is either 0 or a combination of the following:
|