The present invention relates generally to computer software, computer program architecture, and software development techniques and applications. More specifically, techniques for requirements definition using interactive prototyping are described.
Conventional software development is traditionally performed using solutions that rely upon the development of functional requirements or specifications (hereafter “requirements”) in order to identify features or functions that should be built or developed into a computer program or application. In some conventional solutions, computer programs are developed “on-the-fly,” often developing requirements for features and functions on an ad hoc basis. In other conventional solutions, software development methodologies such as agile, waterfall, or iterative are used, developing requirements documents that are used by software development teams in software development projects.
Typically, requirements are often identified using input from departments or functions within an organization, such as marketing or sales. In some conventional software development projects, applications (i.e., software, computer programs, instructions, program code, executables, or the like) are constructed by defining requirements through user groups, focus groups, or surveys. Requirements are often developed by surveying users or intended customers for a software application under development. However, users and customers surveyed are often representative of business users or analysts who identify needs that are solved by software applications within an organization. Business users, analysts, users, and customers are typically not technically trained nor experienced in software development, which results in lengthy specification development processes that can add substantial amounts of time to a software development project during requirements gathering, specification writing, and testing phases.
Conventional solutions for requirements definition and use during a software development project are problematic. Time-consuming requirements definition and transformation of the requirements into functions or features planned for a software development project require time and expertise. The use of conventional software development solutions often take substantial amounts of time, particularly for the development, customization, or integration of a software program for a large-scale organization or enterprise to suit a specific need. Further, software development projects that require and use requirements such as marketing requirements documents, or functional requirement specifications typically require highly trained, experienced software development personnel, resulting in substantial increased costs for a software development project.
Thus, what is needed is a solution for defining software development project requirements without the limitations of conventional techniques.
Various embodiments or examples (“examples”) are disclosed in the following detailed description and the accompanying drawings:
Various embodiments or examples may be implemented in numerous ways, including as a system, a process, an apparatus, a user interface, or a series of program instructions on a computer readable medium such as a computer readable storage medium or a computer network where the program instructions are sent over optical, electronic, or wireless communication links. In general, operations of disclosed processes may be performed in an arbitrary order, unless otherwise provided in the claims.
A detailed description of one or more examples is provided below along with accompanying figures. The detailed description is provided in connection with such examples, but is not limited to any particular example. The scope is limited only by the claims and numerous alternatives, modifications, and equivalents are encompassed. Numerous specific details are set forth in the following description in order to provide a thorough understanding. These details are provided for the purpose of example and the described techniques may be practiced according to the claims without some or all of these specific details. For clarity, technical material that is known in the technical fields related to the examples has not been described in detail to avoid unnecessarily obscuring the description.
In some examples, the described techniques may be implemented as a computer program or application (“application”) or as a plug-in, module, or sub-component of another application. The described techniques may be implemented as software, hardware, firmware, circuitry, or a combination thereof If implemented as software, the described techniques may be implemented using various types of programming, development, scripting, or formatting languages, frameworks, syntax, applications, protocols, objects, or techniques, including ASP, ASP.net, .Net framework, Ruby, Ruby on Rails, C, Objective C, C++, C#, Adobe® Integrated Runtime™ (Adobe® AIR™), ActionScript™, Flex™, Lingo™, Java™, Javascript™, Ajax, Perl, COBOL, Fortran, ADA, XML, MXML, HTML, DHTML, XHTML, HTTP, XMPP, PHP, and others. Design, publishing, and other types of applications such as Dreamweaver®, Shockwave®, Flash®, Drupal and Fireworks® may also be used to implement the described techniques. The described techniques may be varied and are not limited to the examples or descriptions provided.
As described herein, computer software, programs, or applications (hereafter “applications”) may be developed with less time and expense, providing unskilled or inexperienced persons with the ability to identify and define functions, features, or other requirements (hereafter “requirements”) for an application using a web, distributed, downloadable, or standalone application to convert requirements into executable program code, thus reducing development time and costs. In some examples, the use of a client that is configured to handle (i.e., render, display, receive, or otherwise process) Flash®, HTML, XML, or other types of data formats in order to transmit data data to an application simulation server that may be implemented locally or on a remote computer (e.g., a server that is part of a data network (e.g., Internet, Local Area Network (LAN), Wide Area Network (WAN), Municipal Area Network (MAN), and others). As used herein, Flash® refers to an application developed by Adobe Systems, Incorporated of San Jose, Calif. Graphical indications and items (hereafter “items”) may be selected using a visual palette or window to define requirements for an application by using click-and-drag, drag-and-drop, or other user interfaces and interactive interface techniques to identify items desired for a given application. Once identified, items may be converted, translated, or otherwise transformed into executable program code (i.e., software program code that may be run on any computer using any type of operating system or environment, including Windows® as developed by Microsoft Corporation of Redmond, Wash., real-time operating systems (RTOS), or open source operating systems, without limitation) that may be used to construct, assemble, build, or otherwise develop (hereafter “develop) a software development project. Using local, test, or actual data, an application may be simulated or prototyped (hereafter “simulated” or “simulating”) by generating an application simulating from an application simulation server using executable program code, providing rapid requirements definition and development. While requirements definition may be performed on a client, an application simulation may be generated remotely and displayed on the client (i.e., on a monitor or display used with a computer instantiating the client). An application simulation, in some examples, may be an application constructed, assembled, developed, designed, implemented, created, or otherwise generated (hereafter “generated”) in order to develop an interactive prototype of an application that users may interact with during the requirements definition and coding processes of software development. Using the described techniques, rapid interactive prototyping may enable users to quickly identify requirements by selecting graphical icons that are representative of section or portions of computer program code (i.e., executable program code). As an example, when a user has completed graphically identifying (i.e., selecting graphical icons) executable program code, a remote server instance of an application simulation server may be used to generate a simulation of a computer program that is interactive when run. As described herein, an application simulation server may be implemented as hardware, software, circuitry, or a combination thereof and configured to perform the described techniques for application development and requirements definition using interactive prototyping. In other examples, the described techniques may be implemented differently and are not limited to the descriptions provided.
In some examples, communications module 208 may be configured to send and receive data from application 202. For example, application 202 may be implemented on one or more remote servers and, when a message (e.g., data packet) is received from a remote client over a data network (e.g., network 102 (FIG. 1)), communications module 208 receives, decodes, or otherwise interprets data from the message and transmits the data over bus 220 to content handling module 210, requirements definition module 218, and simulation module 214. Once interpreted (i.e., decoded, or otherwise processed for use by application 202), data is used to identify whether a specific graphical input has been received to indicate whether a given feature or function is to be included in an application that is being developed.
In other examples, drawing environment module 212 is configured to generate and present a drawing environment on a local or remote client, without limitation, in order to present one or more graphical user interfaces (hereafter “interface” or “interfaces”) for display at a client. As an example, an interface may be generated and presented by rendering engine 216 that allows a user, regardless of training, education, or experience, to select a graphical picture of a feature or function that she wishes to have implemented in a given application. If a table, for example, is selected, drawing environment module 212 receives that input, which is communication using communications module 208 to content handling module 210, which is configured to determine executable program code that is associated with the selected graphical input, item, or indication. In some examples, an input may be a graphical, visual, or iconic representation displayed on a computer screen that, when selected using an input/output device (e.g., mouse, keyboard, or others) indicates an item (e.g., data structure (e.g., table, record, file, queue, or others), function (e.g., pull down menu, pop-up window, or others), feature (e.g., radio button, text box, form, or others)) or type of item that should be included in an application. As shown, content handling module 210 may be used to interpret data and information entered in a drawing environment. Content handling module 210, in some examples, may be configured to interpret data and information entered, created, authored, formatted, modified, or otherwise operated upon using any type of protocol or format. For example, content handling module 210 may be configured to interpret data formatted using hypertext markup language (HTML), extensible markup language (XML), web services distributed language (WSDL), or others. Content handling module 210 may also be implemented to interpret data formatted or otherwise modified using various types of applications and frameworks, such as Flash®, Flex®, AIR™, Ruby on Rails®, or others that may be used to develop internet application or rich internet applications (RIA). Flash®, Flex®, and AIR™ are developed by Adobe Systems of San Jose, Calif. and Ruby on Rails® is an open source software project released by Yukihiro Matsumoto. In other examples, content handling module 210 may be configured to interpret, handle, read, transform, or otherwise process data formatted in other types of protocols, formats, scripts, or languages, without limitation.
As shown, repository 206 may be implemented as a single, multiple-instance, standalone, distributed, or other type of data storage facility, similar to those described above in connection with
In some examples, simulation module 214 may be used to generate application simulations using input provided within a drawing environment presented by drawing environment module 212. As used herein, “application simulation” may refer to the process of receiving a graphical input indicating a requirement for an application within a drawing environment presented on a client and, after receipt and processing of the input, identifying executable program code that is used to construct (i.e., develop) an application, thus reducing the time from identifying a requirement to development of associated executable program code. Application simulations may include other processes, routines, or functions apart from those described, but are generated in order for a user (e.g., business analyst, marketing personnel, salesperson, software developer, or other) to graphically identify a requirement for an application and, using application 202, run the associated executable program code (which may be compiled, uncompiled, in binary or other formats) in a simulation using test, local, remote, or other sources of data without requiring complete development, integration, and testing before runtime. In other words, application 202 and the above-described elements allow applications to be built using graphical inputs provided using an interface in order to design and construct an application and then run as a simulation for purposes of expeditious troubleshooting and testing at substantially reduced expense in both time and labor.
Here, application 202 may be configured to present interfaces having Flash®-formatted or embedded content. Providing input using an interface (not shown) that is configured to handle Flash®, HTML, XML, or other types of formatted or programmed content allows a user to graphically identify a feature or function that she wishes to include as part of an application. For example, by selecting an icon representing a table, a requirement is identified for a table within an application and, when selected, application 202 (i.e., requirements definition module 218 and simulation module 214) generates the associated executable program code and enables simulation of the run-time environment of the application, thus showing the table. When, for example, the table is shown, rendering engine 216 may be used to render the graphical appearance of the table and the resulting, simulated application. In other examples, application 202 and the above-described elements may be varied in design, function, configuration, implementation, instantiation, or other aspects and are not limited to the examples shown and described.
In some examples, requirements management server 322 may be implemented and used to manage, control, add, delete, or otherwise modify requirements associated with an application under development. For example, multiple items may be graphically selected using an interface (e.g., selecting a table, interactive icon, button, and controls) presented on the client. An interface configured to manage requirements may be the same or different than an interface presented on a client for identifying or defining requirements. Further, each of requirements definition module 318 and requirements management server 322 may be configured to generate, render, and present for display, interfaces associated with requirement definition and management, respectively. In other examples, requirements definition module 318 and requirements management server 322 may be implemented differently or modified from the descriptions provided, including using data provided at a client to feedback module 324.
Here, feedback module 324 may be implemented to provide feedback from clients (Le., users interacting with application 310 on one or more clients). In some examples, feedback may be graphically or visually presented (i.e., displayed) on a monitor or computer associated with a client. Further, data associated with feedback may be input to application 310 and stored on repository 314, the latter of which may be implemented using one or more storage facilities (e.g., databases, data marts, or other storage mechanisms such as those described above). Still further, data associated with any operation performed by application 310 or any of the described elements (e.g., simulation reviewer 312, repository 314, login module 316, requirements definition module 318, account module 320, requirements management server 322, feedback module 324, and reporting module 326).
In some examples, simulation reviewer 312 may be used to generate an application simulation using data from one or more of repository 314, login module 316, requirements definition module 318, account module 320, requirements management server 322, feedback module 324, and reporting module 326. When input is provided at a client, transformation of the input is performed at the client into data that is transmitted to application 310. Upon receipt at application 310, data is processed and used to identify requirements for an application. In some examples, requirements management server 322 may be configured to cooperatively process inputs from a client to determine whether an instruction has been received from the client to generate and run a simulation. In other examples, simulation reviewer 312 may also provide data regarding application simulations to reporting module 326, which may be configured to generate reports regarding scenarios, simulations, data sources, or any other aspects of an application simulation. Further, other modules beyond those shown and described may be included with application 310. For example, modules, components, or portions of functionality may be implemented with application 310 that provide project management, measurement, metrics reporting, analysis, business intelligence, demand management, or other features or functionality for use in the application lifecycle management (ALM) or other software development industries and sectors. In other examples, application 310 and the above-described elements may be varied in design, function, configuration, implementation, instantiation, or other aspects and are not limited to the examples shown and described.
In some examples, each of icons 416-432 may represent an application project being developed. Alternatively, one or more of icons 416-432 may also be representative of different types of projects, files, records, or data that may be configured for interaction in interface 402. Examples of interaction may include selecting, saving, opening, closing, deleting, or modifying the icon by using an input/output device to select one of icons 416-432. Further, when selected, data may be retrieved from a remote or networked server (e.g., server 110 (
When a project is selected, in some examples, a list of options may be presented in region 444, including “Scenarios,” “Simulations,” “Data,” “Images,” “Templates,” “Actors,” and others. Each of the listed options presented (i.e., displayed) in region 444 may have other features or functions that are invoked when selected. Further, when one of the listed options in region 444 is selected using an input/output mechanism, a graphical input is performed, assigning a scenario, simulation, data, image, template, actor, or other requirement to the application under development. Further, by selecting one of tabbed windows 460-464, additional information may be presented in region 446. In other examples, interface 402 and the above-described elements may be varied in design, function, configuration, implementation, instantiation, or other aspects and are not limited to the examples shown and described.
In some examples, expanding window 502 may be configured to present information associated with details of a given project, such as the project name for a given software development project (i.e., application under development). Expanding window 504 may be configured to present general information associated with a given application project. Here, expanding window 504 illustrates additional fields for entering general information associated with a given project, including a project name and description. In other examples, expanding window 504 may be configured to present information beyond that described here.
In some examples, when an option is performed, user input is converted into an item (i.e., one or more data packets) that is sent from a client to application 202 (
In other examples, if an input is detected from a client (604), the input is translated into an item (e.g., a message, signal, data, dataset, packet, group of data packets, or the like) that is received by a requirements simulation server (e.g., application 202 (
Here, after identifying executable program code corresponding to the input from the client, an application simulation may be generated (710). In some examples, an application simulation may be a compilation or aggregation of executable program code that a user has entered as input for requirements for an application under development. After generating an application simulation, a determination is made as to whether a further input is provided to run the application simulation (712). If further input indicating running or executing an application simulation is detected, then the process ends. In other examples, the above-described process may be implemented to await another input indicating whether to run the application simulation. In still other examples, the above-described process may also be implemented to await another input indicating a further requirement for the application (and application simulation). Alternatively, if an input indicating running an application simulation is detected, then the simulation is run (714). Subsequently, the above-described process ends. In further examples, the above-described process may be varied in design, processes, order, or other aspects and is not limited to the descriptions provided.
According to some examples, computer system 800 performs specific operations by processor 804 executing one or more sequences of one or more instructions stored in system memory 806. Such instructions may be read into system memory 806 from another computer readable medium, such as static storage device 808 or disk drive 810. In some examples, hard-wired circuitry may be used in place of or in combination with software instructions for implementation.
The term “computer readable medium” refers to any tangible medium that participates in providing instructions to processor 804 for execution. Such a medium may take many forms, including but not limited to, non-volatile media and volatile media. Non-volatile media includes, for example, optical or magnetic disks, such as disk drive 810. Volatile media includes dynamic memory, such as system memory 806.
Common forms of computer readable media includes, for example, floppy disk, flexible disk, hard disk, magnetic tape, any other magnetic medium, CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, any other memory chip or cartridge, or any other medium from which a computer can read.
Instructions may further be transmitted or received using a transmission medium. The term “transmission medium” may include any tangible or intangible medium that is capable of storing, encoding or carrying instructions for execution by the machine, and includes digital or analog communications signals or other intangible medium to facilitate communication of such instructions. Transmission media includes coaxial cables, copper wire, and fiber optics, including wires that comprise bus 802 for transmitting a computer data signal.
In some examples, execution of the sequences of instructions may be performed by a single computer system 800. According to some examples, two or more computer systems 800 coupled by communication link 820 (e.g., LAN, PSTN, or wireless network) may perform the sequence of instructions in coordination with one another. Computer system 800 may transmit and receive messages, data, and instructions, including program, i.e., application code, through communication link 820 and communication interface 812. Received program code may be executed by processor 804 as it is received, and/or stored in disk drive 810, or other non-volatile storage for later execution.
Although the foregoing examples have been described in some detail for purposes of clarity of understanding, the above-described inventive techniques are not limited to the details provided. There are many alternative ways of implementing the above-described invention techniques. The disclosed examples are illustrative and not restrictive.
This application is a U.S. nonprovisional patent application that claims the benefit of U.S. Provisional Patent Application No. 61/175,715, filed May 5, 2009 with Attorney Docket No. BOR-239P, and entitled “Requirements Definition Using Interactive Prototyping”, which is herein incorporated by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
61175715 | May 2009 | US |