A graphical user interface typically organizes information on a screen in a predetermined manner. For example, a user can typically choose whether objects on a screen are displayed as individual items on the screen, a list, tiles, and so forth. These choices, however, are typically limited to the templates provided by the graphical user interface. Furthermore, they do not provide explicit mechanisms for grouping and organizing information. As a result, they do not necessarily reflect preferences for how a human operator would organize and present information outside of the provided templates. It is with respect to these and other considerations that the present improvements are provided.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This 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.
Various embodiments are generally directed to techniques for organizing information for presentation on a graphical user interface (GUI) and for storage of the associated organizational metadata. Some embodiments are particularly directed to techniques for allowing an operator to arrange and organize objects on the GUI in a free-form and intuitive manner, thereby improving how the operator consumes information.
In one embodiment, for example, a computer system may comprise a display operative to present a GUI with a pointer to select one or more movable objects and position the movable objects at various target positions on the GUI. The computer system may also comprise an input device operative to receive selected movable objects and user movement to position the selected movable objects at a target position on the GUI. The computer system may further comprise an object position component operative to anchor the selected movable objects at the target position using an anchor element to form a group of anchored objects, and arrange the group of anchored objects in a visual pattern relative to the anchor element. Other embodiments are described and claimed.
These and other features and advantages will be apparent from a reading of the following detailed description and a review of the associated drawings. It is to be understood that both the foregoing general description and the following detailed description are explanatory only and are not restrictive of aspects as claimed.
Various embodiments are generally directed to techniques for organizing information for presentation on a GUI. Some embodiments are particularly directed to techniques for allowing an operator to arrange and organize objects on the GUI in a free-form manner. The techniques may be used to create groups of movable objects, and implicitly or explicitly associate other objects with these groups. This solution enables a user to take an unorganized collection of objects and visually arrange them into object categories, groups or groups. For instance, the collection of objects is transformed into a visual metaphor for the collection as a desktop with the collection of objects represented as a group of note cards. An original group with a larger number of multiple objects is arranged into multiple groups with a smaller number of one or more objects. The operator may then pin or anchor the objects together, and cause the anchored objects to be presented in various visual patterns around the anchor. The anchored groups effectively create groups of movable objects that can be classified, moved, or rearranged before saving the categories for various applications. Once a group has been formed, other objects may be explicitly or implicitly associated with the group. As a result, the operator can group and organize separate objects into groups, groups or categories in a virtual space in a manner that is similar to how the operator might group or organize objects in a physical space. Consequently, the operator may group, organize and present information in more intuitive and desired manner.
As illustrated, the computer system 100 is depicted as a block diagram comprising several functional components or modules which may be implemented as hardware, software, or any combination thereof, as desired for a given set of design parameters or performance constraints. Although
As used herein, the terms “component” and “system” are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component can be implemented as a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers as desired for a given implementation.
Various embodiments may be described in the general context of computer-executable instructions, such as program modules or components, being executed by a computer. Generally, program modules or components include any software element arranged to perform particular operations or implement particular abstract data types. Some embodiments also may be practiced in distributed computing environments where operations are performed by one or more remote processing devices that are linked through a communications network. In a distributed computing environment, program modules or components may be located in both local and remote computer storage media including memory storage devices.
As shown in
The computer display 104 may any electronic display arranged to present content to a user and may be implemented by any type of suitable visual interface or display device. Examples of the computer display 104 may include a computer screen, computer monitor, liquid crystal display (LCD), flat panel display (FPD), cathode ray tube (CRT), and so forth.
The computer system 100 may be configured to execute various computer programs such as application 106. In one or more embodiments, the application 106 may be may be implemented as a desktop publishing application, graphical design application, presentation application, chart application, spreadsheet application, or word processing application. In various implementations, the application 106 may comprise an application program forming part of a Microsoft Office suite of application programs. Examples of such application programs include Microsoft Office Publisher, Microsoft Office Visio, Microsoft Office PowerPoint, Microsoft Office Excel, Microsoft Office Access, and Microsoft Office Word. In some cases, application programs can be used as stand-alone applications, but also can operate in conjunction with server-side applications, such as a Microsoft Exchange server, to provide enhanced functions for multiple users in an organization. Although particular examples of the application 106 have been provided, it can be appreciated that the application 106 may be implemented by any other suitable application which is consistent with the described embodiments.
The input device 108 may be arranged to receive input from a user of a computer system 100. In one or more embodiments, the input device 108 may be arranged to allow a user to select and move objects within a GUI presented on the computer display 102. In such embodiments, the input device 108 may be implemented as a mouse, trackball, touch pad, stylus, tablet PC pen, touch screen, and so forth.
In one or more embodiments, the application 106 may be arranged to present a GUI on the computer display 104. The GUI may be used, for example, as an interface to display various views of an electronic document, web page, template, and so forth, and receive operator selections or commands. During the authoring process, an operator, author or user may interact with the GUI to manipulate various graphics to achieve a desired arrangement. In some implementations, the GUI may be subsequently printed and/or published by the user after completion of the authoring process.
The system 100 may include the object position module 110. The object position module 110 provides an application and GUI interface to categorize or sort items of information (or objects) in a way that resembles sticky notes on a bulletin board, note cards on a desk, photos on a table, or other physical metaphors of arrangeable items. The user may then move the sticky notes, note cards, or other movable objects to a position on the virtual board and affixes an anchoring element in a graphic such as a pin, nail, paperweight, title box, or other element that is a metaphor for an anchor to the group. The user can then explicitly associate items with this anchor. Alternative, the user clicks a button, waits for a certain time duration, or performs some other action that signifies that the user is done arranging and categorizing the movable objects. After the object position module 110 triggers a condition indicating that the elements are categorized, the categorical elements fan out, square off, or in some other way arrange themselves around the anchor element. Once the elements are anchored, they can be moved to another group or can be repositioned by intuitively dragging the elements around close to the anchor, spinning the elements around the anchor, exploding the elements out around the anchor on hover, clicking on one element and then clicking on another group, or by using some other aesthetically pleasing or useful effect.
The object position module 110 may be implemented, for example, by a set of event-driven routines to operate as a stand-alone application program, or enhance the application 106. In various implementations, the operating system 102 may be arranged to monitor user movement received from the input device 108 and to execute various computer programs and event-driven routines such as application 106 and object position module 110. In some cases, the object position module 110 may be built into the operating system 102 and/or the application 106.
In various embodiments, the object position module 110 may be generally implemented to create, edit, sort, search, arrange and categorize information for affinity diagramming sessions or other information sorting tasks. Affinity diagramming may refer to sorting data into logical groups based on some commonalities between data. The object position module 110 may implement these operations utilizing a GUI and movable objects presented on the GUI.
The GUI may display various GUI elements such as graphics to a user including a pointer to select and manipulate a movable object. The movable object generally may comprise any two-dimensional or three-dimensional image capable of being selected and moved within the GUI. Examples of movable objects may include without limitation notes, messages, icons, symbols, documents, images, pictures, text, shape, and any other discrete set of information. The movable object may be moved using a “click and drag” technique where the pointer is positioned over the object, a mouse click selects the object, and the selected object is moved within the GUI to a new location. The movable object may also be moved by other control techniques, such as selecting and using keyboard commands to move the movable object. The embodiments are not limited in this context.
The movable object may take any shape, size or dimensions representative of the type of information it represents. For example, when the movable object represents a note item, the movable object may be implemented as a square or rectangular bounding box. The note item may include information displayed within the boundaries of the bounding box. The bounding box may comprise, for example, multiple points on the boundary of the bounding box, or points in-between the boundaries. By way of example and not limitation, the bounding box may include nine points (four points if the items are rectangular) including the four vertices and four midpoints of the boundary and the center of the object. The nine points of the rectangular bounding box may be used individually to determine the position of the object, to make movement calculations, for calculating overlap with a target position, to anchor the movable object with other objects, and so forth. It can be appreciated that when moving an object, the pointer may be placed at various positions on the object. As such, the pointer location may be too unpredictable to be used as a reference. Accordingly, using the points of the bounding box may result in more accurate positioning and calculations.
Additionally or alternatively, in some implementations, an optional guide (not shown) may be structured and arranged to assist users when aligning and positioning objects on a GUI. In one or more embodiments, the guide may comprise a plurality of collinear guide pixels and may be implemented, for example, by at least one of a guideline, a guide region, a shape guide, and a text baseline. The guide may comprise, for example, a horizontal and/or vertical guideline implemented as a ruler, margin, edge, gridline, and so forth. In some embodiments, the guide may comprise a two-dimensional guide region such as a shape outline or solid shape. The guide also may comprise a shape guide comprising a vertical or horizontal guideline extending from a corner or midpoint of an object. The shape guide may be used for alignment between objects and, in some implementations, may be displayed only when an edge or midpoint of a moving object is aligned with the edge or midpoint of another object. The guide may comprise a text baseline comprising a horizontal or vertical line upon which text sits and under which text letter descenders extend. A template comprising one or more configurable guides may be presented to a user. In some implementations, multiple templates comprising various arrangements of guides may be provided allowing a user to select one or more guides from one or more templates. Guides may be built into document templates to provide a user with contemporaneous guidance during the authoring process of a document even when not actively moving objects or using the objects of a template.
The object position component 110 may implement techniques for organizing information for presentation on a GUI. In particular, the object position component 110 may implement techniques for allowing an operator to arrange and organize objects on the GUI in a free-form manner. The operator may then pin the objects together, and cause the pinned objects to be presented in various visual patterns around the pin. As a result, the operator can group and organize separate objects into groups, groups or categories in a virtual space provided by the GUI in a manner that is similar to how the operator might group or organize objects in a physical space, such as on a note board, a desk, table, or other physical environment. Consequently, the operator may group, organize and present information in more intuitive and desired manner using natural human behavior and organizing principles.
In one embodiment, the computer system 100 may comprise the display 104 operative to present a GUI (or GUI view) with a pointer to select one or more movable objects and position the movable objects at various target positions on the GUI. The computer system 100 may also comprise the input device 108 operative to receive selected movable objects and user movement to position the selected movable objects at a target position on the GUI. The computer system 100 may further comprise an object position component 110 operative to anchor the selected movable objects at the target position using an anchor element to form a group of anchored objects, and arrange the group of anchored objects in a visual pattern relative to the anchor element. Exemplary implementations for the computer system 100 in general, and the object position component 110 in particular, may be described in more detail with reference to
Referring to
Referring to
Referring to
Referring to
In some cases, the selected movable object 204-3 may be brought in spatial proximity 212 of more than one existing groups of anchored elements 208. In one embodiment, for example, the input device 108 may be operative to receive the selected movable object 204-3 and user movement to position the selected movable object 204-3 in spatial proximity to multiple anchor elements 208, and the object position component 110 may be operative to select one of the multiple anchor elements 208 in accordance with a set of anchoring rules, and automatically anchor the selected movable object 204-3 using the selected anchor element. The anchoring rules may be user-configurable rules, such as snapping to the closest anchor element, or default rules.
Referring to
Referring to
Referring to
Referring to
In addition to arranging the anchored objects 310-1 to 310-3 in various visual patterns, the object position component 110 may use various visual, audible and tactile effects to allow a viewer to differentiate between the various groups of anchored objects. For instance, the object position component 110 may form multiple groups of anchored objects, and assign different colors, different sounds, different vibrations or other visual/audible/tactile effects to each of the multiple groups of anchored objects. Furthermore, the object position component 110 may also change a size for a movable object or group of movable objects based on available display area on the display 104 (e.g., mobile screen, laptop screen, desktop screen, television, etc.), or other movable objects or groups of movable objects already on the display 104, and so forth. Referring again to the group of anchored objects 210-3, for example, the graphic items used to represent individual movable objects 304-6, 304-7, 304-8 and 304-9 may be reduced in size to fit in the remaining display area not consumed by the groups of anchored objects 210-1, 210-2. Similarly, one or all of the movable objects 304-1-n or groups of anchored objects 210-1-t may be sized to fit as different displays 104 are used (e.g., mobile phone versus desktop). The embodiments are not limited in this context.
Various other features, operations and functionality may be added to the object position component 110 for given implementations. Some of these features may be provided below with respect to the general categories of data connections, collaboration, and organizing information. The embodiments are not limited to these categories.
In various embodiments, the object position component 110 may be implemented to organize information using graphical items with rich connection to data. By way of example, the object position component 110 may provide or allow note pads used as note templates, structured data to be placed on both the front and back of a note with tools to rotate or flip individual notes to view the structured data, custom connections to data schemas, automatic schema discovery, custom schema creation, flexible reading/writing to a file, database or web service, and other customizable features. The embodiments are not limited in this context.
In various embodiments, the object position component 110 may be implemented to facilitate collaboration between operators. By way of example, the object position component 110 may provide or allow shared sessions to allow multiple people editing a same group of data, animations for real-time or near real-time edits, using multiple machines or one machine by many, connections from different devices (e.g., phone, laptop, desktop, etc.), use of multiple devices with different capabilities, storage of intermediate states, recording and playback of sorting sessions, placing markers or tags or “watch” status on specific notes to trace or follow subsequent use or operations, and so forth. The embodiments are not limited in this context.
In various embodiments, the object position component 110 may allow explicit grouping operations. By way of example, the object position component 110 may provide or allow different types of pins or anchors, placements near or on a pin, metaphors for collections, different viewing patterns (e.g., cascade, fans, grid, nesting, etc.), manipulating notes (e.g., push, pull, move, etc.), zooming notes from a group, creating and using a stick pad, exploding or reducing notes, presenting rich multimedia with a movable object (e.g., photo, sound, ink, font, video, etc.), note tools (e.g., search, select, group, reorganize, etc.), infinite canvas/pan/zoom features, different textures/colors/visual effects for movable objects, viewable/audible/tactile effects when moving a pointer across a movable object or groups of movable objects, viewing tools to view movable objects or groups of movable objects, management tools to manage movable objects or groups of movable objects, and so forth. The embodiments are not limited in this context.
Operations for various embodiments may be further described with reference to one or more logic flows. It may be appreciated that the representative logic flows do not necessarily have to be executed in the order presented, or in any particular order, unless otherwise indicated. Moreover, various activities described with respect to the logic flows can be executed in serial or parallel fashion. The logic flows may be implemented using one or more elements of the computing system 100 or alternative elements as desired for a given set of design and performance constraints.
The logic flow 400 may present a graphical user interface on an electronic display with a pointer to select one or more movable objects and position the movable objects at various target positions on the graphical user interface. For example, the object position component 110 may present the GUIs 200, 300 on an electronic display 104 with the pointer 202 to select one or more movable objects 204-1-m, 304-1-n and position the movable objects 202 at various target positions 206-1-r on the GUIs 200, 300. The embodiments are not limited in this context.
The logic flow 400 may receive selected movable objects and user movement to position the selected movable objects at a target position on the graphical user interface. For example, the input device 108 may receive selected movable objects 204-1-m, 304-1-n and user movement to position the selected movable objects 204-1-m, 304-1-n at a target position 206-1-r on the GUIs 200, 300. The embodiments are not limited in this context.
The logic flow 400 may anchor the selected movable objects at the target position using an anchor element to form a group of anchored objects. For example, the object position component 110 may anchor the selected movable objects 204-1-m, 304-1-n at the target position 206-1-r using anchor element 208-1-s to form a group of anchored objects 210-1-t on the GUIs 200, 300. The embodiments are not limited in this context.
The logic flow 400 may arrange the group of anchored objects in a visual pattern relative to the anchor element on the graphical user interface presented on the electronic display. For example, the object position component 110 may arrange the group of anchored objects 210-1-t in a visual pattern relative to the anchor elements 208-1-s on the GUIs 200, 300 presented on the electronic display 104. The embodiments are not limited in this context.
As shown in
In one embodiment, for example, the computer 510 may include one or more processing units 520. A processing unit 520 may comprise any hardware element or software element arranged to process information or data. Some examples of the processing unit 520 may include, without limitation, a complex instruction set computer (CISC) microprocessor, a reduced instruction set computing (RISC) microprocessor, a very long instruction word (VLIW) microprocessor, a processor implementing a combination of instruction sets, or other processor device. In one embodiment, for example, the processing unit 520 may be implemented as a general purpose processor. Alternatively, the processing unit 520 may be implemented as a dedicated processor, such as a controller, microcontroller, embedded processor, a digital signal processor (DSP), a network processor, a media processor, an input/output (I/O) processor, a media access control (MAC) processor, a radio baseband processor, a field programmable gate array (FPGA), a programmable logic device (PLD), an application specific integrated circuit (ASIC), and so forth. The embodiments are not limited in this context.
In one embodiment, for example, the computer 510 may include one or more system memory units 530 coupled to the processing unit 520. A system memory unit 530 may be any hardware element arranged to store information or data. Some examples of memory units may include, without limitation, random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), read-only memory (ROM), programmable ROM (PROM), erasable programmable ROM (EPROM), EEPROM, Compact Disk ROM (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), flash memory (e.g., NOR or NAND flash memory), content addressable memory (CAM), polymer memory (e.g., ferroelectric polymer memory), phase-change memory (e.g., ovonic memory), ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, disk (e.g., floppy disk, hard drive, optical disk, magnetic disk, magneto-optical disk), or card (e.g., magnetic card, optical card), tape, cassette, or any other medium which can be used to store the desired information and which can be accessed by computer 510. The embodiments are not limited in this context.
In one embodiment, for example, the computer 510 may include a system bus 521 that couples various system components including the system memory unit 530 to the processing unit 520. A system bus 521 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include an Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus, and so forth. The embodiments are not limited in this context.
In various embodiments, the computer 510 may include various types of storage media. Storage media may represent any storage media capable of storing data or information, such as volatile or non-volatile memory, removable or non-removable memory, erasable or non-erasable memory, writeable or re-writeable memory, and so forth. Storage media may include two general types, including computer readable media or communication media. Computer readable media may include storage media adapted for reading and writing to a computing system, such as the computing system architecture 500. Examples of computer readable media for computing system architecture 500 may include, but are not limited to, volatile and/or nonvolatile memory such as ROM 531 and RAM 532. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means 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 includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio-frequency (RF) spectrum, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
In various embodiments, the system memory unit 530 includes computer storage media in the form of volatile and/or nonvolatile memory such as ROM 531 and RAM 532. A basic input/output system 533 (BIOS), containing the basic routines that help to transfer information between elements within computer 510, such as during start-up, is typically stored in ROM 531. RAM 532 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 520. By way of example, and not limitation,
The computer 510 may also include other removable/non-removable, volatile/non-volatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 510 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 580. The remote computer 580 may be a PC, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 510, although only a memory storage device 581 has been illustrated in
When used in a LAN networking environment, the computer 510 is connected to the LAN 571 through a network interface 570 or adapter. When used in a WAN networking environment, the computer 510 typically includes a modem 572 or other technique suitable for establishing communications over the WAN 573, such as the Internet. The modem 572, which may be internal or external, may be connected to the system bus 521 via the user input interface 560, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 510, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Various embodiments may be implemented using hardware elements, software elements, or a combination of both. Examples of hardware elements may include logic devices, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. Examples of software elements may include software components, programs, applications, computer programs, application programs, system programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, application program interfaces (API), instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints, as desired for a given implementation.
In some cases, various embodiments may be implemented as an article of manufacture. The article of manufacture may be implemented, for example, as a computer-readable storage medium storing logic and/or data for performing various operations of one or more embodiments. The computer-readable storage medium may include one or more types of storage media capable of storing data, including volatile memory or, non-volatile memory, removable or non-removable memory, erasable or non-erasable memory, writeable or re-writeable memory, and so forth. The computer-readable medium may store logic comprising instructions, data, and/or code that, if executed by a computer system, may cause the computer system to perform a method and/or operations in accordance with the described embodiments. Such a computer system may include, for example, any suitable computing platform, computing device, computer, processing platform, processing system, processor, or the like implemented using any suitable combination of hardware and/or software.
Various embodiments may comprise one or more elements. An element may comprise any structure arranged to perform certain operations. Each element may be implemented as hardware, software, or any combination thereof, as desired for a given set of design and/or performance constraints. Although an embodiment may be described with a limited number of elements in a certain topology by way of example, the embodiment may include more or less elements in alternate topologies as desired for a given implementation.
Although some embodiments may be illustrated and described as comprising exemplary functional components or modules performing various operations, it can be appreciated that such components or modules may be implemented by one or more hardware components, software components, and/or combination thereof. The functional components and/or modules may be implemented, for example, by logic (e.g., instructions, data, and/or code) to be executed by a logic device (e.g., processor). Such logic may be stored internally or externally to a logic device on one or more types of computer-readable storage media.
It also is to be appreciated that the described embodiments illustrate exemplary implementations, and that the functional components and/or modules may be implemented in various other ways which are consistent with the described embodiments. Furthermore, the operations performed by such components or modules may be combined and/or separated for a given implementation and may be performed by a greater number or fewer number of components or modules.
Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. These terms are not necessarily intended as synonyms for each other. For example, some embodiments may be described using the terms “connected” and/or “coupled” to indicate that two or more elements are in direct physical or electrical contact with each other. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other.
It is emphasized that the Abstract of the Disclosure is provided to comply with 37 C.F.R. Section 1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment. In the appended claims, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein,” respectively. It is worthy to note that although some embodiments may describe structures, events, logic or operations using the terms “first,” “second,” “third,” and so forth, such terms are used merely as labels, and are not intended to impose numerical requirements on their objects. Further, such terms are used to differentiate elements and not necessarily limit the structure, events, logic or operations for the elements.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.