As enterprises accumulate ever-greater amounts of data on their transactions, processes, products, and operations, online analytical processing has become an important part of doing business. The number of tools and techniques addressing analytical processing has grown, enabling data analysts to quickly analyze and navigate through vast and complex collections of data using processing software and platforms. Processing software systems use objects to represent real-world items used during the transaction of business. For example, an object may include logic and/or structured data, and may be used to represent a document, such as a sales order, a purchase order, an invoice, a product, a partner company, or equipment. The underlying structure of the object may be determined based on the requirements of the environment in which the object is to be used. In many instances, objects, such as documents in a document flow, include data that can be used in a variety of ways to facilitate understanding of the data by users/customers of the associated analytical processes. However, such data may be spread among many documents in the document flow, and its extraction and processing may be time-consuming and challenging.
Databases and business objects are highly useful tools allowing users to manage complex relationships between large amounts of different types of data. When data is requested to be read, analyzed, and returned in a de-normalized view from a database, in general a user interface (UI), web service, data export and the like will formulate a use scenario, such as a query, search, or free search having features, to the database. The database can include a large number of instantiated business objects, entities that include attributes and associations with other business objects.
Typically, different data models and business object frameworks are implemented in a complex architecture. For example, an integration of each business model into different user interface (UI) technologies can include complex integrations with differing frameworks. Therefore, systems implemented using the UI technologies and the different business models result in different components and the point-to-point integrations. The point-to-point integrations can result in a high total cost of development (TCD) for the business object framework development, maintenance, and the integration effort for the system. Experiences for application developers can be less than ideal, because each of the different integrations have no harmonized look and feel. Again this can results in a high TCD for the developer as well as any partners and/or customers, because no common concepts, tooling and integrations are in place in the current art. As a result, a developer has to learn point to point integration. In addition, a combination of different integrations may not be possible or may require a significant amount of manual effort.
The Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. The Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
In an example aspect of the disclosure, a computer-implemented method of developing a user interface is disclosed and may include receiving a software development framework-independent data processing application of a consumption layer. A software development framework type may be received from a plurality of supported software development framework types of a model layer. A plurality of object models adhering to the selected software development framework type of the model layer may be displayed. A particular object model out of the plurality of object models may be received. A plurality of elements from the particular object model may be displayed for incorporation into the user interface. A selection of elements may be received out of the plurality of elements. The user interface may be generated, where the generating may include incorporating the selected elements for the software development framework-independent data processing application according to the particular object model of the selected software development framework type of the model layer.
In another aspect of the disclosure, a user interface (UI) configurator system may include a plurality of framework-specific object models, each object model including a plurality of elements for selection in a user interface; a framework-independent data processing application associated with a data source; and an interface processor. The interface processor may be operable to couple the framework-independent data processing application with the plurality of framework-specific object models. The plurality of object models may include at least a database dictionary model and a search model. The interface processor may be configured to display a selection of the plurality of elements for a selected object model out of the object models. In response to a selection of one or more of the plurality of displayed elements, a UI may be generated based on the selection of displayed elements. The UI may couple the data processing application to the selected object model. The UI may include a search interface associated with the selection of the plurality of elements. A preview of the UI may be displayed, where the preview of the UI is updated upon selection of a new element, and the preview of the UI is updated upon de-selection of a selected element. Upon receiving a final element selection, the UI may be stored in one or more computer-readable media for use with the data processing application.
As described herein, a variety of other features and advantages can be incorporated into the technologies as desired.
The technologies described herein can be used in a user interface development environment using a model layer, where the resulting UI provides an interface between a consumption layer object and one or more model layer objects. A data processing application can be developed independent of and be decoupled from a particular software development framework type. Via the technologies described herein, user interfaces incorporating elements from a variety of software development framework types can be generated for such an application. A user interface development tool can present a unified development user interface across and generic to different software development framework types.
As used herein, the terms “data” or “information content” can include analytics data, such as created analytics reports, analytics, or other artifacts created by enterprise database suites (e.g., SAP's Crystal Reports, Lumira Datasets, WEBI reports, XCelcius reports, etc.). The data or information content can also be other, arbitrary content such as spreadsheets, images, documents in a document flow, user interfaces, web services, or the like.
As used herein, the term “object” (or “business object”) may represent real-world items used during the transaction of business, such as documents (e.g., a sales order, a purchase order, an invoice, etc.), a product, a partner company, a piece of equipment, and so forth. A business object may include business logic and/or data having any suitable structure, which may be based on the requirements of the business scenario in which the business object is to be used. For example, a business object (or a user interface for rendering data for business objects, or a web service for accessing data for business objects) may include a plurality of attributes (or data), where the attributes may be associated with access paths to the locations (e.g., database locations) storing the attributes' data. Each attribute may be associated with one or more backend data processing services used for querying, retrieving and manipulating the data. As used herein, the terms “object” and “object model” are interchangeable. An example business object and associated attributes is illustrated in
As used herein, the term “metadata” means data about other data, and the term “analytics metadata” can include metadata associated with information content, as well as metadata associated with one or more locations hosting the information content. For example, for a given analytics report, the “analytics metadata” may include metadata associated with the report itself (e.g., title, author, date of creation, report fields, report columns, linked information sources, and the like), as well as metadata associated with the database connection for the analytics report (e.g., metadata associated with a database, a database query and/or a data cube used for accessing or hosting the analytics report). Additionally, analytics metadata for one category of database connections (e.g., a database) may be associated (e.g., linked) to analytics metadata associated with another database connection category (e.g., a query and/or a cube), and/or to analytics metadata associated with information content that is accessible via the database connection. Furthermore, analytics metadata may include information for one or more attributes (or data) associated with a meta object model as well as the access path (e.g., location to a node, a database or another data location) for accessing data associated with the attribute.
As used herein, the term “model layer” refers to a software development layer where one or more software development frameworks are used to generate objects (or object models) (e.g., business objects or data models). The model layer objects can be associated with a plurality of software development framework types, where each type can include a plurality of framework-specific objects (or object models), each object model having a plurality of elements. One or more of the object models and object model elements may be accessed by an application in a consumption layer.
As used herein, the term “consumption layer” refers to a backend, where one or more data processing applications (or objects) that are independent of a software development framework, may reside. The data processing application may include an application developing framework, data access service, report-generating application, and so forth. Each consumption layer object may access one or more of the model layer objects using, for example, a user interface in accordance with the description herein.
In this document, various methods, processes and procedures are detailed. Although particular steps may be described in a certain sequence, such sequence is mainly for convenience and clarity. A particular step may be repeated more than once, may occur before or after other steps (even if those steps are otherwise described in another sequence), and may occur in parallel with other steps. A second step is required to follow a first step only when the first step must be completed before the second step is begun. Such a situation will be specifically pointed out when not clear from the context. A particular step may be omitted; a particular step is required only when its omission would materially impact another step.
In this document, the terms “and”, “or” and “and/or” are used. Such terms are to be read as having the same meaning; that is, inclusively. For example, “A and B” may mean at least the following: “both A and B”, “only A”, “only B”, “at least both A and B”. As another example, “A or B” may mean at least the following: “only A”, “only B”, “both A and B”, “at least both A and B”. When an exclusive-or is intended, such will be specifically noted (e.g., “either A or B”, “at most one of A and B”).
In this document, various computer-implemented methods, processes and procedures are described. It is to be understood that the various actions (receiving, storing, sending, communicating, displaying, etc.) are performed by a hardware device, even if the action may be authorized, initiated or triggered by a user, or even if the hardware device is controlled by a computer program, software, firmware, etc. Further, it is to be understood that the hardware device is operating on data, even if the data may represent concepts or real-world objects, thus the explicit labeling as “data” as such is omitted. For example, when the hardware device is described as “storing a record”, it is to be understood that the hardware device is storing data that represents the record.
Applications, framework types, object models, elements, user interfaces, and the like can be represented by a reference and/or an indications of the item can be received. For example, when receiving a data processing application, a reference (e.g., name, identifier, location or the like) to the application or other indication of it can be received. Such items and the references to them can be stored in one or more computer-readable media as described herein.
The model layer object 110 may be a business object (e.g., as defined above) including, for example, a data model, functions, relationships and an associated business logic. The model layer object 110 may be implemented on a software development framework (e.g., Advanced Business Application Programming (ABAP)) as part of a model layer. In one or more example implementations, the model layer may include several additional frameworks, on which several model layer objects 110 are implemented. In this regard, since the consumption layer object 105 is a data processing application that is independent of a software development framework associated with at least one model layer object 110, developing consumption layer objects 105 may require special knowledge of and special skill for utilizing each of the several model layer objects 110.
In this regard, an interface object 115 may be configured to implement one or more model layer objects 110 in a common structure such that consumption layer objects 105 may utilize a single structure in order to interface with several model layer objects 110. In this regard, the interface object 115 may include a user interface development tool (UIDT) 116, which may be used to generate a user interface (UI) as a uniform structure for interfacing model layer objects 110 with at least one consumption layer object 105 (e.g., a data processing application or framework utilized by a developer of the consumption layer object 105). In other words, an object (e.g., a business object) associated with a model layer object 110 may be de-coupled from the framework used to implement the business object such that a developer of a consumption layer object 105 needs no special knowledge of and/or special skill in order to utilize the model layer object 110.
As shown in
In some systems the business objects (e.g., business object 205, business object item 210, and the like) may be elements of different systems (e.g., sales order management (SO) systems, product management systems, inventory management systems, enterprise resource planning (ERP) systems, and the like). Accordingly, business objects may be implemented on different frameworks or model layers (e.g., model layer 344 associated with model layer object 110). For example, the frameworks may include business object processing framework (BOPF), business object layer (BOL), service provider interface (SPI), or low level representations such as data dictionary (DDIC) tables/views, core data services, HANA views, and the like. Therefore, in order to integrate sales object 200, a developer may require special knowledge of and special skill for utilizing each of the frameworks or accessing these data models.
However, according to example embodiments, an interface object or framework or entity (e.g., interface object 115 and UIDT 116) may be used to de-couple the business object from the framework used to implement the business object using, for example, a UI developed by the UIDT 116 such that a developer needs no special knowledge of and/or special skill in order to utilize the business object and various elements associated with the business object (or another model layer object). In other words, the developer may only use a single user interface (e.g., UI generated by the UIDT 116) to interface a data processing application in a consumption layer with one or more business objects or frameworks associated with a model layer.
The consumption layer 341 can include one or more data processing applications (or objects) 305, 310, . . . , 311, which applications are independent of a software development framework (e.g., independent of the model layer 344 and model layer objects). The data processing application may include an application developing framework, data access service, report-generating application, and so forth. For example, FPM 305 is a framework for developing self-service applications using Web Dynpro® for Java®. FPM 305 may be configured to ensure that self-service applications follow a consistent pattern or road map. GW 310 may be referred to as a “gateway application” and may include a set of add-ons configured to provide the ability to make an HTTP(S) request in order to access data (i.e., a data access application). Other applications 311 can also be included in the consumption layer 341. Each of the applications 305, 310, . . . , 311 can use a data source 306a, 306b, and 306c, respectively.
The model layer 344 includes a plurality of software development framework types 346, where each type can include a plurality of framework-specific objects (or object models) 348, each object model having a plurality of elements 350.
In accordance with an example embodiment of the disclosure, the user interface development tool (UIDT) 116 may be used to generate one or more UIs (e.g., 312, . . . , 313). The UIs 312, . . . , 313 may be used at the consumption layer 341 (e.g., by a developer or user of the applications 305, 310, . . . , 311) so that one or more of the object models (in sub-layer 348) and object model elements (in sub-layer 350) may be accessed by an application in the consumption layer 341. For example, the UIDT 116 may map one or more of the elements 350 to a data source of a corresponding application (e.g., data source 306a of application 305), allowing the application to access and process data in the data source 306a using one or more of the objects 348 in the model layer 344. In this regard, the model layer 344 is de-coupled from the consumption layer 341 via the UIs 312, . . . , 313 within the de-normalized consumption layer 343.
The blocks associated with the model layer software development framework types 346 may include an enterprise search model 315, a business object layer (BOL) 320, a business object processing framework (BOPF) 325, core data services (CDS) 330, a data dictionary (DDIC) 335, a service provider infrastructure (SPI) 340, and other framework types 342.
The Enterprise Search Model 315 is an infrastructure supporting fast search and query operations on replicated data in Text Retrieval and information Extraction (TREX) (e.g., a search engine) or on original data in a High Performance Analytic Appliance (HANA) (e.g., an in-memory, column-oriented, relational database management system). The enterprise search model is an infrastructure configured to support fast search and query operations on replicated data. Enterprise search models are views on the data that can be connected with associations. Therefore, the Enterprise Search Model 315 can be described as a business object without the business logic. The associations may be used for navigation purposes on generic applications consuming these models.
The Business Object Layer (BOL) 320 is an abstraction layer for legacy code. BOL provides an infrastructure to build a business model on top of legacy code with a harmonized Application Programming Interface (API) configured to enable a model-based consumption in higher layers. The framework supports logical unit of work (LUW)/transactional handling, without input as to where the data is persisted.
The Business Object Processing Framework (BOPF) 325 is a framework configured to provide an end-to-end development experience. BOPF 325 supports the modeling of the data model and takes care of the persistency. BOPF 325 also enables the implementation of business logic as actions, determinations and validations, and may be configured to enable a consistent LUW handling (e.g., the span of time during which any database updates must be performed).
The core data services (CDS) 330 is a concept for HANA and ABAP on HANA in order to describe business objects as “first class citizens.” CDS is configured to enable the definition of query languages native syntax (e.g., DDIC, HANA) to work with the business objects.
The data dictionary (DDIC) 335 is a native Advanced Business Application Programming (ABAP) component configured to define database tables and views. These tables and views can natively be handled in ABAP as first class citizens. Persistence classes in object oriented (OO) ABAP provides classes that are representations of tables. The classes combine data models with business logic. ABAP persistence classes are a typical OR-Mapping infrastructure.
The Service Provider Interface (SPI) 340 is similar to BOL 320 but does not provide design time to model business objects. The SPI 340 may be defined via APIs. The other types 342 may include a Business Object Repository (BOR), which may be a registry for function modules. The BOR functions can be registered to enable a harmonized consumption.
Each of the model layer software development framework (SDF) types 346 (e.g., 315, . . . , 342) may include corresponding object models A1, . . . , N1 for the enterprise search model 315; A2, . . . , N2 for the BOL 320; . . . ; and A6, . . . , N6 for SPI 340. Each of the framework-specific object models 348 may include a plurality of elements 350. For example, object model A1 of the enterprise search model 315 may include elements A11, . . . , A1n, and object model N6 of the SPI 340 may include elements N61, . . . , N6n.
At 415, an element of the selected object model may be selected. For example, element A11 of the A1 object model may be selected (e.g., for inclusion in a UI generated by the UIDT 116). At 420, it may be determined whether an additional element or model type may be selected. If an additional element of the already selected SDF type (315) and object model (A1) is needed, then processing may resume at 415, when an additional element (e.g., A12) of the selected object model (A1). If additional elements but from another SDF type are needed, then processing may resume at 405 (indicated by dashed line in
At 425, a view may be built (e.g., 714 in
The UIDT 116 may comprise suitable logic, circuitry, interfaces, and/or code and may be operable to generate one or more UIs, as explained in reference to
Referring to
The UI wizard 708 may be associated with element selection 710 (e.g., steps 415-420 in
In accordance with an example embodiment of the disclosure, the elements 350 may include metadata information associated with each element. Such metadata information may indicate, for example, one or more databases that may be used as data sources for the element, generated UIs that use the element, and one or more other elements (e.g., that belong to one or more other object models) that are considered associated with (related to) the current element. Such metadata information about element associations may be entered by a developer or it may be generated based on previously generated UIs that use the current element (e.g., in this instance, the current element may be deemed associated with one or more of the other elements in the UI). Referring to
At 806, a plurality of object models adhering to the selected software development framework type of the model layer may be displayed. For example, if DDIC 335 is selected (at 704) as the framework type, a plurality of object models associated with DDIC 335 may be displayed for selection (e.g., at 706). At 808, the UIDT 116 may receive a selection of a particular object model out of the plurality of object models (e.g., object model SFLIGHT may be selected at 706) (e.g., step 410 in
At 814, the UIDT 116 may generate the user interface (e.g., 505 or 714), where the generating includes incorporating the selected elements for the software development framework-independent data processing application of the consumption layer according to the particular object model of the selected software development framework type of the model layer.
Referring to
The UI specific framework artifacts are generated by the wizard such that they bind the chosen elements of the interface objects. When the Ui is active, at runtime, the access methods exposed by the interface object are called. They, in turn, work with the data access mechanisms at the level of the business objects or models. These can be exposed by an own framework, such as BOL or BOPF, or can be direct database access in the case of DDIC or CDS artifacts.
The UI 714 may also include a search interface 718 associated with the selection of the plurality of elements. At 906, the UIDT 116 (via the UI wizard 708) may display a preview (716) of the UI, where the preview of the UI is updated upon selection of a new element or upon de-selection of a selected element. At 908, upon receiving a final element selection, the UIDT 116 may store the UI in one or more computer-readable media for use with the data processing application. For example, the UIDT 116 may store the generated UI 505 in UI persistence 506 for subsequent use by one or more applications in the consumption layer 341.
A computing system may have additional features. For example, the computing system 1000 includes storage 1040, one or more input devices 1050, one or more output devices 1060, and one or more communication connections 1070. An interconnection mechanism (not shown) such as a bus, controller, or network interconnects the components of the computing system 1000. Typically, operating system software (not shown) provides an operating environment for other software executing in the computing system 1000, and coordinates activities of the components of the computing system 1000.
The tangible storage 1040 may be removable or non-removable, and includes magnetic disks, magnetic tapes or cassettes, CD-ROMs, DVDs, or any other medium which can be used to store information in a non-transitory way and which can be accessed within the computing system 1000. The storage 1040 stores instructions for the software 1080 implementing one or more innovations described herein.
The input device(s) 1050 may be a touch input device such as a keyboard, mouse, pen, or trackball, a voice input device, a scanning device, or another device that provides input to the computing system 1000. For video encoding, the input device(s) 1050 may be a camera, video card, TV tuner card, or similar device that accepts video input in analog or digital form, or a CD-ROM or CD-RW that reads video samples into the computing system 1000. The output device(s) 1060 may be a display, printer, speaker, CD-writer, or another device that provides output from the computing system 1000.
The communication connection(s) 1070 enable communication over a communication medium to another computing entity. The communication medium conveys information such as computer-executable instructions, audio or video input or output, or other data in a modulated data signal. A modulated data signal is a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media can use an electrical, optical, RF, or other carrier.
The innovations can be described in the general context of computer-executable instructions, such as those included in program modules, being executed in a computing system on a target real or virtual processor. Generally, program modules include routines, programs, libraries, objects, classes, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The functionality of the program modules may be combined or split between program modules as desired in various embodiments. Computer-executable instructions for program modules may be executed within a local or distributed computing system.
The terms “system” and “device” are used interchangeably herein. Unless the context clearly indicates otherwise, neither term implies any limitation on a type of computing system or computing device. In general, a computing system or computing device can be local or distributed, and can include any combination of special-purpose hardware and/or general-purpose hardware with software implementing the functionality described herein.
For the sake of presentation, the detailed description uses terms like “determine” and “use” to describe computer operations in a computing system. These terms are high-level abstractions for operations performed by a computer, and should not be confused with acts performed by a human being. The actual computer operations corresponding to these terms vary depending on implementation.
The cloud computing services 1110 are utilized by various types of computing devices (e.g., client computing devices), such as computing devices 1120, 1122, and 1124. For example, the computing devices (e.g., 1120, 1122, and 1124) can be computers (e.g., desktop or laptop computers), mobile devices (e.g., tablet computers or smart phones), or other types of computing devices. For example, the computing devices (e.g., 1120, 1122, and 1124) can utilize the cloud computing services 1110 to perform computing operators (e.g., data processing, data storage, and the like).
Although the operations of some of the disclosed methods are described in a particular, sequential order for convenient presentation, it should be understood that this manner of description encompasses rearrangement, unless a particular ordering is required by specific language set forth below. For example, operations described sequentially may in some cases be rearranged or performed concurrently. Moreover, for the sake of simplicity, the attached figures may not show the various ways in which the disclosed methods can be used in conjunction with other methods.
Any of the computer-readable media herein can be non-transitory (e.g., volatile memory such as DRAM or SRAM, nonvolatile memory such as magnetic storage, optical storage, or the like) and/or tangible. Any of the storing actions described herein can be implemented by storing in one or more computer-readable media (e.g., computer-readable storage media or other tangible media). Any of the things (e.g., data created and used during implementation) described as stored can be stored in one or more computer-readable media (e.g., computer-readable storage media or other tangible media). Computer-readable media can be limited to implementations not consisting of a signal.
Any of the disclosed methods can be implemented as computer-executable instructions or a computer program product stored on one or more computer-readable storage media and executed on a computing device (e.g., any available computing device, including smart phones or other mobile devices that include computing hardware). Computer-readable storage media are any available tangible media that can be accessed within a computing environment (e.g., non-transitory computer-readable media, such as one or more optical media discs such as DVD or CD, volatile memory components (such as DRAM or SRAM), or nonvolatile memory components (such as flash memory or hard drives)). By way of example and with reference to
Any of the computer-executable instructions for implementing the disclosed techniques as well as any data created and used during implementation of the disclosed embodiments can be stored on one or more computer-readable storage media (e.g., non-transitory computer-readable media). The computer-executable instructions can be part of, for example, a dedicated software application or a software application that is accessed or downloaded via a web browser or other software application (such as a remote computing application). Such software can be executed, for example, on a single local computer (e.g., any suitable commercially available computer) or in a network environment (e.g., via the Internet, a wide-area network, a local-area network, a client-server network (such as a cloud computing network), or other such network) using one or more network computers.
For clarity, only certain selected aspects of the software-based implementations are described. Other details that are well known in the art are omitted. For example, it should be understood that the disclosed technology is not limited to any specific computer language or program. For instance, the disclosed technology can be implemented by software written in C++, Java, Perl, JavaScript, Adobe Flash, or any other suitable programming language. Likewise, the disclosed technology is not limited to any particular computer or type of hardware. Certain details of suitable computers and hardware are well known and need not be set forth in detail in this disclosure.
Furthermore, any of the software-based embodiments (comprising, for example, computer-executable instructions for causing a computer to perform any of the disclosed methods) can be uploaded, downloaded, or remotely accessed through a suitable communication means. Such suitable communication means include, for example, the Internet, the World Wide Web, an intranet, software applications, cable (including fiber optic cable), magnetic communications, electromagnetic communications (including RF, microwave, and infrared communications), electronic communications, or other such communication means.
As utilized herein the terms “circuits” and “circuitry” refer to physical electronic components (i.e. hardware) and any software and/or firmware (“code”) which may configure the hardware, be executed by the hardware, and or otherwise be associated with the hardware. As utilized herein, “and/or” means any one or more of the items in the list joined by “and/or”. As an example, “x and/or y” means any element of the three-element set {(x), (y), (x, y)}. As another example, “x, y, and/or z” means any element of the seven-element set {(x), (y), (z), (x, y), (x, z), (y, z), (x, y, z)}. As utilized herein, the term “e.g.,” introduces a list of one or more non-limiting examples, instances, or illustrations. As utilized herein, the term “processor” may be used to refer to one or more of a central processing unit, a processor of a symmetric or asymmetric multiprocessor system, a digital signal processor, a micro-controller, a graphics/video processor, or another type of processor.
The disclosed methods, apparatus, and systems should not be construed as limiting in any way. Instead, the present disclosure is directed toward all novel and nonobvious features and aspects of the various disclosed embodiments, alone and in various combinations and sub combinations with one another. The disclosed methods, apparatus, and systems are not limited to any specific aspect or feature or combination thereof, nor do the disclosed embodiments require that any one or more specific advantages be present or problems be solved.
The technologies from any example can be combined with the technologies described in any one or more of the other examples. In view of the many possible embodiments to which the principles of the disclosed technology may be applied, it should be recognized that the illustrated embodiments are examples of the disclosed technology and should not be taken as a limitation on the scope of the disclosed technology. Rather, the scope of the disclosed technology includes what is covered by the following claims. We therefore claim as our invention all that comes within the scope and spirit of the claims.
Number | Name | Date | Kind |
---|---|---|---|
8239882 | Dhanjal et al. | Aug 2012 | B2 |
20010049595 | Plumer et al. | Dec 2001 | A1 |
20060026519 | Vaindiner et al. | Feb 2006 | A1 |
20060179065 | Xu | Aug 2006 | A1 |
20070050710 | Redekop | Mar 2007 | A1 |
20090198649 | Vaughan et al. | Aug 2009 | A1 |
20090300060 | Beringer et al. | Dec 2009 | A1 |
20100161682 | Pfeifer et al. | Jun 2010 | A1 |
20100251129 | Beringer et al. | Sep 2010 | A1 |
20100251133 | Beringer et al. | Sep 2010 | A1 |
20120054262 | Demant et al. | Mar 2012 | A1 |
20130144918 | Said et al. | Jun 2013 | A1 |
20130145348 | Agovic et al. | Jun 2013 | A1 |
20130159909 | Kornmann et al. | Jun 2013 | A1 |
20130326464 | Hermanns et al. | Dec 2013 | A1 |
20140181788 | Sullivan et al. | Jun 2014 | A1 |