AutofillNoiseInjectedData
public
final
class
AutofillNoiseInjectedData
extends Object
implements
Parcelable
| java.lang.Object | |
| ↳ | 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 |
|---|
Fields | |
|---|---|
public
static
final
Creator<AutofillNoiseInjectedData> |
CREATOR
|
Public methods | |
|---|---|
int
|
describeContents()
Describe the kinds of special objects contained in this Parcelable instance's marshaled representation. |
boolean
|
equals(Object o)
Indicates whether some other object is "equal to" this one. |
byte[]
|
getNoiseInjectedPayload()
Gets the noise-injected and bit-reduced data. |
byte
|
getRetainedBitMask()
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. |
void
|
writeToParcel(Parcel dest, int flags)
Flatten this object in to a Parcel. |
Inherited methods | |
|---|---|
Fields
Public methods
describeContents
public int describeContents ()
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.
| Returns | |
|---|---|
int |
a bitmask indicating the set of special object types marshaled
by this Parcelable object instance.
Value is either 0 or
|
equals
public boolean equals (Object o)
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 | |
|---|---|
o |
Object: the reference object with which to compare. |
| Returns | |
|---|---|
boolean |
true if this object is the same as the obj
argument; false otherwise. |
getNoiseInjectedPayload
public byte[] getNoiseInjectedPayload ()
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).
| Returns | |
|---|---|
byte[] |
A byte array representing the obfuscated text.
This value cannot be null. |
getRetainedBitMask
public byte getRetainedBitMask ()
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.
| Returns | |
|---|---|
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
public int hashCode ()
Returns a hash code value for the object. This method is
supported for the benefit of hash tables such as those provided by
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.
| Returns | |
|---|---|
int |
a hash code value for this object. |
writeToParcel
public void writeToParcel (Parcel dest, int flags)
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.PARCELABLE_WRITE_RETURN_VALUE.
Value is either 0 or a combination of the following:
|