WO2007136602A2 - System and method for synchronized workflow management - Google Patents

System and method for synchronized workflow management Download PDF

Info

Publication number
WO2007136602A2
WO2007136602A2 PCT/US2007/011516 US2007011516W WO2007136602A2 WO 2007136602 A2 WO2007136602 A2 WO 2007136602A2 US 2007011516 W US2007011516 W US 2007011516W WO 2007136602 A2 WO2007136602 A2 WO 2007136602A2
Authority
WO
WIPO (PCT)
Prior art keywords
workflow
model
view
identified
modeling environment
Prior art date
Application number
PCT/US2007/011516
Other languages
French (fr)
Other versions
WO2007136602A3 (en
Inventor
Peter Szpak
Paulo Pacheco
Christian Robl
Martin Orehek
Original Assignee
The Mathworks, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by The Mathworks, Inc. filed Critical The Mathworks, Inc.
Priority to EP07809076A priority Critical patent/EP2018612A2/en
Publication of WO2007136602A2 publication Critical patent/WO2007136602A2/en
Publication of WO2007136602A3 publication Critical patent/WO2007136602A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/10Requirements analysis; Specification techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/34Graphical or visual programming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling

Definitions

  • the illustrative embodiment of the present invention relates generally to workflows in graphical modeling environments, and more particularly to a workflow manager synchronized with the graphical modeling environment.
  • Graphical programming languages and graphical modeling environments enable the construction of graphical models such as block diagram models, entity flow models, flow diagrams, computational noncausal models, and statechart models.
  • Graphical programming languages provide a wide array of functionality that may be utilized during model design. Frequently there is more than one approach to solving a particular problem, achieving a particular goal, or following a proven procedure. Achieving a particular goal often requires a set of tasks that are unknown or difficult for a novice user to grasp.
  • a workflow describes the set of tasks that must be completed in order to accomplish particular goals during the design of a graphical model.
  • Some conventional graphical programming languages provide tools that assist a user in identifying problems with a design and further facilitate the implementation of recommendations designed to address the problems.
  • these conventional tools provide advice that is relatively unstructured in that the advice is not closely associated with a particular portion of a workflow. Additionally these conventional tools do not tailor the graphical modeling environment for a particular task that the model designer is attempting to accomplish. It would be desirable to provide a workflow management tool that provides structured advice and is able to reconfigure the graphical modeling environment in a manner suitable for the particular workflow that is being executed by the model designer.
  • the illustrative embodiment of the present invention provides a workflow manager that offers structure and control over the graphical modeling environment so that the graphical modeling environment is reconfigured in a manner appropriate for a particular workflow.
  • the workflow manager of the present invention provides hierarchical task management that is synchronized to the graphical modeling environment.
  • the workflow manager allows a model designer to navigate a series of steps required to achieve the goal of a particular workflow.
  • An application programming interface (API) allows the steps to be customized as required by the end user.
  • a method of managing workflows in a graphical modeling environment includes the step of receiving user input associated with an identified workflow. The method also displays information associated with the identified workflow based on the received user input. The method additionally reconfigures the modeling environment in response to a user selection.
  • a system for capturing task-based workflows in a graphical modeling environment includes a task-based workflow identified by a user.
  • the system also includes user input associated with the task-based workflow.
  • a view of information associated with the workflow based on the received user input is also part of the system.
  • the workflow is synchronized to a modeling environment.
  • the modeling environment of the system is reconfigured in response to a user selection.
  • Figure 2 depicts an alternative distributed environment suitable for practicing the illustrative embodiment of the present invention
  • Figure 3 A depicts a screenshot of the selection of a user-identified workflow
  • Figure 3B depicts a screenshot of the solicitation of user input by the workflow manager in order to simplify the chosen workflow
  • Figure 3C depicts a screenshot of a hierarchical view of the tasks relevant to the identified workflow and based on the user input solicited in Figure 3B;
  • Figure 3D depicts the model environment in a default configuration
  • Figures 3E-3F depict a screenshot of a user selection of a particular step in the presented workflow and the subsequent reconfiguring of the graphical modeling environment to show the relevant portions of the model;
  • Figure 3G depicts a screenshot of the graphical model editor highlighted to show the model components relevant to a task;
  • Figures 3H and 31 depict screenshots of the workflow manager reconfiguring the model hierarchy and graphical model editor respectively to show progress towards the completion of a task required in the identified workflow;
  • Figure 4 shows a workflow that may be defined and customized through a provided API;
  • Figure 5 depicts one aspect of the reporting capability of the workflow manager.
  • Figures 6A and 6B depict the bi-directional linkage provided by the present invention between a block diagram editor and model explorer view.
  • the workflow manager of the illustrative embodiment of the present invention programmatically tailors and customizes the graphical modeling environment into a form appropriate for an identified workflow associated with a graphical model.
  • the design process becomes more focused and efficient.
  • the synchronization of the different views of the model design to the workflow allow the user to ascertain how design choices made at each step of the workflow affect the model components impacted by that step of the workflow.
  • the ability to create and restore snapshots of the workflow process allows the design process to be started and stopped efficiently from a number of different points in the workflow without the need to restart the workflow from the beginning of the process.
  • Figure 1 depicts an environment suitable for practicing the illustrative embodiment of the present invention.
  • a computing device 2 supports a graphical modeling environment 4.
  • Graphical modeling environments are programs that enable a user to construct and analyze a model of a process or system.
  • Examples of modeling formalisms that are supported by graphical modeling tools include time-based block diagrams, such as supported by Simulink from The Math Works Inc., discrete event diagrams and reactive state machine diagrams, such as those supported by Stateflow® from The Math Works, Inc., data-flow diagrams, such as those supported by LabVIEW, available from National Instruments Corporation, entity flow modeling tools such as SimEvents, rigid body modeling tools such as SimMechanics both available from The Math Works, Inc., and software diagrams and other graphical modeling languages, as found, for example, in Unified Modeling Language (UML) diagrams such as supported by Rational from IBM and Rhapsody from I-Logix.
  • UML Unified Modeling Language
  • the computing device 2 may be a computing device such as a workstation, server, laptop, mainframe, PDA (personal digital assistant), a game platform, tablet PCs, a mobile telephone, a cluster of devices operating together, a virtual device or another computing device able to support the graphical modeling environment 4.
  • the computing device 2 may have a single processor 24 or multiple processors 24 and 27 and the processors may be single-core processors 25 or multi-core processors 25 and 26 and 28 and 29.
  • the graphical modeling environment 4 includes at least one graphical model 6.
  • the graphical modeling environment 4 also includes at least one workflow for the graphical model 6 that may be identified by a user 40.
  • the workflow 8 may include a set of tasks 10, 12 and 14 that are required to accomplish the goal associated with the workflow.
  • the workflow 8 may be manipulated via an API 16 that allows the user 40 to define and customize the workflow 8.
  • the API defines and manages the workflow.
  • the API allows one to register the specific tasks of a workflow, along with their relative order, optionally a partial order, and dependencies of tasks that, in turn, may be conditional.
  • the API also allows one to specify the structure of the workflow along with the referential integrity between tasks (i.e., which tasks are dependent on each other).
  • the API 16 may also allow a user to define and customize a new workflow for the graphical model 6.
  • Exemplary workflows include a workflow for converting a model from a floating point implementation to a fixed-point implementation, a workflow for converting a model from one type of fixed point implementation to another type of fixed point implementation, a workflow for converting a model from a continuous-time implementation to a discrete-time implementation, a workflow to optimize a model to enhance simulation performance, a workflow to configure a model for optimal code generation, a workflow to instrument a model for data logging, a data management workflow, a code generation workflow, a verification and validation (V &V) workflow to assess the correctness and robustness of a design, a workflow to prepare a model for connecting with instrumentation hardware, a workflow to configure 'reconfigurable input/output (I/O)', a workflow to setup instruments and a workflow for validating the matching of model interfaces, a workflow for calibrating a model to acquired data.
  • I/O input/output
  • the graphical modeling environment also includes a workflow manager 20 that synchronizes the workflow to the graphical modeling environment 4 and progressively tailors the graphical modeling environment based on the current state of the workflow 8.
  • the workflow manager 20 is discussed in further detail below.
  • the workflow manager 20 of the present invention also allows the user 40 to create a snapshot 22 of the current state of the execution of the workflow 8.
  • the snapshot 22 is depicted as being stored in the graphical modeling environment 4 on the computing device 2, the snapshot may be stored in other locations accessible to the workflow manager 20 without departing from the scope of the present invention. It will be recognized by those skilled in the art that the workflow manager 20 may be integrated into the graphical modeling environment 4 as a software tool, may be a plug-in for the graphical modeling environment, or alternatively may be a separate application or process communicating with the graphical modeling environment 4.
  • the computing device 2 communicates with a display 30 such as a computer monitor, television set or some other type of display device.
  • the display 30 may display a view 32 of a listing of the components affected by the identified workflow 8.
  • the display may also display a dialog workflow manager view 34 alternately with a graphical depiction of the graphical model referred to herein as a modeling environment view 36.
  • Exemplary modeling environment views include views of a block diagram editor, a data flow diagram editor, a text-based block inside a graphical diagram (the block may hold instructions in a dynamically typed language), a statechart, a sequence diagram, a class diagram, a physical modeling view, and a data explorer view.
  • other non-visual indicators such as audio or tactile feedback indicators may be used to indicate a component affected by the task in the workflow.
  • the workflow manager of the present invention may also be utilized in a distributed environment.
  • Figure 2 depicts an alternative distributed environment suitable for practicing the illustrative embodiment of the present invention.
  • a virtualized first computing device 60 hosts a modeling environment 62. It will be appreciated that the first computing device 60 could also be a physical device.
  • the modeling environment 62 includes at least one workflow 64 that is associated with a graphical model and the workflow manager 66. In other implementations, the workflow manager 66 may be in communication with, or integrated into, additional third-party workflow tools.
  • a user 92 accesses a second computing device 70 to communicate over a network 90 with the modeling environment 62 on the first computing device 60.
  • the network 90 may be the Internet, a local area network (LAN), a wide area network (WAN), a wireless network, an intranet, an extranet or some other type of network.
  • the second computing device 72 may include a graphical model 72 that is transmitted by the user 92 to the modeling environment 62.
  • the workflow 64 may be located on the second computing device 70 while the graphical model 72 is located on the first computing device.
  • both the workflow 64 and the graphical model 72 may be located in the modeling environment 62.
  • a server may be used to download code to be executed on a client device in order to practice the illustrative embodiment of the present invention.
  • Other alternative distributed architectures in addition to those discussed here will be apparent to those skilled in the art and are considered to be within the scope of the present invention.
  • the second computing device 70 is in communication with a display 80 upon which the output of the modeling environment 62 (which is transmitted over the network 90) may be displayed to the user 92.
  • the display 80 may include a workplace component view 82, a modeling environment view 84 and the workflow manager dialog view 86.
  • the different views 82, 84 and 86 may be displayed simultaneously, singly or in various combinations.
  • the workflow manager 20 of the present invention tailors the graphical modeling environment by synchronizing the model components with the workflow and eliminating or otherwise indicating which components are associated with the current step of the workflow and which are extraneous. It will be appreciated that more than one workflow may be active at a time (and synchronized with the modeling environment) by the workflow manager 20. When more than one workflow is active at a time, the workflows may share data as well as control.
  • Figures 3A-6B provides a series of screenshots which illustrate the usage and functionality of the workflow manager in a SIMULINK environment. It will be appreciated that the workflow manager 20 of the present invention may be employed in many different graphical modeling environments in addition to a SIMULINK environment.
  • Figure 3 A depicts the initialization of the workflow manager for a SIMULINK model with a particular goal in mind, the execution of a workflow converting a floating point SIMULINK model to a fixed-point equivalent.
  • the screenshot 100 shows the user selecting an identified workflow 102 from a menu option. It will be appreciated that other mechanisms for selecting a provided workflow from the graphical modeling environment 4 may be utilized within the scope of the present invention. Alternatively, the user may provide the workflow to the graphical modeling environment by providing a location of a stored workflow rather than selecting the workflow from a menu option.
  • the workflow may be stored in a database or a file.
  • the workflow may be stored in an XML format.
  • the workflow may be subjected to version control as well as configuration control (as a workflow can reference other workflows).
  • the stored workflows may be subjected to differencing and merging operations.
  • documentation of the workflow can be generated, for example in portable document format (PDF), POWERPOINT (PPT), or Hypertext Markup Language (HTML) format, which may show the workflow structure, conditions, requirements, configuration actions, etc.
  • PDF portable document format
  • PPT PowerPOINT
  • HTML Hypertext Markup Language
  • the documentation may be in a textual format or a graphical format.
  • a (partial) workflow may be constructed from a file.
  • POWERPOINT from Microsoft Corporation of Redmond, Washington
  • a workflow framework
  • a workflow editor may be used to supply missing details.
  • the completed workflow may then be exported back to the original or another file format.
  • Figure 3B depicts a screenshot 110 of the querying performed by the workflow manager 20 in an attempt to simplify the workflow steps.
  • the user is questioned to determine whether the conversion is new or a continuation 1 12, whether simulation data is to be used as a reference 114 and whether a feature that takes an automatic snapshot after each major step should be enabled 1 16.
  • Figure 3C depicts a screenshot of the workflow manager 20 presenting a hierarchical workflow view 122 showing the hierarchy of steps/tasks required by the workflow.
  • the workflow in Figure 3C is a streamlined workflow based on the information provided above along with any customization to the workflow through the API discussed below.
  • the workflow is streamlined in that it includes the necessary tasks based on the user input indicating that simulation data is available. If the user response to the queries had not indicated that simulation data was to be used, then those tasks associated with the simulated data would be removed from the workflow.
  • the workflow is synchronized to the modeling environment.
  • the workflow manager can act on any portion or the entirety of a model or models including the content of links such as model reference blocks and library blocks. In the example depicted in Figure 3C, the workflow is targeted to the "Control ler_Sy stem" portion of the model.
  • a tree view of the workflow tasks is just one aspect of the invention. Alternate methods of presenting the workflow are possible: for example, as a flow chart, state diagram, directed graph, with or without cycles or other graphical view.
  • a workflow may contain active parts so that once a workflow is selected, it may do whatever tasks it can automatically before relinquishing control to the user. Or, performing certain tasks automatically can be invoked when a user has prepared a model up to a certain point within one workflow stage. For example, once a sample rate is selected for the overall model and a desired solver that satisfies prerequisites, the workflow can invoke an automatic discretization of continuous time blocks. Before this discretization, it may also be required that the user removes incompatible blocks. Also, selecting a workflow may automatically select certain configuration options (e.g., for code generation). The workflow manager 20 provides a hierarchical description of the steps necessary to complete a specific task.
  • the workflow manager 20 is synchronized to the modeling environment in a way that reconfigures the entire modeling environment (or select portions of the modeling environment if desired) specific to the task at hand.
  • the workflow manager 20 may reconfigure libraries or a set of blocks available for usage.
  • the workflow manager 20 may also be coupled to a modeling style guideline so that selecting a workflow will result in a particular modeling style guideline being used.
  • the screenshot 130 of Figure 3D depicts the model environment in a default configuration when no particular step is selected.
  • the default view includes a listing 134 of the graphical model components, in the case of the present example these components are blocks and connections from the block diagram model.
  • FIG. 3F depicts a screenshot 150 that provides indicators (in this example broken lines) showing which components 158, 160 and 162 are affected by the current step in the workflow in the model contents pane 157 and which parts 152, 154 and 156 of the model hierarchy are associated with the current step in the workflow in a model hierarchy pane 151.
  • the workflow manager also provides an additional workflow manager view dialog 161 that requests additional information from the user for the particular step.
  • the selection of other steps in the workflow would reconfigure the environment specific to that task.
  • the step "prepare for scaling” will reconfigure the modeling environment to display views where data type and scaling information is applicable.
  • the manner and extent to which the environment is reconfigured between tasks is up to the workflow author.
  • the corresponding modeling environment view depicted in the screenshot 170 of Figure 3G also graphically indicates which model components 172, 174 and 176 in the block diagram model are affected by the current step in the workflow.
  • the synchronized information provides the designer with a better understanding of the effect of his design choices on the model than is possible with conventional tools.
  • the workflow manager tailors the graphical modeling environment based upon the current stage in the execution of the workflow.
  • the configuration and arrangement of the environment can change for specific tasks or be shared among tasks, which may be configured within the workflow API.
  • the workflow manager analyzes each workflow step to identify which components in the current model are affected by the current step's execution. For example, if the workflow calls for the alteration of a "sum" block in a block diagram model, the workflow manager can analyze the block diagram model to determine which other blocks are affected, directly or indirectly in a change in the sum block. Each of those blocks and the sum block would then be identified for the user.
  • the author of a particular workflow determines the requirements of each task in a workflow, and programs the workflow via the workflow API.
  • the workflow API allows the author to include analysis, visualization, actions, and artifact archival for each task in the workflow.
  • Figures 3F and 3G use dashed lines surrounding the components to indicate components affected by the current step in the workflow, it should be appreciated that a number of different mechanisms may be used to indicate the affected components.
  • the intensity of the component or component label may be varied to indicate that a particular component is or is not affected by a current step in the workflow.
  • affected components and/or component labels may be displayed in the graphical modeling environment in bold or with increased intensity while non-affected components may be grayed out or simply not shown in a particular view.
  • the components and/or component labels may be displayed using different colors to indicate which model components are affected by the current step in the workflow. It will be appreciated that many different types of indicators may be used within the scope of the present invention.
  • Another aspect of the workflow manager of the present invention is its ability to show progression toward a goal. For example, once the min/max values in the previous example are entered, the modeling environment provides feedback. That is, as information is entered into the modeling environment for a specific task the result is reflected visually. This allows the user to know what tasks are done and which are remaining. For example, the workflow manager may alter the display so that when the "Min” and "Max” values are entered for "Constant” during the "enter design min/max” an icon turns from yellow (meaning not done) to green (meaning done).
  • the constant label 192 may be surrounded by dotted lines to indicate the value has been entered while model hierarchy elements 182, 184 and 186 and model contents .188 and 190 are. surrounded by dashed lines indicating that the workflow is not done with them yet.
  • a similar depiction is shown in the graphical modeling view of Figure 31 where block diagram element 206 (the constant block) is surrounded by dotted lines to indicate completion in the workflow while block diagram elements 202 and 204 are surrounded by dashed lines to indicate their lack of completion.
  • color, display intensity or other forms of indicators may be substituted for those shown herein.
  • the workflow may reference a programmatic API that allows a user to add custom workflows, to add and remove steps from existing workflows and to perform other tasks.
  • the API is implemented using a MATLAB (from The Math Works, Inc of Natick,
  • Figure 4 shows a screenshot 300 of a workflow that may be defined and customized through a provided API.
  • the provision of an API allows a user to define and customize a workflow that synchronizes and controls the layout of the graphical environment.
  • the order of tasks is controlled through the API as well as the dependencies between tasks. For example, if task 2.3 depends on task 1.2, that information can be specified which allows the workflow manager to prevent progress on task 2.3 until task 1.2 is complete.
  • the API allows a user to specify connectivity to other workflows as well as types of people conducting the workflow. This is important since it allows a lower-level workflow to be reused by more than one higher-level workflow, which may involve more than one user.
  • Workflow navigation items can be superimposed on the model.
  • a 'forward' and 'backward' button may be present on the model canvas.
  • the appearance of the navigation items, and the workflow in general, can be designed using graphical editing environments that have a set of workflow specific operations (for example, forward, backward, and checkpoint operations) available for drag and drop design.
  • the graphical modeling environment may then operate in two different modes: one for editing the workflow and the appearance to the model designer and another where the workflow is affected.
  • the workflow manager may also be used in conjunction with templatized workflows (or parameterized workflows) and workflow fragments that represent a portion of a larger workflow.
  • the workflows created and/or altered via the API perform a number of functions.
  • the workflow collects input from the user and performs requested actions.
  • the workflow archives measurements, results, and/or data produced by the user input and/or requested actions.
  • the workflow may thus be used to not only achieve a goal but also to produces the necessary artifacts to prove a goal was met.
  • the proof of completion may meet a standard such as DO-178B.
  • the workflow and its associated API allow the workflow author to specify which tasks should be validated against acceptance criteria. Acceptance criteria are established for a model prior to conducting a workflow. Many types of acceptance criteria are possible depending on the goals of the workflow or application needs. For example, a typical acceptance criterion is to check that the model can still be compiled after a change to the model. Another example acceptance criterion is that the simulation result matches a specified baseline after a change to the model.
  • Acceptance criteria may be represented as a separate unique node in the workflow tree. Acceptance criteria include two types of acceptance criteria, workflow author-defined acceptance criteria and user-defined acceptance criteria The workflow author would determine if user-defined acceptance criteria is required. Acceptance criteria has 'levels'; e.g. mandatory or desired. Tasks may register which acceptance criteria they have to pass in order to be register as passing.
  • OCL object constraint language
  • the workflow manager of the present invention also provides reporting capability to indicate to a user how much work remains to be done. This reporting can be output in a variety of methods including but not limited to HTML and PDF reports, for example, or directly in the workflow manger itself.
  • the screenshot 310 in Figure 5 depicts the workflow manager displaying a "Status summary" 312 that indicates that "27" blocks in the model require min/max data.
  • the workflow manager allows a user to create "snapshots" that represent the current state of execution of the workflow.
  • the snapshot captures both workflow information entered by the user and model information.
  • the snapshot includes all of the data necessary to recreate the exact state of the model and its workflow. Snapshots can be saved and restored thus saving the user the time and effort of recreating an interrupted workflow.
  • the snapshot feature allows a user to experiment with various design choices with the knowledge that the user will be able to "back out” the choices to earlier saved restore point captured by a saved snapshot. Saving and restoring snapshots of a workflow is important since this allows the user to explore a solution space for an optimal result.
  • the full state of the workflow captured in a snapshot is saved as a persistent file on the computer hard drive for later restoration. It will be appreciated that the snapshot may also be saved on other storage mediums accessible to the graphical modeling environment and the workflow manager.
  • the present invention may also be used to facilitate workflow data logging.
  • Workflow data logging can track how long it took to complete a task, how many times did the user select 'undo', how many blocks were changed, what the number of blocks used was, which configuration changes were made, how often the model was simulated, and many other workflow related tasks. This information can be stored in a centralized database with the results being scored. Future workflow selection can be based on the scoring of the data logs and/or changes to the existing workflow can be made based on scores associated with a data log.
  • the present invention provides bi-directional linkage from the graphical modeling environment view such as a block diagram view to a hierarchical view of corresponding objects in the workflow.
  • Bi-directional linkage between components of a modeling environment is important since the optimal realization of an action in a workflow is task dependent.
  • the workflow manager initially guides the user to the most optimal component for realizing a task. However the user may choose to navigate to a different component for a variety of reasons such as understanding the problem context better, configuring in a component more familiar to them, etc. For example, a user can navigate from the block diagram to the component view for a task that requires action.
  • Figures 6A and 6B depicts the bi-directional linkage provided by the present invention between a block diagram editor and component view.
  • the screenshot 320 in Figure 6A shows the block diagram model associated with the identified workflow.
  • a pull down menu 324 By right clicking (or otherwise selecting) a user causes a pull down menu 324 to be displayed which includes the option 326 of navigating directly to the component view of the components affected by the current task.
  • Figure 6B shows a screenshot 330 of the corresponding component view, which includes a listing of the sum block 332, to which the user navigates.
  • the selection by the user of the "Show in FPT-ME" context menu selection 326 for the "Sum” block requiring action brings the user to the same point in the component view for making the desired changes.
  • the workflow manager of the present invention is capable of reconfiguring many different types of views in the modeling environment including a graphical modeling editor view, a model hierarchy view showing the hierarchy of the graphical model, which can be the nesting of graphical entities but could also be the nesting of functionality (which is different in case of virtual graphical nesting), a model dependencies view that shows the elements in the model environment that it depends upon such as initialization scripts, header files with data structures, referenced models, and referenced binaries, a compiled model view that shows the model properties after all degrees of freedom such as data type, dimensions, and sample rate have been determined (which may lead to inserting functional units that could be graphically depicted), a model requirements view that shows the requirements of the model that are compiled in a text based document such as a free-form text document or a spreadsheet, but potentially also superimposed on the model as determined by hotlinks between model entities and specific requirements, a model coverage view that shows the model aspects that have been evaluated and how comprehensively they have been evaluated during one
  • the workflow manager synchronizes a dynamically configurable workflow with the modeling environment.
  • the workflow may be adapted during the design activities.
  • a change in workflow may be predicated upon certain user activity. Instead of a static set of activities, the set of activities becomes dynamically selected. So, if a user selects a nonlinear element to be added to the graphical model, the workflow may be dynamically changed to require a linearization step. This may be based on simulation results as well.
  • the present invention may be provided as one or more computer-readable programs embodied on or in one or more mediums.
  • the mediums may be a floppy disk, a hard disk, a compact disc, a digital versatile disc, a flash memory card, a PROM, a RAM, a ROM, or a magnetic tape.
  • the computer-readable programs may be implemented in any programming language. Some examples of languages that can be used include MATLAB, Python, FORTRAN, C, C++, C#, or JAVA.
  • the software programs may be stored on or in one or more mediums as object code.
  • Hardware acceleration may be used and all or a portion of the code may run on a FPGA, an ASIC, a graphics processing unit (GPU), or any other piece of computational hardware, including analog, such as, for example, a configurable printed circuit board.
  • the code may run in a virtualized environment such as in a virtual machine. Multiple virtual machines running the code may be resident on a single processor. Since certain changes may be made without departing from the scope of the present invention, it is intended that all matter contained in the above description or shown in the accompanying drawings be interpreted as illustrative and not in a literal sense. Practitioners of the art will realize that the sequence of steps and architectures depicted in the figures may be altered without departing from the scope of the present invention and that the illustrations contained herein are singular examples of a multitude of possible depictions of the present invention.

Abstract

A workflow manager that offers structure and control over the graphical modeling environment so that the graphical modeling environment is reconfigured in a manner appropriate for a particular workflow is disclosed. The workflow manager of the present invention provides hierarchical task management that is synchronized to the graphical modeling environment. The workflow manager also allows a model designer to navigate a series of steps required to achieve the goal of a particular workflow. An API allows the steps to be customized as required by the end user.

Description

SYSTEM AND METHOD FOR SYNCHRONIZED WORKFLOW MANAGEMENT
Related Application
This application claims the benefit of U.S. Patent Application Serial No.1 1/432,939, filed May 12, 2006, the contents of which are hereby incorporated by reference.
Field of the Invention
The illustrative embodiment of the present invention relates generally to workflows in graphical modeling environments, and more particularly to a workflow manager synchronized with the graphical modeling environment.
Background
Graphical programming languages and graphical modeling environments enable the construction of graphical models such as block diagram models, entity flow models, flow diagrams, computational noncausal models, and statechart models. Graphical programming languages provide a wide array of functionality that may be utilized during model design. Frequently there is more than one approach to solving a particular problem, achieving a particular goal, or following a proven procedure. Achieving a particular goal often requires a set of tasks that are unknown or difficult for a novice user to grasp. A workflow describes the set of tasks that must be completed in order to accomplish particular goals during the design of a graphical model.
Some conventional graphical programming languages provide tools that assist a user in identifying problems with a design and further facilitate the implementation of recommendations designed to address the problems. Unfortunately, these conventional tools provide advice that is relatively unstructured in that the advice is not closely associated with a particular portion of a workflow. Additionally these conventional tools do not tailor the graphical modeling environment for a particular task that the model designer is attempting to accomplish. It would be desirable to provide a workflow management tool that provides structured advice and is able to reconfigure the graphical modeling environment in a manner suitable for the particular workflow that is being executed by the model designer. Brief Summary
The illustrative embodiment of the present invention provides a workflow manager that offers structure and control over the graphical modeling environment so that the graphical modeling environment is reconfigured in a manner appropriate for a particular workflow. The workflow manager of the present invention provides hierarchical task management that is synchronized to the graphical modeling environment. The workflow manager allows a model designer to navigate a series of steps required to achieve the goal of a particular workflow. An application programming interface (API) allows the steps to be customized as required by the end user.
In one aspect of the present invention, a method of managing workflows in a graphical modeling environment includes the step of receiving user input associated with an identified workflow. The method also displays information associated with the identified workflow based on the received user input. The method additionally reconfigures the modeling environment in response to a user selection.
In another aspect of the present invention, a system for capturing task-based workflows in a graphical modeling environment includes a task-based workflow identified by a user. The system also includes user input associated with the task-based workflow. A view of information associated with the workflow based on the received user input is also part of the system. The workflow is synchronized to a modeling environment. The modeling environment of the system is reconfigured in response to a user selection.
Brief Description of the Drawings
The invention is pointed out with particularity in the appended claims. The advantages of the invention described above, as well as further advantages of the invention, may be better understood by reference to the following description taken in conjunction with the accompanying drawings, in which: Figure 1 depicts an environment suitable for practicing the illustrative embodiment of the present invention;
Figure 2 depicts an alternative distributed environment suitable for practicing the illustrative embodiment of the present invention; Figure 3 A depicts a screenshot of the selection of a user-identified workflow;
Figure 3B depicts a screenshot of the solicitation of user input by the workflow manager in order to simplify the chosen workflow;
Figure 3C depicts a screenshot of a hierarchical view of the tasks relevant to the identified workflow and based on the user input solicited in Figure 3B;
Figure 3D depicts the model environment in a default configuration;
Figures 3E-3F depict a screenshot of a user selection of a particular step in the presented workflow and the subsequent reconfiguring of the graphical modeling environment to show the relevant portions of the model; Figure 3G depicts a screenshot of the graphical model editor highlighted to show the model components relevant to a task;
Figures 3H and 31 depict screenshots of the workflow manager reconfiguring the model hierarchy and graphical model editor respectively to show progress towards the completion of a task required in the identified workflow; Figure 4 shows a workflow that may be defined and customized through a provided API;
Figure 5 depicts one aspect of the reporting capability of the workflow manager; and
Figures 6A and 6B depict the bi-directional linkage provided by the present invention between a block diagram editor and model explorer view.
Detailed Description
The workflow manager of the illustrative embodiment of the present invention programmatically tailors and customizes the graphical modeling environment into a form appropriate for an identified workflow associated with a graphical model. By tailoring the graphical modeling environment to the workflow, the design process becomes more focused and efficient. The synchronization of the different views of the model design to the workflow allow the user to ascertain how design choices made at each step of the workflow affect the model components impacted by that step of the workflow. The ability to create and restore snapshots of the workflow process allows the design process to be started and stopped efficiently from a number of different points in the workflow without the need to restart the workflow from the beginning of the process. Figure 1 depicts an environment suitable for practicing the illustrative embodiment of the present invention. A computing device 2 supports a graphical modeling environment 4. Graphical modeling environments are programs that enable a user to construct and analyze a model of a process or system. Examples of modeling formalisms that are supported by graphical modeling tools include time-based block diagrams, such as supported by Simulink from The Math Works Inc., discrete event diagrams and reactive state machine diagrams, such as those supported by Stateflow® from The Math Works, Inc., data-flow diagrams, such as those supported by LabVIEW, available from National Instruments Corporation, entity flow modeling tools such as SimEvents, rigid body modeling tools such as SimMechanics both available from The Math Works, Inc., and software diagrams and other graphical modeling languages, as found, for example, in Unified Modeling Language (UML) diagrams such as supported by Rational from IBM and Rhapsody from I-Logix. The computing device 2 may be a computing device such as a workstation, server, laptop, mainframe, PDA (personal digital assistant), a game platform, tablet PCs, a mobile telephone, a cluster of devices operating together, a virtual device or another computing device able to support the graphical modeling environment 4. The computing device 2 may have a single processor 24 or multiple processors 24 and 27 and the processors may be single-core processors 25 or multi-core processors 25 and 26 and 28 and 29. The graphical modeling environment 4 includes at least one graphical model 6.
The graphical modeling environment 4 also includes at least one workflow for the graphical model 6 that may be identified by a user 40. The workflow 8 may include a set of tasks 10, 12 and 14 that are required to accomplish the goal associated with the workflow. The workflow 8 may be manipulated via an API 16 that allows the user 40 to define and customize the workflow 8. The API defines and manages the workflow. The API allows one to register the specific tasks of a workflow, along with their relative order, optionally a partial order, and dependencies of tasks that, in turn, may be conditional. The API also allows one to specify the structure of the workflow along with the referential integrity between tasks (i.e., which tasks are dependent on each other). The API 16 may also allow a user to define and customize a new workflow for the graphical model 6. Exemplary workflows include a workflow for converting a model from a floating point implementation to a fixed-point implementation, a workflow for converting a model from one type of fixed point implementation to another type of fixed point implementation, a workflow for converting a model from a continuous-time implementation to a discrete-time implementation, a workflow to optimize a model to enhance simulation performance, a workflow to configure a model for optimal code generation, a workflow to instrument a model for data logging, a data management workflow, a code generation workflow, a verification and validation (V &V) workflow to assess the correctness and robustness of a design, a workflow to prepare a model for connecting with instrumentation hardware, a workflow to configure 'reconfigurable input/output (I/O)', a workflow to setup instruments and a workflow for validating the matching of model interfaces, a workflow for calibrating a model to acquired data. Those skilled in the art will recognize that many additional workflows may also be managed by the workflow manager of the present invention and that the above list is included for illustrative purposes rather than to provide an exhaustive listing of all of the workflows available to the present invention. Furthermore it will also be appreciated that a workflow may be nested within another workflow or referenced by another workflow so that the execution of a first workflow is dependent on a second workflow. The graphical modeling environment also includes a workflow manager 20 that synchronizes the workflow to the graphical modeling environment 4 and progressively tailors the graphical modeling environment based on the current state of the workflow 8. The workflow manager 20 is discussed in further detail below. The workflow manager 20 of the present invention also allows the user 40 to create a snapshot 22 of the current state of the execution of the workflow 8. It will be appreciated that although the snapshot 22 is depicted as being stored in the graphical modeling environment 4 on the computing device 2, the snapshot may be stored in other locations accessible to the workflow manager 20 without departing from the scope of the present invention. It will be recognized by those skilled in the art that the workflow manager 20 may be integrated into the graphical modeling environment 4 as a software tool, may be a plug-in for the graphical modeling environment, or alternatively may be a separate application or process communicating with the graphical modeling environment 4.
The computing device 2 communicates with a display 30 such as a computer monitor, television set or some other type of display device. The display 30 may display a view 32 of a listing of the components affected by the identified workflow 8. The display may also display a dialog workflow manager view 34 alternately with a graphical depiction of the graphical model referred to herein as a modeling environment view 36. Exemplary modeling environment views include views of a block diagram editor, a data flow diagram editor, a text-based block inside a graphical diagram (the block may hold instructions in a dynamically typed language), a statechart, a sequence diagram, a class diagram, a physical modeling view, and a data explorer view. In other implementations, other non-visual indicators such as audio or tactile feedback indicators may be used to indicate a component affected by the task in the workflow.
The workflow manager of the present invention may also be utilized in a distributed environment. Figure 2 depicts an alternative distributed environment suitable for practicing the illustrative embodiment of the present invention. A virtualized first computing device 60 hosts a modeling environment 62. It will be appreciated that the first computing device 60 could also be a physical device. The modeling environment 62 includes at least one workflow 64 that is associated with a graphical model and the workflow manager 66. In other implementations, the workflow manager 66 may be in communication with, or integrated into, additional third-party workflow tools. A user 92 accesses a second computing device 70 to communicate over a network 90 with the modeling environment 62 on the first computing device 60. The network 90 may be the Internet, a local area network (LAN), a wide area network (WAN), a wireless network, an intranet, an extranet or some other type of network. The second computing device 72 may include a graphical model 72 that is transmitted by the user 92 to the modeling environment 62. In another implementation, the workflow 64 may be located on the second computing device 70 while the graphical model 72 is located on the first computing device. Alternatively, both the workflow 64 and the graphical model 72 may be located in the modeling environment 62. In an alternative implementation, a server may be used to download code to be executed on a client device in order to practice the illustrative embodiment of the present invention. Other alternative distributed architectures in addition to those discussed here will be apparent to those skilled in the art and are considered to be within the scope of the present invention.
The second computing device 70 is in communication with a display 80 upon which the output of the modeling environment 62 (which is transmitted over the network 90) may be displayed to the user 92. The display 80 may include a workplace component view 82, a modeling environment view 84 and the workflow manager dialog view 86. The different views 82, 84 and 86 may be displayed simultaneously, singly or in various combinations.
The workflow manager 20 of the present invention tailors the graphical modeling environment by synchronizing the model components with the workflow and eliminating or otherwise indicating which components are associated with the current step of the workflow and which are extraneous. It will be appreciated that more than one workflow may be active at a time (and synchronized with the modeling environment) by the workflow manager 20. When more than one workflow is active at a time, the workflows may share data as well as control. In order to better explain the workflow manager 20, Figures 3A-6B provides a series of screenshots which illustrate the usage and functionality of the workflow manager in a SIMULINK environment. It will be appreciated that the workflow manager 20 of the present invention may be employed in many different graphical modeling environments in addition to a SIMULINK environment.
Figure 3 A depicts the initialization of the workflow manager for a SIMULINK model with a particular goal in mind, the execution of a workflow converting a floating point SIMULINK model to a fixed-point equivalent. The screenshot 100 shows the user selecting an identified workflow 102 from a menu option. It will be appreciated that other mechanisms for selecting a provided workflow from the graphical modeling environment 4 may be utilized within the scope of the present invention. Alternatively, the user may provide the workflow to the graphical modeling environment by providing a location of a stored workflow rather than selecting the workflow from a menu option.
The workflow may be stored in a database or a file. The workflow may be stored in an XML format. The workflow may be subjected to version control as well as configuration control (as a workflow can reference other workflows). The stored workflows may be subjected to differencing and merging operations. Furthermore, documentation of the workflow can be generated, for example in portable document format (PDF), POWERPOINT (PPT), or Hypertext Markup Language (HTML) format, which may show the workflow structure, conditions, requirements, configuration actions, etc. The documentation may be in a textual format or a graphical format. Moreover, a (partial) workflow may be constructed from a file. For example, a number of slides in POWERPOINT (from Microsoft Corporation of Redmond, Washington) can be imported and converted into a workflow (framework), including the branching points that POWERPOINT facilitates. In the case of a partial workflow (e.g., a workflow framework or template), a workflow editor may be used to supply missing details. The completed workflow may then be exported back to the original or another file format.
Figure 3B depicts a screenshot 110 of the querying performed by the workflow manager 20 in an attempt to simplify the workflow steps. Thus, the user is questioned to determine whether the conversion is new or a continuation 1 12, whether simulation data is to be used as a reference 114 and whether a feature that takes an automatic snapshot after each major step should be enabled 1 16. It will be appreciated that the substance of the queries will vary according to the nature of the workflow. Figure 3C depicts a screenshot of the workflow manager 20 presenting a hierarchical workflow view 122 showing the hierarchy of steps/tasks required by the workflow. The workflow in Figure 3C is a streamlined workflow based on the information provided above along with any customization to the workflow through the API discussed below. The workflow is streamlined in that it includes the necessary tasks based on the user input indicating that simulation data is available. If the user response to the queries had not indicated that simulation data was to be used, then those tasks associated with the simulated data would be removed from the workflow. The workflow is synchronized to the modeling environment. The workflow manager can act on any portion or the entirety of a model or models including the content of links such as model reference blocks and library blocks. In the example depicted in Figure 3C, the workflow is targeted to the "Control ler_Sy stem" portion of the model. It should be noted that a tree view of the workflow tasks is just one aspect of the invention. Alternate methods of presenting the workflow are possible: for example, as a flow chart, state diagram, directed graph, with or without cycles or other graphical view.
A workflow may contain active parts so that once a workflow is selected, it may do whatever tasks it can automatically before relinquishing control to the user. Or, performing certain tasks automatically can be invoked when a user has prepared a model up to a certain point within one workflow stage. For example, once a sample rate is selected for the overall model and a desired solver that satisfies prerequisites, the workflow can invoke an automatic discretization of continuous time blocks. Before this discretization, it may also be required that the user removes incompatible blocks. Also, selecting a workflow may automatically select certain configuration options (e.g., for code generation). The workflow manager 20 provides a hierarchical description of the steps necessary to complete a specific task. One aspect of the present invention is that the workflow manager 20 is synchronized to the modeling environment in a way that reconfigures the entire modeling environment (or select portions of the modeling environment if desired) specific to the task at hand. For example, the workflow manager 20 may reconfigure libraries or a set of blocks available for usage. The workflow manager 20 may also be coupled to a modeling style guideline so that selecting a workflow will result in a particular modeling style guideline being used. As another example of the synchronization of the modeling environment with the workflow, the screenshot 130 of Figure 3D depicts the model environment in a default configuration when no particular step is selected. The default view includes a listing 134 of the graphical model components, in the case of the present example these components are blocks and connections from the block diagram model. After the selection and expansion of the fixed point conversion workflow 132 and a selection of the step 142 for entering a design min/max as depicted in the screenshot 140 of Figure 3E, the model environment is reconfigured by the workflow manager. The workflow manager presents a new window pane 144 that includes information related to the current step. The workflow manager synchronizes the workflow step to the alternate views in the modeling environment. Thus Figure 3F depicts a screenshot 150 that provides indicators (in this example broken lines) showing which components 158, 160 and 162 are affected by the current step in the workflow in the model contents pane 157 and which parts 152, 154 and 156 of the model hierarchy are associated with the current step in the workflow in a model hierarchy pane 151. The workflow manager also provides an additional workflow manager view dialog 161 that requests additional information from the user for the particular step. It will be appreciated that the selection of other steps in the workflow would reconfigure the environment specific to that task. For example, the step "prepare for scaling" will reconfigure the modeling environment to display views where data type and scaling information is applicable. The manner and extent to which the environment is reconfigured between tasks is up to the workflow author. The corresponding modeling environment view depicted in the screenshot 170 of Figure 3G also graphically indicates which model components 172, 174 and 176 in the block diagram model are affected by the current step in the workflow. The synchronized information provides the designer with a better understanding of the effect of his design choices on the model than is possible with conventional tools.
The workflow manager tailors the graphical modeling environment based upon the current stage in the execution of the workflow. The configuration and arrangement of the environment can change for specific tasks or be shared among tasks, which may be configured within the workflow API. The workflow manager analyzes each workflow step to identify which components in the current model are affected by the current step's execution. For example, if the workflow calls for the alteration of a "sum" block in a block diagram model, the workflow manager can analyze the block diagram model to determine which other blocks are affected, directly or indirectly in a change in the sum block. Each of those blocks and the sum block would then be identified for the user. The author of a particular workflow determines the requirements of each task in a workflow, and programs the workflow via the workflow API. The workflow API allows the author to include analysis, visualization, actions, and artifact archival for each task in the workflow.
Although Figures 3F and 3G use dashed lines surrounding the components to indicate components affected by the current step in the workflow, it should be appreciated that a number of different mechanisms may be used to indicate the affected components. For example, the intensity of the component or component label may be varied to indicate that a particular component is or is not affected by a current step in the workflow. Thus affected components and/or component labels may be displayed in the graphical modeling environment in bold or with increased intensity while non-affected components may be grayed out or simply not shown in a particular view. Alternatively, the components and/or component labels may be displayed using different colors to indicate which model components are affected by the current step in the workflow. It will be appreciated that many different types of indicators may be used within the scope of the present invention.
Another aspect of the workflow manager of the present invention is its ability to show progression toward a goal. For example, once the min/max values in the previous example are entered, the modeling environment provides feedback. That is, as information is entered into the modeling environment for a specific task the result is reflected visually. This allows the user to know what tasks are done and which are remaining. For example, the workflow manager may alter the display so that when the "Min" and "Max" values are entered for "Constant" during the "enter design min/max" an icon turns from yellow (meaning not done) to green (meaning done). Alternatively as depicted in the screenshot 180 of Figure 3H, the constant label 192 may be surrounded by dotted lines to indicate the value has been entered while model hierarchy elements 182, 184 and 186 and model contents .188 and 190 are. surrounded by dashed lines indicating that the workflow is not done with them yet. A similar depiction is shown in the graphical modeling view of Figure 31 where block diagram element 206 (the constant block) is surrounded by dotted lines to indicate completion in the workflow while block diagram elements 202 and 204 are surrounded by dashed lines to indicate their lack of completion. As noted above, color, display intensity or other forms of indicators may be substituted for those shown herein.
In one aspect of the present invention, the workflow may reference a programmatic API that allows a user to add custom workflows, to add and remove steps from existing workflows and to perform other tasks. In an exemplary implementation, the API is implemented using a MATLAB (from The Math Works, Inc of Natick,
Massachusetts) programming interface, but many other implementations are possible within the scope of the present invention. Figure 4 shows a screenshot 300 of a workflow that may be defined and customized through a provided API. The provision of an API allows a user to define and customize a workflow that synchronizes and controls the layout of the graphical environment. The order of tasks is controlled through the API as well as the dependencies between tasks. For example, if task 2.3 depends on task 1.2, that information can be specified which allows the workflow manager to prevent progress on task 2.3 until task 1.2 is complete. In addition, the API allows a user to specify connectivity to other workflows as well as types of people conducting the workflow. This is important since it allows a lower-level workflow to be reused by more than one higher-level workflow, which may involve more than one user.
Workflow navigation items can be superimposed on the model. For example, a 'forward' and 'backward' button may be present on the model canvas. The appearance of the navigation items, and the workflow in general, can be designed using graphical editing environments that have a set of workflow specific operations (for example, forward, backward, and checkpoint operations) available for drag and drop design. The graphical modeling environment may then operate in two different modes: one for editing the workflow and the appearance to the model designer and another where the workflow is affected. The workflow manager may also be used in conjunction with templatized workflows (or parameterized workflows) and workflow fragments that represent a portion of a larger workflow.
The workflows created and/or altered via the API perform a number of functions. The workflow collects input from the user and performs requested actions.
Additionally, the workflow archives measurements, results, and/or data produced by the user input and/or requested actions. The workflow may thus be used to not only achieve a goal but also to produces the necessary artifacts to prove a goal was met. The proof of completion may meet a standard such as DO-178B. Additionally, the workflow and its associated API allow the workflow author to specify which tasks should be validated against acceptance criteria. Acceptance criteria are established for a model prior to conducting a workflow. Many types of acceptance criteria are possible depending on the goals of the workflow or application needs. For example, a typical acceptance criterion is to check that the model can still be compiled after a change to the model. Another example acceptance criterion is that the simulation result matches a specified baseline after a change to the model. In other words, as the user perform tasks within the workflow, the model changes and is therefore continuously validated against a set of acceptance criteria. The acceptance criteria and the workflow may be specified using object constraint language (OCL). Acceptance criteria may be represented as a separate unique node in the workflow tree. Acceptance criteria include two types of acceptance criteria, workflow author-defined acceptance criteria and user-defined acceptance criteria The workflow author would determine if user-defined acceptance criteria is required. Acceptance criteria has 'levels'; e.g. mandatory or desired. Tasks may register which acceptance criteria they have to pass in order to be register as passing.
The workflow manager of the present invention also provides reporting capability to indicate to a user how much work remains to be done. This reporting can be output in a variety of methods including but not limited to HTML and PDF reports, for example, or directly in the workflow manger itself. The screenshot 310 in Figure 5 depicts the workflow manager displaying a "Status summary" 312 that indicates that "27" blocks in the model require min/max data.
In another aspect of the present invention, the workflow manager allows a user to create "snapshots" that represent the current state of execution of the workflow. The snapshot captures both workflow information entered by the user and model information. The snapshot includes all of the data necessary to recreate the exact state of the model and its workflow. Snapshots can be saved and restored thus saving the user the time and effort of recreating an interrupted workflow. Additionally, the snapshot feature allows a user to experiment with various design choices with the knowledge that the user will be able to "back out" the choices to earlier saved restore point captured by a saved snapshot. Saving and restoring snapshots of a workflow is important since this allows the user to explore a solution space for an optimal result. In one implementation, the full state of the workflow captured in a snapshot is saved as a persistent file on the computer hard drive for later restoration. It will be appreciated that the snapshot may also be saved on other storage mediums accessible to the graphical modeling environment and the workflow manager.
The present invention may also be used to facilitate workflow data logging. Workflow data logging can track how long it took to complete a task, how many times did the user select 'undo', how many blocks were changed, what the number of blocks used was, which configuration changes were made, how often the model was simulated, and many other workflow related tasks. This information can be stored in a centralized database with the results being scored. Future workflow selection can be based on the scoring of the data logs and/or changes to the existing workflow can be made based on scores associated with a data log.
The present invention provides bi-directional linkage from the graphical modeling environment view such as a block diagram view to a hierarchical view of corresponding objects in the workflow. Bi-directional linkage between components of a modeling environment is important since the optimal realization of an action in a workflow is task dependent. The workflow manager initially guides the user to the most optimal component for realizing a task. However the user may choose to navigate to a different component for a variety of reasons such as understanding the problem context better, configuring in a component more familiar to them, etc. For example, a user can navigate from the block diagram to the component view for a task that requires action. Figures 6A and 6B depicts the bi-directional linkage provided by the present invention between a block diagram editor and component view. The screenshot 320 in Figure 6A shows the block diagram model associated with the identified workflow. By right clicking (or otherwise selecting) a user causes a pull down menu 324 to be displayed which includes the option 326 of navigating directly to the component view of the components affected by the current task. Figure 6B shows a screenshot 330 of the corresponding component view, which includes a listing of the sum block 332, to which the user navigates. In other words, the selection by the user of the "Show in FPT-ME" context menu selection 326 for the "Sum" block requiring action brings the user to the same point in the component view for making the desired changes.
As will be apparent from the above discussion, the workflow manager of the present invention is capable of reconfiguring many different types of views in the modeling environment including a graphical modeling editor view, a model hierarchy view showing the hierarchy of the graphical model, which can be the nesting of graphical entities but could also be the nesting of functionality (which is different in case of virtual graphical nesting), a model dependencies view that shows the elements in the model environment that it depends upon such as initialization scripts, header files with data structures, referenced models, and referenced binaries, a compiled model view that shows the model properties after all degrees of freedom such as data type, dimensions, and sample rate have been determined (which may lead to inserting functional units that could be graphically depicted), a model requirements view that shows the requirements of the model that are compiled in a text based document such as a free-form text document or a spreadsheet, but potentially also superimposed on the model as determined by hotlinks between model entities and specific requirements, a model coverage view that shows the model aspects that have been evaluated and how comprehensively they have been evaluated during one or a number of simulations (for example, condition coverage or modified condition/decision coverage, MC/DC), a model simulation results view, a model debugging view that shows values internal to the execution computations and that allows halting the execution at desired points in the flow of computations required for execution, a model profiling view that shows the computational expense of the model entities as established during one or multiple simulation runs, and a contents editor view.
In one aspect of the present invention, the workflow manager synchronizes a dynamically configurable workflow with the modeling environment. For a dynamically configurable workflow, the workflow may be adapted during the design activities. A change in workflow may be predicated upon certain user activity. Instead of a static set of activities, the set of activities becomes dynamically selected. So, if a user selects a nonlinear element to be added to the graphical model, the workflow may be dynamically changed to require a linearization step. This may be based on simulation results as well.
The present invention may be provided as one or more computer-readable programs embodied on or in one or more mediums. The mediums may be a floppy disk, a hard disk, a compact disc, a digital versatile disc, a flash memory card, a PROM, a RAM, a ROM, or a magnetic tape. In general, the computer-readable programs may be implemented in any programming language. Some examples of languages that can be used include MATLAB, Python, FORTRAN, C, C++, C#, or JAVA. The software programs may be stored on or in one or more mediums as object code. Hardware acceleration may be used and all or a portion of the code may run on a FPGA, an ASIC, a graphics processing unit (GPU), or any other piece of computational hardware, including analog, such as, for example, a configurable printed circuit board. The code may run in a virtualized environment such as in a virtual machine. Multiple virtual machines running the code may be resident on a single processor. Since certain changes may be made without departing from the scope of the present invention, it is intended that all matter contained in the above description or shown in the accompanying drawings be interpreted as illustrative and not in a literal sense. Practitioners of the art will realize that the sequence of steps and architectures depicted in the figures may be altered without departing from the scope of the present invention and that the illustrations contained herein are singular examples of a multitude of possible depictions of the present invention.

Claims

We Claim:
1. A method of managing workflows in a graphical modeling environment, comprising: receiving user input associated with an identified workflow; displaying information associated with the identified workflow based on the received user input; and reconfiguring at least a portion of a modeling environment in response to a user selection.
2. The method of claim 1 wherein the user selection is the selection of a step in the identified workflow and wherein reconfiguring at least a portion of the modeling environment comprises reconfiguring the modeling environment to graphically indicate model elements associated with the identified step.
3. The method of claim 2, wherein graphically indicating model elements associated with the identified step further comprises at least one of modifying a display color of at least one model element associated with the identified step and altering a display intensity property for the element.
4. The method of claim 1 wherein reconfiguring at least a portion of a modeling environment further comprises displaying at least one of: a graphical modeling editor view, a model hierarchy view, a model dependencies view, a compiled model view, a model requirements view, a model coverage view, a model simulation results view, a model debugging view, a model profiling view and a contents editor view.
5. The method of claim 1, wherein the reconfiguring of the modeling environment further comprises altering a view generated by the modeling environment to indicate to the user a progression towards completion of the identified workflow.
6. The method of claim 5 wherein the modeling environment is altered to display completed items in the identified workflow in a first color and incomplete items in the identified workflow in a second color.
7. The method of claim 1 wherein the identified workflow is selected by a user from a menu.
8. The method of claim 1, further comprising: providing an API that allows a user to add at least a second workflow to the modeling environment, both the second workflow and the identified workflow being simultaneously active in the modeling environment.
9. The method of claim 1, further comprising: providing an API that allows a user to create a new workflow associated with a model being modeled in the modeling environment.
10. The method of claim 1, further comprising: providing an API that allows a user to alter an existing workflow.
1 1. The method of claim 10, wherein the altering of the existing workflow comprises one or a combination of: adding a step to the existing workflow, deleting a step from the existing workflow, an ordering of tasks in the workflow, a changing of the dependencies of tasks in the workflow, a setting of a permission level for at least one of a user or type of user to execute the workflow, an addition of an indication of a relationship to at least one other workflow, highlighting model elements and an altering of an existing indication of a relationship to at least one other workflow.
12. The method of claim 1, further comprising: providing a set of acceptance criteria for a model being modeled in the modeling environment; specifying at least one task in a workflow associated with the model as requiring validation against the acceptance criteria.
13. The method of claim 12 wherein one of the set of acceptance criteria or an alteration to the set of acceptance criteria are specified using an API associated with the workflow.
14. The method of claim 12 further comprising: performing a task in the workflow; and validating the model against the set of acceptance criteria.
15. The method of claim 1 , further comprising: providing to the user a report indicating an amount of incomplete work in the workflow.
16. The method of claim 16 wherein the report is displayed in a workflow manager.
17. The method of claim 1, further comprising: saving a snapshot of a state of the identified workflow, the snapshot including at least one of a collection of current workflow information and a collection of current model information.
18. The method of claim 18, further comprising: restoring the state saved in the snapshot in the graphical modeling environment.
19. The method of claim 1, further comprising: linking bi-directionally components in different views of the graphical modeling environment, the bi-directional linkage allowing a user to navigate from a first component in one view to a corresponding component in a second view.
20. The method of claim 1 wherein the identified workflow is one or a combination of: a workflow converting a model from a floating point implementation to a fixed-point implementation, a workflow converting a model from one type of fixed point implementation to another type of fixed point implementation, a workflow converting a model from a continuous-time implementation to a discrete-time implementation, a workflow to optimize a model to enhance simulation performance, a workflow to configure a model for optimal code generation, a workflow for instrumenting a model for data logging, a data management workflow, a code generation workflow, a verification and validation workflow, a workflow calibrating against collected data, a workflow for validating the matching of model interfaces, a workflow to prepare a model for connecting with instrumentation hardware, a workflow to configure 'reconfigurable I/O', and a workflow to setup instruments.
21. The method of claim 1 wherein the reconfiguring of the model environment further comprises: reconfiguring one or more of: a block diagram editor, a data flow diagram editor, a text-based block inside a graphical diagram, a statechart, a sequence diagram, a class diagram, a physical modeling view, and a data explorer view.
22. The method of claim 1 wherein the reconfiguring of the model environment reconfigures one or more of: a spreadsheet view, a GUI, a tree view, a block, a state, a library, a user dialog, a signal, a dependency view, a text-based editor, an application environment, a system environment and a transition.
23. The method of claim 1 wherein the identified workflow is a hierarchical task- based workflow.
24. The method of claim 1 wherein the identified workflow is depicted using one of the group of: graphics and text.
25. The method of claim 25 wherein the identified workflow is represented by one of a flowchart and state chart.
26. The method of claim 1 wherein the identified workflow generates an artifact proving the completion of at least one task within the workflow.
27. The method of claim 1, further comprising: synchronizing the workflow to the modeling environment.
28. A system for capturing task-based workflows in a graphical modeling environment, comprising: a task-based workflow identified by a user; user input associated with the task-based workflow; a view of information associated with the workflow based on the received user input, the workflow synchronized to a modeling environment; and a modeling environment, the modeling environment being reconfigured in response to a user selection.
29. The system of claim 28 wherein the task-based workflow is a hierarchical task- based workflow.
30. The system of claim 28 wherein the modeling environment includes at least one of: a block diagram editor, a data flow diagram editor, a text-based block inside a graphical diagram, a statechart, a sequence diagram, an entity flow diagram, a class diagram, a physical modeling view, and a data explorer view.
31. The system of claim 28 further comprising: at least one snapshot of a current state of the identified workflow, the snapshot including at least one of a collection of current workflow information and a collection of current model information.
32. A medium holding computer-executable instructions for providing a task manager, the instructions comprising: instructions for receiving user input associated with a identified workflow; instructions for displaying information associated with the identified workflow based on the received user input; and instructions for reconfiguring at least a portion of a modeling environment in response to a user selection.
33. The medium of claim 32 wherein the user selection is the selection of a step in the identified workflow and wherein reconfiguring at least a portion of the modeling environment comprises reconfiguring the modeling environment to graphically indicate model elements associated with the identified step.
34. The medium of claim 33 wherein graphically indicating model elements associated with the identified step further comprises: modifying a display color of at least one model element associated with the identified step.
35. The medium of claim 33 wherein the instructions further comprise: instructions for graphically indicating in the modeling environment the elements associated with the identified step by altering a display intensity property for the element.
36. The medium of claim 32 wherein a view generated by the modeling environment includes at least one of a graphical modeling editor view, a model hierarchy view, a model dependencies view, a compiled model view, a model requirements view, a model coverage view, a model simulation results view, a model debugging view, a model profiling view and a contents editor view.
37. The medium of claim 32 wherein the reconfiguring of the modeling environment includes altering a view generated by the modeling environment to indicate to the user a progression towards completion of the identified workflow.
38. The medium of claim 37 wherein the modeling environment is altered to display completed items in the identified workflow in a first color and incomplete items in the identified workflow in a second color.
39. The medium of claim 32 wherein the identified workflow is selected by a user from a menu.
40. The medium of claim 32 wherein the instructions further comprise: instructions for providing an API that allows a user to add at least a second workflow to the modeling environment, both the second workflow and the identified workflow being simultaneously active in the modeling environment.
41. The medium of claim 32 wherein the instructions further comprise: instructions for providing an API that allows a user to create a new workflow.
42. The medium of claim 32 wherein the instructions further comprise: instructions for providing an API that allows a user to alter an existing workflow.
43. The medium of claim 42, wherein the altering comprises one or a combination of: adding a step to the existing workflow, deleting a step from the existing workflow, an ordering of tasks in the workflow, a changing of the dependencies of tasks in the workflow, a setting of a permission level for at least one of a user or type of user to execute the workflow, an addition of an indication of a relationship to at least one other workflow and an altering of an existing indication of a relationship to at least one other workflow.
44. The medium of claim 32, wherein the instructions further comprise: instructions for providing a set of acceptance criteria for a model being modeled in the modeling environment; instructions for specifying at least one task in a workflow associated with the model as requiring validation against the acceptance criteria.
45. The medium of claim 44 wherein one of the set of acceptance criteria or an alteration to the set of acceptance criteria are specified using an API associated with the workflow. :
46. The medium of claim 44 wherein the instructions further comprise: instructions for performing a task in the workflow; and instructions for validating the model against the set of acceptance criteria.
47. The medium of claim 32 wherein the instructions further comprise: instructions for providing a report to a user indicating an amount of incomplete work in the workflow.
48. The medium of claim 47 wherein the report is displayed in a workflow manager.
49. The medium of claim 32 wherein the instructions further comprise: instructions for saving a snapshot of a state of the identified workflow, the snapshot including at least one of a collection of current workflow information and a collection of current model information.
50. The medium of claim 49 wherein the instructions further comprise: instructions for restoring the state saved by the snapshot in the graphical modeling environment.
51. The medium of claim 32 wherein the instructions further comprise: instructions for linking bi-directionally components in different views of the graphical modeling environment, the bi-directional linkage allowing a user to navigate from a first component in one view to a corresponding component in a second view.
52. The medium of claim 32 wherein the identified workflow is one or a combination of: a workflow converting a model from a floating point implementation to a fixed-point implementation, a workflow converting a model from one type of fixed point implementation to another type of fixed point implementation, a workflow converting a model from a continuous-time implementation to a discrete-time implementation, a workflow to optimize a model to enhance simulation performance, a workflow to configure a model for optimal code generation, a workflow for instrumenting a model for data logging, a data management workflow, a code generation workflow, a verification and validation workflow, a workflow calibrating against collected data, a workflow for validating the matching of model interfaces, a workflow to prepare a model for connecting with instrumentation hardware, a workflow to configure 'reconfϊgurable I/O', and a workflow to setup instruments.
53. The medium of claim 32 wherein the reconfiguring of the model environment further comprises reconfiguring one or more of: a block diagram editor, a data flow diagram editor, a text-based block inside a graphical diagram, a statechart, an entity flow diagram, a sequence diagram, a class diagram, a physical modeling view, and a data explorer view.
54. The medium of claim 32 wherein the reconfiguring of the model environment reconfigures one or a combination of : a spreadsheet view, a GUI, a tree view, a block, a state, a library, a user dialog, a signal, a dependency view, a text-based editor, an application environment, a system environment and a transition.
55. The medium of claim 32 wherein the identified workflow is a hierarchical task- based workflow.
56. The medium of claim 32 wherein the identified workflow is depicted using one of the group of: graphics and text.
57. The medium of claim 56 wherein the identified workflow is one of a flowchart and state chart.
58. The method of claim 32 wherein the identified workflow generates an artifact proving the completion of at least one task within the workflow.
59. The method of claim 32 wherein the instructions further comprise: instructions for synchronizing the workflow with the modeling environment.
60. In a graphical modeling environment, a method for managing workflows in a graphical modeling environment, comprising: means for receiving user input associated with an identified workflow; means for displaying information associated with the identified workflow based on the received user input; and means for reconfiguring at least a portion of a modeling environment in response to a user selection. '
PCT/US2007/011516 2006-05-12 2007-05-14 System and method for synchronized workflow management WO2007136602A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP07809076A EP2018612A2 (en) 2006-05-12 2007-05-14 System and method for synchronized workflow management

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/432,939 2006-05-12
US11/432,939 US8181150B2 (en) 2006-05-12 2006-05-12 System and method for synchronized workflow management

Publications (2)

Publication Number Publication Date
WO2007136602A2 true WO2007136602A2 (en) 2007-11-29
WO2007136602A3 WO2007136602A3 (en) 2008-07-17

Family

ID=38686545

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2007/011516 WO2007136602A2 (en) 2006-05-12 2007-05-14 System and method for synchronized workflow management

Country Status (3)

Country Link
US (3) US8181150B2 (en)
EP (1) EP2018612A2 (en)
WO (1) WO2007136602A2 (en)

Families Citing this family (99)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8104017B2 (en) * 2001-10-25 2012-01-24 The Mathworks, Inc. Traceability in a modeling environment
US8423975B1 (en) * 2004-05-05 2013-04-16 Gregory M. Scallon System performance simulator
US8201140B2 (en) * 2005-08-30 2012-06-12 The Mathworks, Inc. System and method for creating and using graphical object instances in a statechart environment
US20070226732A1 (en) * 2006-03-16 2007-09-27 Timekeeping Systems, Inc. Flow chart programmable data collector
US20080082390A1 (en) * 2006-10-02 2008-04-03 International Business Machines Corporation Methods for Generating Auxiliary Data Operations for a Role Based Personalized Business User Workplace
US7969452B2 (en) * 2007-01-31 2011-06-28 The Mathworks, Inc. Reporting fixed-point information for a graphical model
GB0702822D0 (en) * 2007-02-14 2007-03-28 Salamander Organization The Lt Organisation representational system
US8731998B2 (en) * 2007-03-01 2014-05-20 Sap Ag Three dimensional visual representation for identifying problems in monitored model oriented business processes
US9729843B1 (en) 2007-03-16 2017-08-08 The Mathworks, Inc. Enriched video for a technical computing environment
US8005812B1 (en) 2007-03-16 2011-08-23 The Mathworks, Inc. Collaborative modeling environment
US20090030918A1 (en) * 2007-07-26 2009-01-29 Ryma Technology Solutions Collaborative development method and system
US7788294B2 (en) * 2007-08-17 2010-08-31 Graywolf Sensing Solutions, Llc Method and system for collecting and analyzing environmental data
US20090138319A1 (en) * 2007-11-22 2009-05-28 Kiran Kumar Satya Srinivasa Ratnala Task registration methods and systems
US8458667B2 (en) * 2008-01-30 2013-06-04 National Instruments Corporation Debugging a statechart for a real time target
JP5194914B2 (en) 2008-03-18 2013-05-08 株式会社リコー Image processing apparatus, image processing apparatus display method and program
US20090319987A1 (en) * 2008-06-19 2009-12-24 Bartz Christopher T Automatic Fixed Point Code Generation
US20110276915A1 (en) * 2008-10-16 2011-11-10 The University Of Utah Research Foundation Automated development of data processing results
US8818961B1 (en) * 2009-10-30 2014-08-26 Symantec Corporation User restoration of workflow objects and elements from an archived database
CA2787185A1 (en) * 2010-01-19 2011-07-28 Whatsnexx Marketing Automation Inc. System and method for designing and executing subject-state engine workflows
US8484610B2 (en) 2010-03-17 2013-07-09 Microsoft Corporation Workflow execution model
US8316323B2 (en) * 2010-03-26 2012-11-20 Microsoft Corporation Breadcrumb navigation through heirarchical structures
US8793645B2 (en) 2010-04-02 2014-07-29 Microsoft Corporation Replacement of data element in a graph
US8468124B2 (en) * 2010-06-30 2013-06-18 International Business Machines Corporation Debugging workflows
US8782434B1 (en) 2010-07-15 2014-07-15 The Research Foundation For The State University Of New York System and method for validating program execution at run-time
US9177452B1 (en) * 2011-04-01 2015-11-03 The Mathworks, Inc. User interface for a modeling environment
US8661444B2 (en) * 2011-05-17 2014-02-25 International Business Machines Corporation Creation of flexible workflows using artifacts
US8954924B2 (en) * 2011-08-10 2015-02-10 Microsoft Technology Licensing, Llc Dynamic update of modularized programs in a continuation-based runtime
US9043744B2 (en) * 2011-09-07 2015-05-26 Mckesson Financial Holdings Converting existing artifacts to new artifacts
US8732568B1 (en) * 2011-09-15 2014-05-20 Symantec Corporation Systems and methods for managing workflows
US8862975B2 (en) * 2011-09-19 2014-10-14 Microsoft Corporation Web-based workflow service visualization and navigation
US9395959B2 (en) 2011-12-09 2016-07-19 Microsoft Technology Licensing, Llc Integrated workflow visualization and editing
US9210161B2 (en) * 2011-12-13 2015-12-08 Business Objects Software Limited Authentication certificates as source of contextual information in business intelligence processes
US20130159047A1 (en) * 2011-12-14 2013-06-20 Jochen Mayerle Dynamic business scenario key performance indicator definitions, real time calculations, and analysis
US9355375B2 (en) 2011-12-14 2016-05-31 Holger Knospe Launch of target user interface features based on specific business process instances
US9081472B2 (en) 2011-12-14 2015-07-14 Sap Se Dynamic enhancement of context matching rules for business scenario models
US9070097B2 (en) 2011-12-14 2015-06-30 Sap Se Seamless morphing from scenario model to system-based instance visualization
US9064220B2 (en) 2011-12-14 2015-06-23 Sap Se Linear visualization for overview, status display, and navigation along business scenario instances
US9286584B2 (en) 2011-12-14 2016-03-15 Sap Se Visualizing business processes or scenarios in a business software model using transit maps
US9009675B2 (en) * 2012-03-21 2015-04-14 International Business Machines Corporation Verification of complex workflows through internal assessment or community based assessment
US9122873B2 (en) 2012-09-14 2015-09-01 The Research Foundation For The State University Of New York Continuous run-time validation of program execution: a practical approach
US9069782B2 (en) 2012-10-01 2015-06-30 The Research Foundation For The State University Of New York System and method for security and privacy aware virtual machine checkpointing
US9852220B1 (en) * 2012-10-08 2017-12-26 Amazon Technologies, Inc. Distributed workflow management system
WO2014084820A1 (en) * 2012-11-28 2014-06-05 Hewlett-Packard Development Company, L.P. Regulating application task development
US9098291B1 (en) * 2012-12-04 2015-08-04 The Mathworks, Inc. Transforming modeling environment code/model into a non-modeling environment format
US9436442B1 (en) * 2012-12-05 2016-09-06 The Mathworks, Inc. Automatic floating-point to fixed-point conversion
US8806407B2 (en) 2012-12-31 2014-08-12 Synopsys, Inc. Multiple-instantiated-module (MIM) aware pin assignment
US8856234B2 (en) 2013-02-28 2014-10-07 Workiva Llc System and method for performing distributed asynchronous calculations in a networked environment
JP5472504B1 (en) * 2013-03-12 2014-04-16 富士ゼロックス株式会社 Work flow creation support apparatus and method, and program
US9235808B2 (en) 2013-03-14 2016-01-12 International Business Machines Corporation Evaluation of predictions in the absence of a known ground truth
US9401835B2 (en) 2013-03-15 2016-07-26 International Business Machines Corporation Data integration on retargetable engines in a networked environment
US9256460B2 (en) * 2013-03-15 2016-02-09 International Business Machines Corporation Selective checkpointing of links in a data flow based on a set of predefined criteria
US9323619B2 (en) 2013-03-15 2016-04-26 International Business Machines Corporation Deploying parallel data integration applications to distributed computing environments
JP6064734B2 (en) * 2013-03-27 2017-01-25 富士通株式会社 Workflow control program, apparatus and method
US20140316841A1 (en) * 2013-04-23 2014-10-23 Kofax, Inc. Location-based workflows and services
US9575732B2 (en) * 2013-06-17 2017-02-21 Microsoft Technology Licensing, Llc Providing design time projections for a visual program
US9477511B2 (en) 2013-08-14 2016-10-25 International Business Machines Corporation Task-based modeling for parallel data integration
CN105659242A (en) 2013-09-23 2016-06-08 慧与发展有限责任合伙企业 Workflow and user credentials
US9280319B2 (en) * 2013-10-18 2016-03-08 Microsoft Technology Licensing, Llc Integrated visualization for modeled customizations
US9529572B1 (en) 2013-12-20 2016-12-27 Emc Corporation Composable application session parameters
US10466872B1 (en) 2013-12-20 2019-11-05 Open Text Corporation Composable events for dynamic user interface composition
US9756147B1 (en) 2013-12-20 2017-09-05 Open Text Corporation Dynamic discovery and management of page fragments
US9851951B1 (en) 2013-12-20 2017-12-26 Emc Corporation Composable action flows
US9170786B1 (en) 2013-12-20 2015-10-27 Emc Corporation Composable context menus
US9912824B2 (en) 2014-02-10 2018-03-06 Xerox Corporation Triggering workflows from a multifunction device
EP2916183B1 (en) * 2014-03-06 2016-11-09 dSPACE digital signal processing and control engineering GmbH Method for generating a control program for a control system
US9946516B2 (en) 2014-03-14 2018-04-17 Starbucks Corporation Application workflow framework
US10592068B1 (en) * 2014-03-27 2020-03-17 Amazon Technologies, Inc. Graphic composer for service integration
US10747390B1 (en) 2014-03-27 2020-08-18 Amazon Technologies, Inc. Graphical composer for policy management
US10289524B2 (en) * 2014-06-06 2019-05-14 Accenture Global Services Limited Workflow test case generation
US9313230B1 (en) 2014-09-22 2016-04-12 Amazon Technologies, Inc. Policy approval layer
US9772822B2 (en) 2015-03-16 2017-09-26 Microsoft Technology Licensing, Llc Visualization framework for customizable types in a development environment
US10019238B2 (en) * 2015-06-23 2018-07-10 Open Text Sa Ulc Compositional entity modeling systems and methods
US10108321B2 (en) * 2015-08-31 2018-10-23 Microsoft Technology Licensing, Llc Interface for defining user directed partial graph execution
US10114636B2 (en) * 2016-04-20 2018-10-30 Microsoft Technology Licensing, Llc Production telemetry insights inline to developer experience
US10423393B2 (en) * 2016-04-28 2019-09-24 Microsoft Technology Licensing, Llc Intelligent flow designer
US20170322716A1 (en) 2016-05-04 2017-11-09 Open Text Sa Ulc Reusable entity modeling systems and methods
US10671800B2 (en) * 2016-09-15 2020-06-02 Oracle International Corporation Providing way to store process data object state as snapshots at different points of process
US10572237B2 (en) * 2016-12-12 2020-02-25 AT&T Intellectual Property I, I.P. Managing software changes to virtual network functions
US11004025B1 (en) * 2017-11-01 2021-05-11 EMC IP Holding Company LLC Simulation-based online optimization of workflows
US11614978B2 (en) * 2018-04-24 2023-03-28 EMC IP Holding Company LLC Deep reinforcement learning for workflow optimization using provenance-based simulation
US10732940B2 (en) 2018-04-27 2020-08-04 EMC IP Holding Company LLC Enterprise services framework for presentation layer management
US11263369B2 (en) * 2018-06-29 2022-03-01 EMC IP Holding Company LLC Workflow simulation using provenance data similarity and sequence alignment
US10908881B2 (en) * 2018-06-29 2021-02-02 Mastercard International Incorporated System and computer-implemented method for bidirectional translation between diagramming and implementation tools
US11119879B2 (en) * 2018-07-18 2021-09-14 EMC IP Holding Company LLC Detection of resource bottlenecks in execution of workflow tasks using provenance data
US20200278840A1 (en) * 2018-08-07 2020-09-03 Investcloud Inc Multi-question multi-answer configuration
US11119864B2 (en) * 2018-10-02 2021-09-14 International Business Machines Corporation Achieving activity centric computing using portable containers
US10740537B2 (en) * 2018-11-01 2020-08-11 Dell Products L.P. Enterprise form dependency visualization and management
US10747658B2 (en) * 2018-11-19 2020-08-18 Paypal, Inc. Systems and methods for testing online use-case scenarios in a staging environment
US10754626B2 (en) 2018-11-30 2020-08-25 Shopify Inc. Visual and code views in a process workflow user interface
US10958517B2 (en) 2019-02-15 2021-03-23 At&T Intellectual Property I, L.P. Conflict-free change deployment
CN110795406A (en) * 2019-09-30 2020-02-14 广州供电局有限公司 Service file transmission method, device, system and storage medium
EP3816740A1 (en) * 2019-10-28 2021-05-05 Siemens Aktiengesellschaft Method for virtual configuration of an automation system
US11282011B2 (en) * 2020-04-01 2022-03-22 Chevron U.S.A. Inc. Task management interface for well operations
US11115476B1 (en) * 2020-04-22 2021-09-07 Drb Systems, Llc System for and method of controlling operations of a car wash
US11743350B2 (en) 2021-01-07 2023-08-29 The Toronto-Dominion Bank System and method for integrating external services into process workflow environments
US11449312B2 (en) 2021-01-07 2022-09-20 The Toronto-Dominion Bank System and method for executing a process workflow
US11561827B2 (en) 2021-01-07 2023-01-24 The Toronto-Dominion Bank System and method for executing a dynamic routing service
US11928626B2 (en) 2021-01-07 2024-03-12 The Toronto-Dominion Bank System and method for persisting data generated in executing a process workflow
US20220237021A1 (en) * 2021-01-26 2022-07-28 Salesforce.Com, Inc. Systems and methods of telemetry diagnostics

Family Cites Families (90)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5442746A (en) 1992-08-28 1995-08-15 Hughes Aircraft Company Procedural user interface
JP2516317B2 (en) * 1992-10-13 1996-07-24 インターナショナル・ビジネス・マシーンズ・コーポレイション Data processing system and method for loading digital signal processor.
US5440740A (en) * 1992-10-13 1995-08-08 Chen; Fetchi System and method for managing devices on multiple digital signal processors
US5442789A (en) * 1994-03-31 1995-08-15 International Business Machines Corporation System and method for efficiently loading and removing selected functions on digital signal processors without interrupting execution of other functions on the digital signal processors
US5754179A (en) 1995-06-07 1998-05-19 International Business Machines Corporation Selection facilitation on a graphical interface
US6237020B1 (en) * 1996-10-01 2001-05-22 International Business Machines Corporation Task-oriented automatic distribution of software
DE19739559A1 (en) * 1997-09-09 1999-03-18 Traub Drehmaschinen Gmbh I L Process and system for creating or visualizing control data records
US6038393A (en) * 1997-09-22 2000-03-14 Unisys Corp. Software development tool to accept object modeling data from a wide variety of other vendors and filter the format into a format that is able to be stored in OMG compliant UML representation
US6470227B1 (en) * 1997-12-02 2002-10-22 Murali D. Rangachari Method and apparatus for automating a microelectric manufacturing process
US6286129B1 (en) * 1997-12-02 2001-09-04 Aspect Communications Method and apparatus for compiling transaction processing workflows
US6339838B1 (en) * 1998-01-02 2002-01-15 At&T Corp. Control of commercial processes
US6078982A (en) * 1998-03-24 2000-06-20 Hewlett-Packard Company Pre-locking scheme for allowing consistent and concurrent workflow process execution in a workflow management system
US6161051A (en) * 1998-05-08 2000-12-12 Rockwell Technologies, Llc System, method and article of manufacture for utilizing external models for enterprise wide control
US6397192B1 (en) * 1998-06-05 2002-05-28 I2 Technologies Us, Inc. Synchronizing one or more workflows using one or more synchronization-join activities that include synchronization logic
US6772407B1 (en) * 1998-10-02 2004-08-03 International Business Machines Corporation Staging objects in workflow management systems
US6507844B1 (en) * 1998-11-20 2003-01-14 International Business Machines Corporation Method and system for minimizing network traffic
US6499023B1 (en) * 1999-02-19 2002-12-24 Lucent Technologies Inc. Data item evaluation based on the combination of multiple factors
US7370325B1 (en) * 1999-02-19 2008-05-06 Lucent Technologies Inc. Eager evaluation of tasks in a workflow system
US7055098B2 (en) * 1999-02-19 2006-05-30 Lucent Technologies Inc. Dynamic display of data item evaluation
US6536037B1 (en) * 1999-05-27 2003-03-18 Accenture Llp Identification of redundancies and omissions among components of a web based architecture
US6473794B1 (en) * 1999-05-27 2002-10-29 Accenture Llp System for establishing plan to test components of web based framework by displaying pictorial representation and conveying indicia coded components of existing network framework
US6031747A (en) * 1999-08-02 2000-02-29 Lockheed Martin Missiles & Space Company Interleaved synchronous flyback converter with high efficiency over a wide operating load range
US6405364B1 (en) * 1999-08-31 2002-06-11 Accenture Llp Building techniques in a development architecture framework
US6636242B2 (en) * 1999-08-31 2003-10-21 Accenture Llp View configurer in a presentation services patterns environment
US6968536B2 (en) * 2000-07-14 2005-11-22 Borland Software Corporation Frame component container
WO2002019226A1 (en) * 2000-09-01 2002-03-07 Togethersoft Corporation Methods and systems for optimizing resource allocation based on data mined from plans created from a workflow
US6782379B2 (en) 2000-12-22 2004-08-24 Oblix, Inc. Preparing output XML based on selected programs and XML templates
US7937655B2 (en) * 2000-12-22 2011-05-03 Oracle International Corporation Workflows with associated processes
US20020128890A1 (en) 2000-12-26 2002-09-12 Appareon System, method and article of manufacture for workflow management of a supply chain system
US7174534B2 (en) * 2001-01-22 2007-02-06 Symbol Technologies, Inc. Efficient system and method for running and analyzing multi-channel, multi-modal applications
US7155681B2 (en) * 2001-02-14 2006-12-26 Sproqit Technologies, Inc. Platform-independent distributed user interface server architecture
US7240324B2 (en) * 2001-02-28 2007-07-03 Hewlett-Packard Development Company, L.P. Event-based scheduling method and system for workflow activities
US6889363B2 (en) * 2001-03-02 2005-05-03 The Arizona Board Of Regents On Behalf Of The University Of Arizona Interactive multimedia report viewer
US7614036B2 (en) * 2001-03-22 2009-11-03 Robert D Bjornson Method and system for dataflow creation and execution
US7499948B2 (en) * 2001-04-16 2009-03-03 Bea Systems, Inc. System and method for web-based personalization and ecommerce management
US20020194045A1 (en) * 2001-05-01 2002-12-19 Izhar Shay System and method for automatically allocating and de-allocating resources and services
US6973626B1 (en) * 2001-06-22 2005-12-06 I2 Technologies Us, Inc. Automatically generating graphical user interface elements at a client system according to a current configuration model
US6983421B1 (en) * 2001-06-22 2006-01-03 I2 Technologies Us, Inc. Using connectors to automatically update graphical user interface elements at a client system according to an updated state of a configuration
US7100147B2 (en) * 2001-06-28 2006-08-29 International Business Machines Corporation Method, system, and program for generating a workflow
CA2704080C (en) * 2001-07-26 2012-08-28 Irise System and process for cooperatively programming a simulation program of a computer application to be developed
US20030093471A1 (en) * 2001-10-18 2003-05-15 Mitch Upton System and method using asynchronous messaging for application integration
US8104017B2 (en) * 2001-10-25 2012-01-24 The Mathworks, Inc. Traceability in a modeling environment
US7685527B2 (en) * 2001-11-20 2010-03-23 Siebel Systems, Inc. Method and apparatus for controlling view navigation in workflow systems
US7020844B2 (en) * 2001-11-21 2006-03-28 General Electric Company Method and apparatus for managing workflow in prescribing and processing medical images
US7051036B2 (en) * 2001-12-03 2006-05-23 Kraft Foods Holdings, Inc. Computer-implemented system and method for project development
US7152229B2 (en) * 2002-01-18 2006-12-19 Symbol Technologies, Inc Workflow code generator
US7305656B2 (en) * 2002-02-14 2007-12-04 Hubbard & Wells Content management framework for use with a system for application development
US7653562B2 (en) * 2002-07-31 2010-01-26 Sap Aktiengesellschaft Workflow management architecture
US7506302B2 (en) * 2002-10-22 2009-03-17 The Boeing Company System and methods for business process modeling
CA2506555C (en) * 2002-11-08 2018-08-14 Arbitration Forums, Inc. A system and process for electronic subrogation, inter-organization workflow management, inter-organization transaction processing and optimized web-based user interaction
US7412658B2 (en) * 2002-11-14 2008-08-12 Sap Ag Modeling system for graphic user interface
US7272820B2 (en) 2002-12-12 2007-09-18 Extrapoles Pty Limited Graphical development of fully executable transactional workflow applications with adaptive high-performance capacity
US7610575B2 (en) * 2003-01-08 2009-10-27 Consona Crm Inc. System and method for the composition, generation, integration and execution of business processes over a network
US20060259524A1 (en) * 2003-03-17 2006-11-16 Horton D T Systems and methods for document project management, conversion, and filing
US7809545B2 (en) * 2003-04-16 2010-10-05 The Mathworks, Inc. System and method for using execution contexts in block diagram modeling
WO2004104728A2 (en) * 2003-05-19 2004-12-02 Sap Aktiengesellschaft Methods and systems for facilitating data processing workflow
US20040260593A1 (en) * 2003-05-20 2004-12-23 Klaus Abraham-Fuchs System and user interface supporting workflow operation improvement
US7240327B2 (en) * 2003-06-04 2007-07-03 Sap Ag Cross-platform development for devices with heterogeneous capabilities
WO2005017743A2 (en) * 2003-08-07 2005-02-24 National Instruments Corporation A graphical program which executes a timed loop
US7650589B2 (en) * 2003-08-15 2010-01-19 National Instruments Corporation Signal analysis function blocks and method of use
US20050044529A1 (en) * 2003-08-20 2005-02-24 Microsoft Corporation Task library of task data for a plurality of components on a computer system
CA2451164C (en) * 2003-09-11 2016-08-30 Teamplate Inc. Customizable components
US20070067373A1 (en) * 2003-11-03 2007-03-22 Steven Higgins Methods and apparatuses to provide mobile applications
US20070011334A1 (en) * 2003-11-03 2007-01-11 Steven Higgins Methods and apparatuses to provide composite applications
TWI221240B (en) * 2003-11-14 2004-09-21 Via Tech Inc Workflow defining system and workflow managing system
US7315791B2 (en) * 2004-02-18 2008-01-01 National Instruments Corporation Application programming interface for synchronizing multiple instrumentation devices
US7849440B1 (en) * 2004-04-16 2010-12-07 The Mathworks, Inc. Real-time code preview for a model based development process
US7539982B2 (en) 2004-05-07 2009-05-26 International Business Machines Corporation XML based scripting language
US7614037B2 (en) * 2004-05-21 2009-11-03 Microsoft Corporation Method and system for graph analysis and synchronization
US20060053172A1 (en) * 2004-09-03 2006-03-09 Biowisdom Limited System and method for creating, editing, and using multi-relational ontologies
US7974825B2 (en) * 2004-09-20 2011-07-05 The Mathworks, Inc. Generation of code from a graphical model
US7464366B2 (en) 2004-10-01 2008-12-09 Microsoft Corporation Programming interface for a componentized and extensible workflow model
US20060074735A1 (en) 2004-10-01 2006-04-06 Microsoft Corporation Ink-enabled workflow authoring
US7451432B2 (en) * 2004-10-01 2008-11-11 Microsoft Corporation Transformation of componentized and extensible workflow to a declarative format
US7565640B2 (en) * 2004-10-01 2009-07-21 Microsoft Corporation Framework for seamlessly authoring and editing workflows at design and runtime
US20060195817A1 (en) * 2005-02-28 2006-08-31 Microsoft Corporation Visual workflow modeling tools for user interface automation
US7657868B2 (en) * 2005-03-14 2010-02-02 Research In Motion Limited System and method for applying development patterns for component based applications
US7958454B2 (en) * 2005-04-19 2011-06-07 The Mathworks, Inc. Graphical state machine based programming for a graphical user interface
US20060293934A1 (en) * 2005-04-22 2006-12-28 Igor Tsyganskiy Methods and systems for providing an integrated business application configuration environment
US20060242194A1 (en) * 2005-04-22 2006-10-26 Igor Tsyganskiy Systems and methods for modeling and manipulating a table-driven business application in an object-oriented environment
US9774699B2 (en) * 2005-09-20 2017-09-26 The Mathworks, Inc. System and method for transforming graphical models
US7861217B2 (en) * 2005-12-30 2010-12-28 The Mathworks, Inc. Non-graphical model dependencies in graphical modeling environments
US7703071B2 (en) * 2006-04-13 2010-04-20 International Business Machines Corporation Method for modeling business transformation
US8234630B2 (en) * 2006-05-03 2012-07-31 The Mathworks, Inc. Calling an entity of a graphical model with a non-graphical entity and calling a non-graphical entity of a graphical model with a graphical entity
US7644390B2 (en) * 2006-08-14 2010-01-05 Payman Khodabandehloo Design tool and methodology for enterprise software applications
US20080134140A1 (en) * 2006-10-16 2008-06-05 Pharsight Corporation Integrated drug development software platform
US7934194B2 (en) * 2006-10-17 2011-04-26 The Mathworks, Inc. User-defined hierarchies of user-defined classes of graphical objects in a graphical modeling environment
US20090165021A1 (en) * 2007-10-23 2009-06-25 Microsoft Corporation Model-Based Composite Application Platform
EP2248013A4 (en) * 2007-12-20 2012-09-26 Hsbc Technologies Inc Automated methods and systems for developing and deploying projects in parallel
US8224931B1 (en) * 2010-03-31 2012-07-17 Amazon Technologies, Inc. Managing use of intermediate destination computing nodes for provided computer networks

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
None

Also Published As

Publication number Publication date
US8261233B2 (en) 2012-09-04
US20070266368A1 (en) 2007-11-15
US20120331444A1 (en) 2012-12-27
US8656352B2 (en) 2014-02-18
WO2007136602A3 (en) 2008-07-17
US8181150B2 (en) 2012-05-15
EP2018612A2 (en) 2009-01-28
US20090007063A1 (en) 2009-01-01

Similar Documents

Publication Publication Date Title
US8181150B2 (en) System and method for synchronized workflow management
US8856667B2 (en) Graphical state machine based programming for a graphical user interface
US9754059B2 (en) Graphical design verification environment generator
US8209663B2 (en) Dynamic generation of formatted user interfaces in software environments
US9952837B1 (en) Reusable component in a modeling environment
US8726233B1 (en) System and method of using an active link in a state programming environment to locate an element
US8701084B1 (en) Preview of auto-fix changes to software code
US20060136863A1 (en) Applying coding standards in graphical programming environments
US9176640B1 (en) Method of graphically linking multiple disjoint models
US20080235660A1 (en) Depicting Changes to Structures in an Integrated Development Environment
Campos et al. Supporting the analysis of safety critical user interfaces: an exploration of three formal tools
AU2014100798A4 (en) A visual role and transition based method and system for developing complex web applications
US8126961B2 (en) Integration of client and server development environments
US20220137959A1 (en) Detecting duplicated code patterns in visual programming language code instances
US10222944B1 (en) Embedding user interface elements in documents containing code
Vilhunen User interface test automation for an Android application
US11853690B1 (en) Systems and methods for highlighting graphical models
Fayollas et al. Supporting the analysis of safety critical user interfaces: An Exploration of Three Formal Tools
Wang Architecture-level risk assessment tool based on UML specification
Blouin Contribution to the Engineering of User Interfaces
Hauptmann Model-based test instantiation for applications with user interfaces
Cinar et al. Android Development Tools for Eclipse
Ralich EMC 2 On-the-Fly Configurations
Nami Elide: an interactive development environment for Erasmus language
Sparks A Systematic Approach to Debugging in the Blaise Environment: An Author's Perspective

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 2007809076

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: DE

121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 07809076

Country of ref document: EP

Kind code of ref document: A2