Embodiments of the present invention relate generally to methods and systems for organizing and presenting information related to ongoing business processes and more particularly to providing a contextual visualization of business processes and related business data.
Any business decision making process highly depends on creating a clear mental model of the business process among all team members. Moreover, understanding a business process depends on understanding the related information, the relationship between the information, the collaborations and discussions around the information, and the evolution of the process and data over time. As a business process becomes more complex, understanding and transferring this kind of knowledge become challenging. It is even more challenging for top executive managers and strategic decision makers who work on different projects simultaneously and collaborating with multiple teams on different processes. Since the processes evolve and the related information changes often, each time the participants switch between projects, they have to rebuild their mental model, which can consume lots of time and effort and may end up with decisions being made on incomplete, misleading, and/or inaccurate information.
Even though current enterprise applications facilitate management of business processes by providing the ability to store, retrieve and manage the business information, none of them provide an effective solution to understand and communicate the in context knowledge created through the process. Most of business applications only address formal collaborations, such as a procurement approval process, where the information passes from one business group to another. However, most collaborations in strategic decision making processes, which can have a huge impact on the future of a company, are ad-hoc and informal involving large number of business participants and managers from different disciplines communicating the business information to create a common ground-knowledge of the context. Social collaborative tools such as Web-2.0 applications try to address this problem, but they do not offer a comprehensive view of the entire context of the business process and related business data. Hence, there is a need for improved methods and systems for organizing and presenting information related to ongoing business processes.
Embodiments of the invention provide systems and methods for providing a contextual visualization of business processes and related business data. According to one embodiment, a method for providing a contextual visualization of business processes and related business data can comprise generating a first canvas representing a first business process. The first canvas can comprise a collaborative, interactive environment accessible to one or more users and can provide access to business data of the first business process to the one or more users. One or more visual objects representing the business data of the first business process can be generated and added to the first canvas. The first canvas with the added one or more visual objects can be provided to the one or more users, e.g., users with access to the first business process.
In some cases, a second canvas representing a second business process can be generated. The second canvas can comprise a collaborative, interactive environment accessible to one or more users and can provides access to business data of the second business process to the one or more users. One or more visual objects representing the business data of the second business process can be generated and added to the second canvas. The second canvas with the added one or more visual objects can be provided to the one or more users, e.g., users with access to the second business process. For example, the first business process can be related to the second business process. In such cases, providing the first canvas and the second canvas to the one or more users can comprise providing an indication of the relationship between the first business process and the second business process.
In some cases, the one or more visual objects can include a snapshot representation of the business data of the first business process. In such cases, the snapshot can be linked to the business data of the first business process and an update of the snapshot can cause an update of the business data. Additionally or alternatively, the one or more visual objects can include a thumbnail representation of at least a portion of a document related to the first business process. In such cases, the thumbnail can be linked to the document and the document can be opened through the thumbnail.
For example, the one or more visual objects can comprise at least a first visual object representing a first business data object and a second visual object representing a second business data object. In such cases, the first business data object can be related to the second business data object and adding the first visual object and second visual object to the first canvas can comprise adding an indication of the relationship between the first business object and the second business object.
Additionally or alternatively, one of the one or more visual objects can represent a business data object and the business data object can comprise related metadata. In such cases, the visual object includes a representation of at least some of the metadata. In an additional or alternative case, a threaded discussion between two or more of the users can be added to the first canvas and/or the second canvas. The threaded discussion can be related to at least one of the canvas, one or more of the visual object, or a relationship between two or more of the visual objects.
In some cases, a first snapshot can be taken of the first canvas with the added one or more visual objects at a first time. A second snapshot can be taken of the first canvas with the added one or more visual objects at a second time later than the first time. In such cases, a timeline can be presented in the canvas using the first snapshot and the second snapshot. The timeline can represent an evolution of the canvas and the one or more visual objects between the first time and the second time.
According to another embodiment, a system can comprise a processor and a memory communicatively coupled with and readable by the processor. The memory can have stored therein a sequence of instructions which, when executed by the processor, cause the processor to provide a contextual visualization of business processes and related business data by generating a first canvas representing a first business process. The first canvas can comprise a collaborative, interactive environment accessible to one or more users and can provide access to business data of the first business process to the one or more users. One or more visual objects representing the business data of the first business process can be generated and added to the first canvas. The first canvas with the added one or more visual objects can be provided to the one or more users, e.g., users with access to the first business process. A second canvas representing a second business process can be generated. The second canvas can comprise a collaborative, interactive environment accessible to one or more users and can provides access to business data of the second business process to the one or more users. One or more visual objects representing the business data of the second business process can be generated and added to the second canvas. The second canvas with the added one or more visual objects can be provided to the one or more users, e.g., users with access to the second business process. For example, the first business process can be related to the second business process. In such cases, providing the first canvas and the second canvas to the one or more users can comprise providing an indication of the relationship between the first business process and the second business process.
In some cases, the one or more visual objects can include a snapshot representation of the business data of the first business process. In such cases, the snapshot can be linked to the business data of the first business process and an update of the snapshot can cause an update of the business data. Additionally or alternatively, the one or more visual objects can include a thumbnail representation of at least a portion of a document related to the first business process. In such cases, the thumbnail can be linked to the document and the document can be opened through the thumbnail.
According to yet another embodiment, a computer-readable memory can have stored therein a sequence of instructions which, when executed by a processor, cause the processor to provide a contextual visualization of business processes and related business data by generating a first canvas representing a first business process. The first canvas can comprise a collaborative, interactive environment accessible to one or more users and can provide access to business data of the first business process to the one or more users. One or more visual objects representing the business data of the first business process can be generated and added to the first canvas. The first canvas with the added one or more visual objects can be provided to the one or more users, e.g., users with access to the first business process. A second canvas representing a second business process can be generated. The second canvas can comprise a collaborative, interactive environment accessible to one or more users and can provides access to business data of the second business process to the one or more users. One or more visual objects representing the business data of the second business process can be generated and added to the second canvas. The second canvas with the added one or more visual objects can be provided to the one or more users, e.g., users with access to the second business process. For example, the first business process can be related to the second business process. In such cases, providing the first canvas and the second canvas to the one or more users can comprise providing an indication of the relationship between the first business process and the second business process.
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of various embodiments of the present invention. It will be apparent, however, to one skilled in the art that embodiments of the present invention may be practiced without some of these specific details. In other instances, well-known structures and devices are shown in block diagram form.
The ensuing description provides exemplary embodiments only, and is not intended to limit the scope, applicability, or configuration of the disclosure. Rather, the ensuing description of the exemplary embodiments will provide those skilled in the art with an enabling description for implementing an exemplary embodiment. It should be understood that various changes may be made in the function and arrangement of elements without departing from the spirit and scope of the invention as set forth in the appended claims.
Specific details are given in the following description to provide a thorough understanding of the embodiments. However, it will be understood by one of ordinary skill in the art that the embodiments may be practiced without these specific details. For example, circuits, systems, networks, processes, and other components may be shown as components in block diagram form in order not to obscure the embodiments in unnecessary detail. In other instances, well-known circuits, processes, algorithms, structures, and techniques may be shown without unnecessary detail in order to avoid obscuring the embodiments.
Also, it is noted that individual embodiments may be described as a process which is depicted as a flowchart, a flow diagram, a data flow diagram, a structure diagram, or a block diagram. Although a flowchart may describe the operations as a sequential process, many of the operations can be performed in parallel or concurrently. In addition, the order of the operations may be re-arranged. A process is terminated when its operations are completed, but could have additional steps not included in a figure. A process may correspond to a method, a function, a procedure, a subroutine, a subprogram, etc. When a process corresponds to a function, its termination can correspond to a return of the function to the calling function or the main function.
The term “machine-readable medium” includes, but is not limited to portable or fixed storage devices, optical storage devices, wireless channels and various other mediums capable of storing, containing or carrying instruction(s) and/or data. A code segment or machine-executable instructions may represent a procedure, a function, a subprogram, a program, a routine, a subroutine, a module, a software package, a class, or any combination of instructions, data structures, or program statements. A code segment may be coupled to another code segment or a hardware circuit by passing and/or receiving information, data, arguments, parameters, or memory contents. Information, arguments, parameters, data, etc. may be passed, forwarded, or transmitted via any suitable means including memory sharing, message passing, token passing, network transmission, etc.
Furthermore, embodiments may be implemented by hardware, software, firmware, middleware, microcode, hardware description languages, or any combination thereof. When implemented in software, firmware, middleware or microcode, the program code or code segments to perform the necessary tasks may be stored in a machine readable medium. A processor(s) may perform the necessary tasks.
Embodiments of the invention include systems and methods for providing a contextual visualization of business processes and related business data. More specifically, embodiments of the present invention provide a holistic view of digital information in the context of a business process through a set of visual objects, also referred to herein as visual cards, representing digital information including documents of different formats, semi-structured content, and business data. A visual card can represent, for example, an entire document or a part of a document, and it can also include annotations added by users, metadata associated with the document or business object, etc. These cards can be added to a visualization environment referred to as a visual canvas. The cards can be added to the canvas programmatically, e.g., adding all or some business objects of a particular business process, or manually by users.
According to one embodiment, the visual canvas can also include visualization of relationships between the digital information represented by the visual cards. In some cases, the canvas can render pre-defined relationships between business objects such as the hierarchical relationship between design parts in Product Lifecycle Management. In other cases, the user can create or change relationships manually by grouping visual cards under a pool, or connecting them to other visual cards or business objects. Embodiments can also support nested relationships and the user can easily move or copy a part of the visualization.
Using this contextual visualization presented by the visual canvas and the cards thereon, users can update the workflow of the business process in context. Users also can add markers and tags to objects or relationships represented in the visual canvas. According to one embodiment and depending upon the document or business object represented by the visual cards, the permissions of the user, etc. changes made to the visual cards and/or the relationships represented in the canvas can be saved to the represented objects or documents for further retrieval. Various additional details of embodiments of the present invention will be described below with reference to the figures.
In some embodiments, the system 100 may also include a network 115. The network may can be any type of network familiar to those skilled in the art that can support data communications using any of a variety of commercially-available protocols, including without limitation TCP/IP, SNA, IPX, AppleTalk, and the like. Merely by way of example, the network 115 maybe a local area network (“LAN”), such as an Ethernet network, a Token-Ring network and/or the like; a wide-area network; a virtual network, including without limitation a virtual private network (“VPN”); the Internet; an intranet; an extranet; a public switched telephone network (“PSTN”); an infra-red network; a wireless network (e.g., a network operating under any of the IEEE 802.11 suite of protocols, the Bluetooth protocol known in the art, and/or any other wireless protocol); and/or any combination of these and/or other networks such as GSM, GPRS, EDGE, UMTS, 3G, 2.5 G, CDMA, CDMA2000, WCDMA, EVDO etc.
The system may also include one or more server computers 120, 125, 130 which can be general purpose computers and/or specialized server computers (including, merely by way of example, PC servers, UNIX servers, mid-range servers, mainframe computers rack-mounted servers, etc.). One or more of the servers (e.g., 130) may be dedicated to running applications, such as a business application, a web server, application server, etc. Such servers may be used to process requests from user computers 105, 110. The applications can also include any number of applications for controlling access to resources of the servers 120, 125, 130.
The web server can be running an operating system including any of those discussed above, as well as any commercially-available server operating systems. The web server can also run any of a variety of server applications and/or mid-tier applications, including HTTP servers, FTP servers, CGI servers, database servers, Java servers, business applications, and the like. The server(s) also may be one or more computers which can be capable of executing programs or scripts in response to the user computers 105, 110. As one example, a server may execute one or more web applications. The web application may be implemented as one or more scripts or programs written in any programming language, such as Java™, C, C# or C++, and/or any scripting language, such as Perl, Python, or TCL, as well as combinations of any programming/scripting languages. The server(s) may also include database servers, including without limitation those commercially available from Oracle®, Microsoft®, Sybase®, IBM® and the like, which can process requests from database clients running on a user computer 105, 110.
In some embodiments, an application server may create web pages dynamically for displaying on an end-user (client) system. The web pages created by the web application server may be forwarded to a user computer 105 via a web server. Similarly, the web server can receive web page requests and/or input data from a user computer and can forward the web page requests and/or input data to an application and/or a database server. Those skilled in the art will recognize that the functions described with respect to various types of servers may be performed by a single server and/or a plurality of specialized servers, depending on implementation-specific needs and parameters.
The system 100 may also include one or more databases 135. The database(s) 135 may reside in a variety of locations. By way of example, a database 135 may reside on a storage medium local to (and/or resident in) one or more of the computers 105, 110, 115, 125, 130. Alternatively, it may be remote from any or all of the computers 105, 110, 115, 125, 130, and/or in communication (e.g., via the network 120) with one or more of these. In a particular set of embodiments, the database 135 may reside in a storage-area network (“SAN”) familiar to those skilled in the art. Similarly, any necessary files for performing the functions attributed to the computers 105, 110, 115, 125, 130 may be stored locally on the respective computer and/or remotely, as appropriate. In one set of embodiments, the database 135 may be a relational database, such as Oracle 10g, that is adapted to store, update, and retrieve data in response to SQL-formatted commands.
The computer system 200 may additionally include a computer-readable storage media reader 225a, a communications system 230 (e.g., a modem, a network card (wireless or wired), an infra-red communication device, etc.), and working memory 240, which may include RAM and ROM devices as described above. In some embodiments, the computer system 200 may also include a processing acceleration unit 235, which can include a DSP, a special-purpose processor and/or the like.
The computer-readable storage media reader 225a can further be connected to a computer-readable storage medium 225b, together (and, optionally, in combination with storage device(s) 220) comprehensively representing remote, local, fixed, and/or removable storage devices plus storage media for temporarily and/or more permanently containing computer-readable information. The communications system 230 may permit data to be exchanged with the network 220 and/or any other computer described above with respect to the system 200.
The computer system 200 may also comprise software elements, shown as being currently located within a working memory 240, including an operating system 245 and/or other code 250, such as an application program (which may be a client application, web browser, mid-tier application, RDBMS, etc.). It should be appreciated that alternate embodiments of a computer system 200 may have numerous variations from that described above. For example, customized hardware might also be used and/or particular elements might be implemented in hardware, software (including portable software, such as applets), or both. Further, connection to other computing devices such as network input/output devices may be employed. Software of computer system 200 may include code 250 for implementing embodiments of the present invention as described herein.
Additionally, the same or a different computer system may execute one or more document applications 320. For example, the document applications 320 can include, but are not limited to, an office application suite, a drawing or design application, an email client, etc. Each of these document applications 320 can also maintain a set of content data 325 related to these various applications. This content data 325 can include any number and variety of different types of documents 330 such as textual documents, drawings, emails, and other types of documents depending upon the application 320. These documents 330 can be generated and used by different users and/or groups of users that also participate in the business processes of the business applications 305. Thus, the documents 330 may be related to those processes and may, in different ways, be identified as such. For example, a given document may be identified as related to a business process by the contents of that document, by header information such as a title or subject line, by metadata associated with that document, etc.
As introduced above, embodiments of the invention include systems and methods for providing a contextual visualization of business processes of the business applications 305 and related business data such as the various business objects 315 and documents 330. More specifically, embodiments of the present invention provide a holistic view of digital information in the context of a business process through a set of visual objects 340, 345, 350, and 355 representing the documents 330 and business objects 315. As will be described in greater detail below, a visual object 340, 345, 350, and 355 can represent, for example, an entire document 330 or a part of a document, and it can also include annotations added by users, metadata associated with the document 330 or business object 315, etc. These visual objects 340, 345, 350, and 355 can be added to a visualization environment referred to as a visual canvas 335. As will also be described further below, the visual objects 340, 345, 350, and 355 can be added to the canvas 335 programmatically, e.g., adding all or some business objects of a particular business process, or manually by users.
As will be seen, the visual canvas 335 can include a master canvas and one or more sub-canvases. Generally speaking, a master canvas 335 can comprise a visual area that provides a holistic view of a context of a process of the business application 305. This visual canvas 335 can be automatically created for each process of a business application 305 and made available to users thereof. Sub-canvases (not shown here) can comprise visual areas of the main visual canvas 335 that provide holistic views of the connected business context, e.g., sub-processes, related processes, etc. These canvases can be created for any business workflow, task, internal and external collaboration, project, etc. The sub-canvases, if any, can be nested (ex. a task and sub-tasks) or can be connected (ex. Phase 1, Phase 2, etc. of a design process). The canvas 335 and any sub-canvases can include customized views defined by collaborators of the processes of the business application 305 and related business objects 315 and documents 330.
The visual objects 340, 345, 350, and 355 can include objects 340 and 345 representing the business objects 315 related to a process represented by the canvas 335. These visual objects 340 and 345 can comprise a snapshot of a related business object 315 that may be linked to the original business object 315 so that updates made to the visual object 340 or 345 in the visual canvas 335 can be automatically or manually, i.e., upon request, propagated and saved to the business object 315 represented. The ability of users to view and/or modify visual objects 340 and 345 and the contents of the canvas can be based on their access right in associated business application 305.
The visual objects 340, 345, 350, and 355 can also include objects 350 and 355 representing the documents 330 related to a process represented by the canvas 335.
According to one embodiment, these visual objects 350 and 355 can comprise a thumbnail view of digital information created by users from the documents 330 (in whole or in part). These visual objects 350 and 355 can also include annotations and may be modified by the users. These visual object 350 and 355 can also be linked to the original documents 330 so that updates made to the visual object 350 or 355 in the visual canvas 335 can be automatically or manually, i.e., upon request, propagated and saved to the documents 330 represented. The ability of users to view and/or modify visual objects 350 and 355 and the contents of the canvas 335 can be based on their access right in associated document application 320.
Using this contextual visualization presented by the visual canvas 335 and the visual objects 340, 345, 350, and 355 thereon, users can update the workflow of the business process in context. Users also can add markers and tags to objects 340, 345, 350, and 355 or relationships represented in the visual canvas 335. According to one embodiment and depending upon the document or business object represented by the visual objects 340, 345, 350, and 355, the permissions of the user, etc. changes made to the visual objects 340, 345, 350, and 355 and/or the relationships represented in the canvas can be saved to the represented business objects or documents for further retrieval. That is, collaborators in or on a canvas 335 can comprise users of the business application with access to associated business workflow. Roles of these users within the canvas can be set by an administrator at canvas creation time. The roles and privileges of the users can be enforced both at the canvas and object level. The canvas 335 can support multi-user real time access and provide multiple users the ability to view and navigate the canvas, add to the canvas, modify objects represented thereon, etc.
Thus, embodiments of the present invention can provide a platform agnostic framework for abstracting applications used underneath. The visualizations provided hereby can connect objects and canvases from different business applications to visualize the high level business processes. For example, the user may want to connect an order management canvas in a Customer Relationship Management (CRM) application that contains all customers negotiations to an Order Fulfillment in Supply Chain Management (SCM) application that contains collaboration with suppliers to visualize an order-to-cash work flow. The visualization can also combine structured and unstructured data created by processes or users and represent relationships between those objects. The connections or relationships between objects or canvases can be of different types, e.g., directional, bidirectional, etc. These visualizations can modelize business processes and associated knowledge based on tagging, templates or user created relationships. As will be illustrated in the figures and described below, embodiments of the present invention can provide an intuitive visual interface into the state of a process and its associated knowledge based on user role, current task and access rights. These visualization can support intelligent data exploration via smart tagging and advanced search. Additional details of these processes, the visual canvas 335 and visual objects 340, 345, 350, and 355 will now be described.
In some cases, the canvas 400 can render pre-defined relationships between business objects such as the hierarchical relationship between business objects, between documents and business objects, etc. In other cases, the user can create or change relationships manually and representing relationships between objects can include grouping visual objects in a pool 435 and 440, or connecting them to other visual objects such as will be described below with reference to
In summary, relationships that can be represented in a visual canvas 400 can include canvas relationships rendering any possible relationship between a main can base and any sub-canvases (nested or connected). Also represented can be business data relationships rendering relationships between business data objects. Any of these relationships can be created by users between visual objects by manipulating the user interface of the visual canvas 400 to indicate direct connections between visual objects, define pools of information, define sequences or hierarchies of objects, etc.
Optionally, the process can further comprise presenting additional canvases representing sub-processes of the first business process, separate but related processes to the first business process, or even unrelated business processes. In such cases, the process can optionally continue with generating 1125 a second canvas representing the second business process. One or more visual objects representing the business data of the second business process can be generated and added 1135 to the second canvas. The second canvas with the added one or more visual objects can be provided 1140 to the one or more users. If the second business process is related to the first business process in some way, e.g., as a sub process or other relationship, this relationship can also be represented 1145 when displaying the second canvas. Once displayed, the user may manipulate the visual objects of the canvases to affect the data and/or the relationships between the documents, business objects and/or the business processes as described above. If the visual objects are linked to the represented documents and/or objects, these changes may be saved to update the documents and/or objects as will be described with reference to
It should be noted that context visualization can also provide visualization across application business processes. In this case, embodiments could provide abstraction of the overall business process regardless of technical application. As an example, a visualization can be provided for an “Order to Cash” workflow which may include: 1. Lead to opportunity process provided by CRM (Consumer Relationship management); 2. Opportunity to Order provided by CRM; 3. Order Fulfillment provided by SCM (Supply Chain Management); and 4. Payment and Collection provided by Financial Application. The users can view the entire process, zoom into a sub process, and zoom into a canvas related to a single process.
A determination 1210 can be made as to whether the affected visual objects are linked to the documents and/or business objects they represent. If a determination 1210 is made that the changed visual objects are linked to the documents and/or business objects they represent, updates to those documents or objects can be made automatically or manually. For example, a determination 1215 can be made as to whether the updates should be made automatically. This determination 1215 can be based, for example, on a setting or preference for the user, on a default value or setting for one or more of the visual canvas and/or the visual objects, or on other criteria or conditions. If the determination 1215 is made that the documents or objects should be updated automatically, the changes can be saved to the original document or object to which the visual object is linked.
If a determination 1215 is made that the documents or objects should not be updated automatically, another determination 1220 can be made as to whether the documents or objects should be updated manually. This determination 1220 can be based, for example, on querying the user by presenting a popup or other message to confirm the changes and/or on the user clicking or selecting a link, button, icon, or other control from a message, menu, toolbar etc. If the determination 1220 is made that the documents or objects should be updated manually, the changes can be saved to the original document or object to which the visual object is linked. As these changes are made over time, the canvas can be periodically captured and saved, as will be described below with reference to
According to one embodiment and as illustrated in
In the foregoing description, for the purposes of illustration, methods were described in a particular order. It should be appreciated that in alternate embodiments, the methods may be performed in a different order than that described. It should also be appreciated that the methods described above may be performed by hardware components or may be embodied in sequences of machine-executable instructions, which may be used to cause a machine, such as a general-purpose or special-purpose processor or logic circuits programmed with the instructions to perform the methods. These machine-executable instructions may be stored on one or more machine readable mediums, such as CD-ROMs or other type of optical disks, floppy diskettes, ROMs, RAMs, EPROMs, EEPROMs, magnetic or optical cards, flash memory, or other types of machine-readable mediums suitable for storing electronic instructions. Alternatively, the methods may be performed by a combination of hardware and software.
While illustrative and presently preferred embodiments of the invention have been described in detail herein, it is to be understood that the inventive concepts may be otherwise variously embodied and employed, and that the appended claims are intended to be construed to include such variations, except as limited by the prior art.
The present application claims benefit under 35 USC 119(e) of U.S. Provisional Application No. 61/540,684, filed on Sep. 29, 2011 by Naghshin et al and entitled “Enterprise Context Visualization,” of which the entire disclosure is incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
61540684 | Sep 2011 | US |