The present inventions relate to electronic devices and systems and, more particularly, relate to trusted customization thereof.
Systems have been used for customizing computers and mobile telephones. Typically these systems provided for user level preference settings such as display language, alert settings, service level (such as media bandwidth) and font, within limitations defined by a service provider or the user, or a manufacturer, etc., and combinations thereof. However, conflicts between the entities that affect preference settings can cause extra work and complexity for the user.
Furthermore, when customizations are made, requests and authorizations may not originate from a legitimate source. What is needed is the ability to gain confidence in the legitimacy of an entity who determines a requirement.
Advanced systems and devices for determining and setting customizations are needed that provide for customizations in a trustworthy manner.
Details of the inventions will be more readily understood from the following detailed description when read in conjunction with the accompanying drawings wherein:
Electronic devices and portable electronic devices, such as mobile telephones or portable computers, have various components, features or attributes available for use. These components need to be chosen. When customizations are made, requests and authorizations may not originate from a legitimate source. What is needed is the ability to gain confidence in the legitimacy of an entity who determines a requirement before determining and setting customizations in an electronic device. The embodiments of the present inventions provide for selection in a trustworthy manner.
The user of an electronic device as well as the manufacturer of the electronic device, the service provider for the electronic device, the seller of the electronic device, and the application or software provider of the electronic device are all stakeholders which may desire influence over a chosen configuration. Besides the user, the device manufacturer, the service provider, the seller of the electronic device, and the application provider, an application developer, a content owner, and an environment location owner can also be a stakeholder which may desire influence over a chosen configuration.
When a stakeholder influences the choice, it is important that the stakeholder is legitimate and authorized. Otherwise non-payment for characteristics such as applications or services is possible through fraud or misrepresentation.
A capability table 120 holds a plurality of capability table records. Each capability table record is a candidate for a portable device 130. The capability table 120 is stored in memory 110. A given capability table 120 defines recommended characteristics of user interface categories to be established for various capabilities of a device. These characteristics can be sets of capabilities, features or attributes desired for the electronic device. An electronic device uses one or more capability table records from the table 120 to define capabilities, features or attributes desired for the electronic device. The attributes might be user interface elements. Example capabilities are alert, keys, text, video and image. The values for each characteristic defined in the capability record table 120 are values such as on or off, list selections, numbers or ranges.
The capability table 120 of
A characteristic can define a desired persistence, for example, of an alert or a key press. The ranges can be defined by a desired maximum and minimum range of characteristics for one or more user interface elements. A discrete value can defines a desired characteristic for one or more user interface elements. At any given time, although there may be only one capability table record 122 for the processor of the device 130 to correlate, typically a device 130 will be presented from the capability table 120 with many capability table records 122. When the processor faces multiple capability table records 122, the correlation method 133 decides which attributes to use. In one approach, the correlation method 133 combines discrete capability table records to find attributes common to the capability table records 122 of the table 120. In another approach, in the case of a capability table record 122 with ranges, the correlation method 133 combines ranges of the capability table records to find ranges that are common to the capability table records 122 of the table 120.
The correlation method 133 can correlate the desired characteristics in the capability table records 122 with a components database 140. By correlating the desired characteristics for a device with the available components in a device, a configuration is determined for the portable device 130. This correlation gives the characteristics “wish list” a “reality check” as to the available components on a device. Stakeholder requirements can also be added to this correlation to further filter or prioritize the configuration choices, and signed certificates used for trust, as will be described below.
Each portable device 130 is associated with a components database 140. The components database 140 may be stored in memory 145 which can be the memory of the portable device 130, depending on a chosen system configuration. The components database 140 is coupled to the portable device 130 at 147. The components database 140 contains lists of the components available in the portable device 130. The components database 140 also lists, for each component, capabilities of that component. For example, a camera component would have its capabilities define the kinds of images producible by the camera such as mpeg or jpg.
Depending on the level a user has purchased from a service provider, from a manufacturer, from an application provider, from a software provider, or from other stakeholders, the capabilities of the components may or may not be chosen or enabled in the electronic device. Further, the user may be considered to be a stakeholder and may desire his or her own level of certain components within the electronic device.
A portable electronic device 130 such as a mobile telephone has its operation characteristics (the values of features, capabilities or attributes used in operation) selected by use of the available capability table records. The capability table record 120, the components database 140, a stakeholder requirements table 138 and stakeholder priority certificates 136 may be used for this selection. The capability table 120 is also coupled to the portable device 130 at 127.
Stakeholder priority certificates 136 hold stakeholder priority codes for applications and also hold an authentication signature. The stakeholder priority certificates 136 are coupled to the portable device 130 at 137. The stakeholder priority certificates 136 are delivered to the portable electronic device for storage in memory therein by modem over a network or via other mechanisms such as Bluetooth, IR or on a smart or SIM card.
A stakeholder requirements table 138 holds stakeholder priority sequences. The stakeholder requirements table 138 is coupled to the portable device 130 at 139. These stakeholder priority sequences can be derived from the stakeholder priority certificates 136. The processor of the portable device 130 can derive these stakeholder priority sequences for the stakeholder requirements table 138 by collecting the priority codes from the stakeholder certificates and ranking the stakeholders relative to one another.
The portable electronic device 130 checks the authentication signatures in the stakeholder priority certificates 136 to ensure that the priorities are authorized before implementing the determined characteristics for the device 130.
Characteristics for the device 130 are determined using a correlation method 133 to negotiate operation characteristics of the electronic device. The correlation is preferably performed by the device 130 using the priority entries in the stakeholder requirements table 138 and the capability table 120 ands components database 140.
The embodiments of the present inventions provide methods for negotiation of operation characteristics of the electronic device based on trusted stakeholder priorities. The method 133 assures stakeholder requirements are authorized to eliminate fraud or theft of unauthorized device features. The method 133 also determines operation characteristics of the electronic device by correlating one or more of the capability table records 122 with the component database 140 for a portable device 130, and using stakeholder priorities from a stakeholder requirements table 138 to resolve any conflicts that arise from the correlation. These priorities use a stakeholder certificate for trusted capability selection for the components of the portable device.
An example use is the characteristics selection for the components of a mobile phone based on a purchased subscriber levels. The purchased subscriber level may be indicated within the stakeholder priorities for a particular end user or device.
The correlation between the records of the capability table 120 and the components database 140 can be a matching process followed by thresholding. After the thresholding, conflict resolution can be applied.
An example of one matching process is to take the vector dot product on the rows of the table against the database. This is then followed by thresholding to select the best matching rows that are above a certain threshold. The rows above the threshold are then run through the conflict resolution process 133 and authorized and ranked based on the stakeholder.
A first embodiment of the correlation of the method 133 uses stakeholder priority based conflict resolution. In this approach, the combination of capabilities is cast as a constrained linear optimization problem with the constraints ordered according to the stakeholder priorities. There are a number of well known methods in the literature for solving these types of constrained optimization problems, including linear programming, simplex methods and convex hull methods. Examples can be found in Principles of Operations Research, H. M. Wagner, 1975. In all of these methods, the basic approach is to minimize some measure of dissatisfaction, which is a weighted combination of the degree of dissatisfaction of all of the constraints. Constraints determined by high priority stakeholders are assigned higher weights and are thus more likely to be resolved early. The optimization method will proceed until a global minima is found. The general method allows constraints to be defined in terms of continuous ranges of values, but a simplification is to allow each constrained to simply be represented by a binary variable which is 0 if the constraint is satisfied and non-zero otherwise. For this special case, binary programming can be used which is a more efficient form of optimization algorithm.
A second embodiment of the correlation of the method 133 uses filter, or category, based conflict resolution. This is a simpler, but much more efficient to implement form of conflict resolution. It is not in general guaranteed to provide an optimal solution, but it does guarantee that the constraints of the highest priority stakeholder are completely met, and as many non-conflicting constraints of subsequent stakeholders are met as possible.
The approach is fairly simple, and can be illustrated by considering a particular example. Imagine that there are three stakeholders, a service provider, a location owner and the device owner. The service provider has a requirement that emergency messages which it transmits to an end-user device must create an audible ring of at least level 3 (assume we have 10 volume levels for illustration). Currently the user is in a restaurant which requires any audible ring to be of a maximum volume of 4. Finally, our user is suffering some hearing loss, and has a preference that any audible ring be of at least level 5. We assume here that the priority ordering of stakeholders is that the service provider has highest priority and the end user lowest priority. The constraint of the first stakeholder says that the volume must be greater than or equal to 3, so any value from 3 to 10 is valid after considering this stakeholder. The second stakeholder adds a constraint of volume less than or equal to 4. So “anding” these two constraints we have the volume must be greater than or equal to 3 and less than or equal to 4. An audible ring level of 3 or 4 allows the constraints of both the first and second stakeholder to be met. The constraint of the third stakeholder is incompatible with the constraint of the second stakeholder, so it will not be satisfied and the combination of constraints stops at this point. If you think of each constraint as being a filter on allowed values of a variable, then we are combining together these filters as long as they are compatible with each other, until we have the tightest filter possible.
The negotiation or correlation method 133 can be performed in the portable device 130 or alternatively on a server in its network or system.
The processor 250 also assures that the stakeholders are legitimate and authorized by checking the authentication signature on each of the stakeholder requirements certificates 240. Non-payment for characteristics such as applications or services through fraud or misrepresentation can thus be prevented.
Further, the processor 250 has access to the components database 260 of the electronic device 200. The components database 260 is typically established in the electronic device 200 at the time of its manufacture, but could be downloaded or updated over the modem 220. Also, the capability table records 230 and stakeholder requirements 240 could be established by the electronic device 200 rather than received from the network over the modem.
The processor 250 can perform a correlation within the electronic device 200 to determine the operation characteristics using one or more capability table records 230, the components database 260 and the stakeholder requirements 240. The processor 250 can execute a conflict resolution process to resolve conflicts among stakeholder requirements such as arbitrating among at least two of the stakeholders or using a stakeholder requirements table. The processor 250 can override the stakeholder requirement of the stakeholder requirements table. The capability table record 230 can comprise the stakeholder requirements table.
Although a radio transceiver and antenna is illustrated for the electronic device 200 of
Although some of the tables may be described above as being stored in the electronic device, the tables can alternatively be stored on a server connected over the network to the electronic device. Furthermore the processor for performing the stakeholder decisions can either access the records over the network or could itself also be located on a server and deliver the decisions over the network to the portable electronic device.
Exemplary hardware features are illustrated in
In the representation of the example in
The stakeholder priority sequences 410 illustrated in the example of
The priority numbers for the stakeholders define which hardware features apply to which applications in what stakeholder priorities. Thus, the stakeholder software requirements table of
Values can be received over the network from a service provider to store in a stakeholder requirements table. The values of the stakeholder requirements table can be determined based on a degree of service provider subsidy. They can be set initially on service provider setup and then altered upon subsequent setup changes initiated by the service provider.
According to an alternate embodiment stakeholder requirements can be expressed using a stakeholder filter. In this an alternate embodiment, when a feature is assessed such as upon a request, the feature is passed through a series of the filtering constraints. The filtering constraints define whether a feature is allowed. The filter constraints generally act as AND gate to require all constraints are met. An override filtering constraint acts as an OR gate to allow a feature regardless of whether the other constraints are met. Priorities for each of a plurality of the stakeholders are resolved using this alternate table. By establishing the filter constraints for each feature and needs of the stakeholders, this alternate table representing a method for making these decisions is provided.
To implement this alternate embodiment, the valid stakeholder certificates are ANDed together to provide the allowable applications in a rank determined by the processor using the priority codes for each stakeholder in each stakeholder certificate.
Although the inventions have been described and illustrated in the above description and drawings, it is understood that this description is by example only, and that numerous changes and modifications can be made by those skilled in the art without departing from the true spirit and scope of the inventions. Although the examples in the drawings depict only example constructions and embodiments, alternate embodiments are available given the teachings of the present patent disclosure.
This application is related to applications being filed concurrently with the USPTO, and assigned to the assignee hereof, identified as: “THEME RECORDS DEFINING DESIRED DEVICE CHARACTERISTICS AND METHODS OF SHARING”, attorney docket number CML04619HISTR; and “STAKEHOLDER CERTIFICATES”, attorney docket number CS27780STARS.