US8789017B2 - System and method for using stream objects to perform stream processing in a text-based computing environment - Google Patents

System and method for using stream objects to perform stream processing in a text-based computing environment Download PDF

Info

Publication number
US8789017B2
US8789017B2 US13/561,818 US201213561818A US8789017B2 US 8789017 B2 US8789017 B2 US 8789017B2 US 201213561818 A US201213561818 A US 201213561818A US 8789017 B2 US8789017 B2 US 8789017B2
Authority
US
United States
Prior art keywords
data stream
data
processing class
instance
stream processing
Prior art date
Legal status (The legal status 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 status listed.)
Active
Application number
US13/561,818
Other versions
US20120291054A1 (en
Inventor
II Donald Paul Orofino
Michael James Longfritz
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
MathWorks Inc
Original Assignee
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 MathWorks Inc filed Critical MathWorks Inc
Priority to US13/561,818 priority Critical patent/US8789017B2/en
Assigned to THE MATHWORKS, INC. reassignment THE MATHWORKS, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: LONGFRITZ, MICHAEL JAMES, OROFINO, II, DONALD PAUL
Publication of US20120291054A1 publication Critical patent/US20120291054A1/en
Application granted granted Critical
Publication of US8789017B2 publication Critical patent/US8789017B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/448Execution paradigms, e.g. implementations of programming paradigms
    • G06F9/4488Object-oriented
    • G06F9/4493Object persistence

Definitions

  • Many stream processing systems are implemented using dataflow systems that may be modeled with a dataflow language, where the execution of a particular system component may be triggered by the availability of data as inputs to one or more system components.
  • the program or model may include model components represented as blocks with inputs and/or outputs.
  • the graphical program or model may also include arrows between the blocks, where the arrows are used to represent the flow of the input and output data.
  • Components in these program or model environments may be executed as soon as all of the inputs become valid depending upon how the development environment is implemented and the specific model of computation employed.
  • Graphical programming environments that support stream processing operations may include block libraries that contain blocks associated with code for stream processing algorithms.
  • the blocks provide a mechanism for programmers to add components to a model to handle the processing of stream data.
  • the addition of the stream processing blocks to the model in the graphical modeling environment enables the execution of the associated stream processing algorithm.
  • the stream processing algorithm creates a stream component with an internal state, calculates new output values using the state information and then updates the state information.
  • the combination operation may be the default operation and may be called without using a specific keyword, such as by invoking an operation call on an object using the object name.
  • Another embodiment of the invention may provide functionality for generating code from the stream-processing objects.
  • the generated code may be target platform specific, and/or may be generated based on specific target parameters.
  • the target may be real-time simulation, a specific hardware platform, a fixed-point emulation, etc.
  • FIG. 1 is a block diagram of a computing device environment suitable for practicing an exemplary embodiment
  • FIG. 5 is a flowchart of a sequence of steps that can be practiced in the exemplary embodiment of FIG. 1 to process stream data in a text-based computing environment and to forward the processed data to a graphical model component;
  • a “process” method may be included in the stream-processing object class definition, the process method performing both an update state and output operation.
  • the process method may be a functor—that is, the default method for the object.
  • the class definition 6 is used during the instantiation of at least one instance of the stream object class 12 in the text-based computing environment 4 .
  • exemplary types of stream objects can include stream objects such as, for example, filter objects and delay objects. Filter objects provide a filtering of the stream data being processed while delay objects may impose a delay in the stream being processed. It will be appreciated by one of skill in the art that many other types of objects operating on streams of data are within the scope of the present invention.
  • the stream object 12 allows a user to retain and update state information for one or more data streams 40 .
  • the data stream 40 may be, but is not limited to, video data, audio data, stock data, radio frequency sensor data, digitized transducer data, gene sequence data, test and measurement data, SQL query data, and/or RSS feed, In one implementation, the data stream 40 may include substantially any type of data with high throughput. In one implementation, the data stream 40 may be real-time data, pseudo real-time data and/or archived data.
  • the stream object 12 includes an internal state 14 and an update method 18 and an output method 20 .
  • the update method 18 updates the internal state of the stream object 12 .
  • the update method 18 may use one or more of the following: input values from the stream data, an internal state 14 of the stream object 12 , and object parameters.
  • the illustrative embodiment thus allows a user to get the benefit of state retention when working with streaming data without requiring that the user write code that determines how to update states based on outputs and/or to maintain states.
  • the output operation 20 may use at least one object parameter and/or the current internal state to calculate a new set of output values. Alternatively, the output operation 20 may also use current input values for calculating the new output values.
  • Exemplary object parameters include initial conditions, filter types, filter coefficients, delay length, algorithm modes, etc.
  • a copy of the calculated output value may be stored in an internal buffer 30 .
  • Algorithms that operate with stream data may call an output operation prior to calling an update operation or vice versa.
  • the stream object 12 may include an operation, 22 , that, upon being called, calls both the update and output operations, by, for example, calling first the output operation 20 and then calling the update operation 18 .
  • the update operation 18 and output operation 20 may be written so as to form part of the combined operation 22 or may be separate operations programmatically called by the combined operation 22 .
  • the combined operation 22 may be designated as a functor—that is, as a default method.
  • An example of an algorithm that may use separate update and output operations is a feedback loop with a delay (such as a one-pole IIR filter).
  • the feedback loop may be graphically depicted as shown in FIG. 3 .
  • Sample code for the IIR filter may be shown as:
  • the feedback loop may involve splitting the algorithm into two steps; otherwise, it may not be possible to resolve the feedback loop (i.e.: the delay block 68 may need the output from the sum block 67 , but the sum block 67 (indirectly) may need the output from the delay block 68 ).
  • the two steps are (i) calculating outputs, and then (ii) updating states.
  • the delay block 68 calculates its output based on its state.
  • the delay block 68 calculates its output using its initial state value. As depicted in FIG. 3 , the delay output is written to an output memory location via the output port 71 and passes through the gain block 69 .
  • each component that has state updates its state.
  • the delay block 68 stores the current output of the sum block 77 as its state to use as its output value 71 in the next iteration.
  • FIG. 4 is a flowchart of a sequence of steps followed by the illustrative embodiment of the present invention in using the API supported by an instantiated stream object to process stream data.
  • the sequence begins with the stream data being provided as input to the stream object (step 70 ).
  • the stream data may be a substantially continuous stream of data that a user is interested in processing. While the stream data may be processed in a serial datum by datum fashion, the illustrative embodiment is not limited to serial processing.
  • the stream data may also be stored in a buffer or other location upon arrival and assembled into data units, such as frames. Stream data may further be arranged, stored, and/or formatted in other ways to allow stream data to be processed as a group.
  • the output operation for the stream object that is supported by the API is then called in order to calculate new output values (step 72 ).
  • the output method uses the current internal state and/or object parameters of the stream object in the calculation of the new output value (and optionally the current input values).
  • the retention of state by the stream object allows more complex operations to be performed on the stream data as previous processing of the stream data can be used as a factor in calculating a new output value.
  • the state provides a memory (or history) of what has previously occurred and prevents the stream object from having to consider the new stream input data in a context that may lack historical information or parameters.
  • the output operation transmits the newly calculated output value to the destination indicated by the algorithm being executed (step 74 ).
  • the update operation is called (step 76 ).
  • the update operation may use at least one input value (from the stream data), the current internal state of the stream object and/or at least one object parameter in order to update the state of the stream object.
  • the new internal state may be stored (step 78 ).
  • the new internal state is stored in an internal buffer. This retention of state provides the ability to perform cumulative operations easily on the stream data where the previously processed data is a factor in the current processing of the stream data.
  • the instantiation of the stream object 12 may be triggered by the execution of an embedded text block located within a graphical model.
  • the embedded text block may be any block embedded within a graphical model that requires a call to a separate text-based computing environment in order to process the code in the block.
  • the execution of an Embedded MATLAB block located with a SIMULINK model may cause the instantiation of a stream object in a text-based computing environment to which stream data is then directed.
  • FIG. 6 depicts a sequence of steps that may be followed by an illustrative embodiment to execute an embedded text block. The sequence begins with the execution of a graphical model (step 90 ).
  • an embedded text block is encountered (step 92 ).
  • the processing of the embedded text block triggers a call to a text-based computing environment (step 94 ).
  • the embedded text block then executes in the text-based computing environment and instantiates a stream object 12 as discussed above to perform streaming operations (step 96 ).
  • FIG. 7 shows a graphical model of an audio flanger—a system that offsets signals from each other—which includes an embedded textual block.
  • the model includes a signal 100 containing a stream of audio data.
  • the model also includes a sine wave block 102 and constant block 112 which together provide input to a sum block 104 .
  • the sum block 104 provides its output as the delay value for an embedded textual block providing a variable fraction delay 112 .
  • the signal 100 is provided as input to the embedded textual block providing a variable fraction delay 112 .
  • the delayed output from the embedded textual block providing a variable fraction delay 112 is then added to a sum block 106 and combined with the non-delayed audio signal 100 .
  • the output of the sum block 100 is provided to a gain block 108 which then returns its output to the originating workspace 110 .
  • Execution of the embedded textual block may provide a variable fraction delay 112 that can cause the text-based computing environment to be called to execute the block.
  • the execution of the block instantiates an instance of the stream object class discussed above.
  • the stream object allows state information to be retained about the stream of audio data which in one implementation is being buffered and assembled into frames. The retention of the state information allows a desired amount of variable delay to be added to each frame and the calling of the stream object's update and output operations allows the state to be updated as necessary and the new output calculated respectively.
  • the embedded textual block providing a variable fraction delay 112 code being processed in the text-based computing environment may be represented as:
  • % Accepting default values for unspecified parameters in constructor calls % In particular, inputs default to be interpreted as frame-based columns load music_signal; % loads audio input x_afxf, sample rate Fs, etc.
  • sineGen dspSineGen(‘Freq’,0.25, ‘phase’,pi/4, ... ‘SampleRate’, Fs, ‘FrameSize’,128 );
  • varDelay dspVariableDelay(‘MaxDelay’,100, ...
  • the code can be generated based on parameters such as, but not limited to, whether it should be fixed-point or floating-point, whether memory usage should be minimized, whether debugging, profiling, and other instrumentation code should be included, whether function parameters should be stored locally or made available globally, whether functions should be reused wherever possible, whether argument lists to functions should be flat or are allowed to be structured.
  • TLC Target Language Compiler
  • Exemplary embodiments 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 Programmable ROM (PROM), a Magnetic RAM (MRAM), a Random Access Memory (RAM), a Read Only Memory (ROM), a magnetic tape, etc.
  • PROM Programmable ROM
  • MRAM Magnetic RAM
  • RAM Random Access Memory
  • ROM Read Only Memory
  • the computer-readable programs may be implemented in substantially any programming language. Examples of languages that can be used include but are not limited to, MATLAB language, FORTRAN, C, C++, C#, Python, JavaScript, Java, etc.
  • Examples of graphical programming environments include, but are not limited to, Simulink, LabView, Hyperception, Signal Processing Designer, VisualSim, SCADE, etc.
  • 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 Field Programmable Gate Array (FPGA), an Application Specific Instruction set Processor (ASIP), an Application Specific Integrated Circuit (ASIC), etc.
  • FPGA Field Programmable Gate Array
  • ASIP Application Specific Instruction set Processor
  • ASIC Application Specific Integrated Circuit
  • 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 and multiple processors having two or more cores may be implemented on the same chip.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

A mechanism for using stream objects in stream processing operations is provided. A definition of a class of stream objects used in stream processing algorithms can define output and update operations included in instances of the stream objects and the API (application programming interface) through which they may be called. The class definition may further include the type of state information to be held by the instantiated stream objects. An instance of the stream object may be instantiated in a text-based computing environment and the operations may be used to process streams of data.

Description

RELATED APPLICATION INFORMATION
This application is a continuation of U.S. patent application Ser. No. 11/519,255, filed Sep. 11, 2006 (now U.S. Pat. No. 8,234,623, issued Jul. 31, 2012), the entire content of which are incorporated by reference herein.
BACKGROUND
Many computational systems are designed, implemented, and deployed using a programming environment so as to operate on streaming data. The processing of data streams, such as audio data, video data, stock data, radio frequency data, digitized transducer outputs, test and measurement data, SQL query data, gene sequence data, etc., has taken on increasing importance as development environments attempt to simulate or model systems dependent upon streaming data, such as high throughput or time-critical processing systems.
Stream-based processing may be defined as a processing of data samples arriving sequentially over a period of time. A data sample may be scalar in nature, that is, a single data element. It may also be a vector, a matrix, a higher-dimensional regular array of data elements, etc. A data sample may also be irregular or non-uniform in structure, depending upon the nature of the intended application. Continuous-time data may be sampled discretely in time to produce a sampled sequence of streaming data. The sequence of data samples over time may have periodic sampling (that is, uniformly sampled over time) or may be aperiodic with respect to the sampling interval. The duration of a data stream may be finite in time with short duration, or having a sufficiently long duration so as to be considered infinite in practice for a given application. The stream-processing system may therefore be designed to handle an infinite stream of data as a design requirement.
Streaming operations may also require the collection and processing of buffered sub-sequences of data in the data stream, the buffered data being referred to as a data buffer, a batch, or a data frame. A data frame may represent a finite time interval, and the processing of an infinite sequence of data frames may be a requirement of the stream processing system. Data may therefore be input to a stream processing system as individual samples or as frames of data samples. A data sample may include one or more data elements relating to the data at a particular time point.
Different models of computation may be employed by the programming and/or modeling environment being utilized. A modeling environment may be either textual or graphical in nature, and each model of computation may impose certain design restrictions and semantic constraints. Dataflow is an example of one family of models of computation. Specific members of the dataflow family may include dynamic dataflow, synchronous dataflow, boolean dataflow, and the like. A particular dataflow model of computation may impose some restriction on the types of computational semantics that can be modeled and implemented by the system, such as, for example, forbidding feedback, recursion, different mixtures of sample rates, different mixtures of consumption and production rates of the computational process, different mixtures of frame sizes, etc. A dataflow model may also offer certain capabilities to the model designer and/or user, such as, for example, providing higher data throughput, deterministic performance, or greater expressivity in terms of modeling semantics.
Many stream processing systems are implemented using dataflow systems that may be modeled with a dataflow language, where the execution of a particular system component may be triggered by the availability of data as inputs to one or more system components.
For example, in a graphical programming language that implements a dataflow-based stream processing system, the program or model may include model components represented as blocks with inputs and/or outputs. The graphical program or model may also include arrows between the blocks, where the arrows are used to represent the flow of the input and output data. Components in these program or model environments may be executed as soon as all of the inputs become valid depending upon how the development environment is implemented and the specific model of computation employed.
Graphical programming environments that support stream processing operations may include block libraries that contain blocks associated with code for stream processing algorithms. The blocks provide a mechanism for programmers to add components to a model to handle the processing of stream data. The addition of the stream processing blocks to the model in the graphical modeling environment enables the execution of the associated stream processing algorithm. The stream processing algorithm creates a stream component with an internal state, calculates new output values using the state information and then updates the state information.
The semantic constraints and performance limitations imposed by the choice of a dataflow model of computation may limit the applicability of current design tools to the design of practical stream processing systems in text-based computing environments.
BRIEF SUMMARY
One embodiment of the present invention is directed to providing objects in a text-based programming language for performing operations on data, such as, for example, stream data. An object may be defined by an object definition (also referred herein as a “class”). The object definition may include a definition of object operations (also referred herein as “methods”) and one or more variables representing a state of an object.
In one embodiment of the invention, the operations of the stream-processing objects may include an update operation and/or an output operation. The update operation updates the state of an object, without producing an output. The output operation produces one or more output data samples and may optionally use state information and inputs to calculate the outputs. The output operation (which may be the default operation of the object) and update operation may also optionally use one or more of the input data samples and/or one or more object parameters.
The class definition may also include a combination operation. The combination operation may combine the functionality of the update operation and the output operation. The combination operation may be a default operation for the object. The default operation is an operation that is performed if a name of an operation is not indicated when calling a method of an object.
The operations as defined above constitute a model of computation when expressed in a textual programming environment, such as an object-oriented implementation in MATLAB®. This model of computation offers advantages applied to the design of stream processing systems, such as expressing feedback systems, certain mixtures of sample rates, certain mixtures of consumption and production rates of the computational process, certain mixtures of frame sizes, etc.
One embodiment of the invention provides an API (Application Programming Interface) for processing of data by instances of the defined objects. For example, the output operation may be called using a syntax including at least an object name and an “output” keyword, and the update operation may be called using a syntax including at least the object name and an “update” keyword. The combination operation may be called using a syntax including the object name and a “process” keyword.
Alternatively, the combination operation may be the default operation and may be called without using a specific keyword, such as by invoking an operation call on an object using the object name.
One embodiment of the invention may provide objects capable of polymorphic processing, that is, of processing variables of different specifications, such as for example, both fixed point and floating point values, sample-based and frame-based values, real and complex values, sample-time and single- and multiple-dimension values.
Another embodiment of the invention may provide functionality for generating code from the stream-processing objects. The generated code may be target platform specific, and/or may be generated based on specific target parameters. The target may be real-time simulation, a specific hardware platform, a fixed-point emulation, etc.
The object definition of one embodiment of the invention may be written in an array based programming language. In another embodiment of the invention, the object definition may be written in a dynamically typed programming language. In yet another embodiment of the invention, the object definition may be written in a language compatible with the MATLAB modeling environment and/or SIMULINK modeling environment.
It will be apparent to one of skill in the art that the object definitions and/or objects instantiated from the object definitions may be used both from within a textual environment and a graphical programming and/or modeling environment, or a combination of the above. The input and/or output data may be communicated from/to either graphical or textual modeling environments.
BRIEF DESCRIPTION OF THE DRAWINGS
The invention is pointed out with particularity in the appended claims. The advantages of the invention may be better understood by reference to the following description taken in conjunction with the accompanying drawings, in which:
FIG. 1 is a block diagram of a computing device environment suitable for practicing an exemplary embodiment;
FIG. 2 is a flowchart of a sequence of steps that can be implemented via the exemplary embodiments of FIG. 1 to process stream data;
FIG. 3 depicts a feedback loop;
FIG. 4 is flowchart of a sequence of steps that can be practiced in the exemplary embodiment of FIG. 1 using the stream object's API to process stream data;
FIG. 5 is a flowchart of a sequence of steps that can be practiced in the exemplary embodiment of FIG. 1 to process stream data in a text-based computing environment and to forward the processed data to a graphical model component;
FIG. 6 is a flowchart of a sequence of steps that can be practiced in the exemplary embodiment of FIG. 1 to process stream data using an embedded text block in a graphical model;
FIG. 7 shows a graphical model of an audio flanger that includes an embedded textual block in the model; and
FIG. 8 is a flowchart of a sequence of steps that can be practiced in the exemplary embodiment of FIG. 1 to generate code using a stream object.
DETAILED DESCRIPTION
An illustrative embodiment of the present invention provides a mechanism for handling stream processing operations in text-based computing environments. While a stream processing algorithm may be implemented in the graphical programming environment via a block library, it may be difficult to implement a corresponding stream processing algorithm in a text-based computing environment. A definition of a class of objects used in stream processing algorithms may include output and/or update methods, which may be used in instances of the stream-processing object class. The class definition also defines the API through which the operations may be called. Additionally, the class definition defines the type of internal state information maintained by the instances of the stream object class. In short, a class definition specifies at least one method (also referred to as “operations” herein) and state-holding variables of the objects instantiated from the class. As will be understood by one of skill in the art of object-oriented programming, a class of stream-processing objects may be a base class or a class inherited from a base class and/or any intervening parent classes. Users of the system in one embodiment of the invention may be enabled to create their own classes, inheriting from one or more predefined stream-processing object classes.
Methods provided in the predefined object classes of one embodiment of the invention, include at least an “output” method (also referred to as an output operation) and an “update” method (also referred to as an update operation). The output operation produces new output values, such as, for example, output values based on processing one or more stream values. The update operation updates the state of the instantiated stream-processing object (also referred herein as a “stream object” or “instance of a stream object class”) based in part on stream input values. The update operation need not produce output values.
A “process” method may be included in the stream-processing object class definition, the process method performing both an update state and output operation.
In one embodiment of the invention, the process method may be a functor—that is, the default method for the object.
The stream processing objects may be instantiated in the textual or graphical environments or in combinations thereof.
FIG. 1 depicts an environment suitable for practicing an illustrative embodiment of the present invention. A computing device 2 hosts a text-based computing environment 4. The computing device 2 may be a server, workstation, laptop, personal computer, PDA or other computing device equipped with one or more processors and able to host the text-based computing environment 4. The text-based computing environment 4 may support dynamically typed programming languages. The text-based computing environment may also support array-based programming languages. The text-based computing environment 4 may be any computing environment that allows processing of textually represented source code.
Exemplary text-based computing environments include MATLAB from The MathWorks, Inc. of Natick, Mass. and the LABVIEW MATHSCRIPT environment from National Instruments, Inc. of Austin, Tex.
Additionally, as used herein, the term “text-based computing” specifically encompasses the processing of embedded textual blocks within graphical programming environments. For example, the processing of an embedded MATLAB block within a model in a SIMULINK modeling environment would be considered to be taking place within a text-based computing environment 4 (SIMULINK modeling environment may call MATLAB computing environment upon encountering the embedded MATLAB block, the processing of the embedded MATLAB block may take place in MATLAB computing environment, and the results may be returned to the component in the SIMULINK environment). The text-based computing environment 4 includes a class definition for stream objects 6. The class definition for stream objects 6 defines the type of state information 8 to be maintained by the stream objects and an API 10 for the stream object. The API 10 provides the interface through which the operations in the stream objects may be called. The API 10 enables the calling of an update and output operation and may allow the calling of other operations of the stream object to be called.
The class definition 6 is used during the instantiation of at least one instance of the stream object class 12 in the text-based computing environment 4. Exemplary types of stream objects can include stream objects such as, for example, filter objects and delay objects. Filter objects provide a filtering of the stream data being processed while delay objects may impose a delay in the stream being processed. It will be appreciated by one of skill in the art that many other types of objects operating on streams of data are within the scope of the present invention. The stream object 12 allows a user to retain and update state information for one or more data streams 40. The data stream 40 may be, but is not limited to, video data, audio data, stock data, radio frequency sensor data, digitized transducer data, gene sequence data, test and measurement data, SQL query data, and/or RSS feed, In one implementation, the data stream 40 may include substantially any type of data with high throughput. In one implementation, the data stream 40 may be real-time data, pseudo real-time data and/or archived data.
The stream object 12 includes an internal state 14 and an update method 18 and an output method 20. The update method 18 updates the internal state of the stream object 12. In updating the internal state of the object, the update method 18 may use one or more of the following: input values from the stream data, an internal state 14 of the stream object 12, and object parameters. The illustrative embodiment thus allows a user to get the benefit of state retention when working with streaming data without requiring that the user write code that determines how to update states based on outputs and/or to maintain states. The output operation 20 may use at least one object parameter and/or the current internal state to calculate a new set of output values. Alternatively, the output operation 20 may also use current input values for calculating the new output values. Exemplary object parameters include initial conditions, filter types, filter coefficients, delay length, algorithm modes, etc. A copy of the calculated output value may be stored in an internal buffer 30.
Algorithms that operate with stream data may call an output operation prior to calling an update operation or vice versa. In one embodiment of the invention, the stream object 12 may include an operation, 22, that, upon being called, calls both the update and output operations, by, for example, calling first the output operation 20 and then calling the update operation 18. It will be appreciated that the update operation 18 and output operation 20 may be written so as to form part of the combined operation 22 or may be separate operations programmatically called by the combined operation 22. In some embodiments of the invention, the combined operation 22 may be designated as a functor—that is, as a default method. In calling the combined operation 22, the users may then omit the explicit method name in a method call and refer only to the object name, and the system of one embodiment of the invention will understand that syntax to refer to the method call to the default combined operation 22. The combined operation 22 may be referred to as the “process” method, or operation, in the API 10. The output and update operations may also be designated the default method, instead of the process method.
Additional operations that may be defined by the API 10 and implemented by the stream object 12 include a reset operation 24, a terminate operation 26 and a retrieve outputs operation 28. The reset operation 24 may reset an object's internal state 14 back to an initial and/or other default value. For example, a filter object might reset its state to its initial condition (which may be specified as an object parameter). Similarly, a file reader may reset its index back to the beginning of a file and an object calculating a running mean may reset its internal running sum to zero. Upon being called, the terminate operation 26 may release resources that are associated with the stream object 12. Exemplary resources that may be released by the terminate operation 26 can include allocated memory, file handles and hardware connections. Calling the terminate operation indicates that processing has completed. Any allocated resources can be released. The retrieve output operation 28 retrieves the last previously calculated output value. In one embodiment of the invention, the last previously calculated output value is retrieved from an internal buffer 30.
The computing device 2 may also support a graphical modeling environment 50 that includes a graphical model 52. Alternatively, the graphical modeling environment may be located on a separate computing device accessible to the computing device 2. Exemplary graphical modeling environments can include, among other things, SIMULINK and STATEFLOW, both from The MathWorks, Inc. Following the processing of the data stream 40, the resulting output may be transmitted as input to a component in the graphical model 52. For example, the output from a stream object in code being executed in MATLAB may be directed as input for a block diagram component in a block diagram model being executed in SIMULINK. It should be appreciated that the update and output operations may also be invoked remotely through Remote Procedure Call (RCP) or Remote Method Invocation (RMI) mechanisms.
FIG. 2 is a flowchart of the overall sequence of steps followed by the illustrative embodiment to process stream data. The sequence may begin by providing a class definition for the stream object that includes the definition of state information 8 and an API 10 that allows the calling of the stream object's output and update operations (step 60). The class definition is configurable by a user. Code being executed in a text-based computing environment instantiates the stream object based on the class definition (step 62). A stream of data is subsequently provided as input to the stream object (step 64), which proceeds to execute its output and update operations to process the stream data (step 66).
An example of an algorithm that may use separate update and output operations is a feedback loop with a delay (such as a one-pole IIR filter). The feedback loop may be graphically depicted as shown in FIG. 3.
Sample code for the IIR filter may be shown as:
% construct objects using ‘package.classname’ syntax
% pick a wave (audio) file for input and output
delay = splib.delay;
gain = splib.gain;
sum = splib.sum;
input = splib.fromwavefile;
output = splib.towavefile;
%# setup objects; default values are good for most parameters
gain.Value = 0.5;
% start processing the file
while (~input.done)
 % calculate outputs
 out = delay.output;
 towavefile.process(out); % towavefile is a sink, no outputs
 out = gain. process (out);
 in = fromwavefile. process; %fromwavefile is a source, no inputs
 out = sum. process (in, out);
 % update states
 delay.update(out);
end
The feedback loop may involve splitting the algorithm into two steps; otherwise, it may not be possible to resolve the feedback loop (i.e.: the delay block 68 may need the output from the sum block 67, but the sum block 67 (indirectly) may need the output from the delay block 68). The two steps are (i) calculating outputs, and then (ii) updating states. In the output step, the delay block 68 calculates its output based on its state. In the first iteration, the delay block 68 calculates its output using its initial state value. As depicted in FIG. 3, the delay output is written to an output memory location via the output port 71 and passes through the gain block 69. The gain output 73 and the input block output 75 would be added together to create the sum block output value 77. In the update step, each component that has state (only the delay, in this case) updates its state. The delay block 68 stores the current output of the sum block 77 as its state to use as its output value 71 in the next iteration.
As noted above, in one implementation a combined operation 22 (referred to below and in the sample code above as a process operation) may be used in place of separate explicit calls to the output and update methods. Thus, in place of separately calling:
  • out=object.output(in);
  • object.update(in);
    for every object in every loop, the combined operation allows the following call to be made:
  • out=object.process(in);
    The process operation will make a call to the output operation, and then a call to the update operation. In the sample code (above) for the IIR filter example, the delay object uses output and update separately, while all of the other objects use the combined operation ‘process’ call. The use of the combined operation provides a more efficient mechanism for outputting data from the stream object 12 and updating the internal state of the stream object.
FIG. 4 is a flowchart of a sequence of steps followed by the illustrative embodiment of the present invention in using the API supported by an instantiated stream object to process stream data. The sequence begins with the stream data being provided as input to the stream object (step 70). As noted above, the stream data may be a substantially continuous stream of data that a user is interested in processing. While the stream data may be processed in a serial datum by datum fashion, the illustrative embodiment is not limited to serial processing. The stream data may also be stored in a buffer or other location upon arrival and assembled into data units, such as frames. Stream data may further be arranged, stored, and/or formatted in other ways to allow stream data to be processed as a group. The output operation for the stream object that is supported by the API is then called in order to calculate new output values (step 72). The output method uses the current internal state and/or object parameters of the stream object in the calculation of the new output value (and optionally the current input values). The retention of state by the stream object allows more complex operations to be performed on the stream data as previous processing of the stream data can be used as a factor in calculating a new output value. Put another way, the state provides a memory (or history) of what has previously occurred and prevents the stream object from having to consider the new stream input data in a context that may lack historical information or parameters. The output operation transmits the newly calculated output value to the destination indicated by the algorithm being executed (step 74). After the calculation and transmittal of the new output value, the update operation is called (step 76). In one implementation, the update operation may use at least one input value (from the stream data), the current internal state of the stream object and/or at least one object parameter in order to update the state of the stream object. Once updated, the new internal state may be stored (step 78). In one implementation, the new internal state is stored in an internal buffer. This retention of state provides the ability to perform cumulative operations easily on the stream data where the previously processed data is a factor in the current processing of the stream data.
Once calculated, the output values may be provided as input values to components in other environments that are performing additional processing. FIG. 5 is a flowchart of a sequence of steps that can be followed by an illustrative embodiment of the present invention to process stream data in a text-based computing environment and to forward the processed data to a graphical model component. The sequence begins with the stream data being provided as input to the stream object (step 80). The input may be provided from either the textual or the graphical environments or the combination of the above. The algorithm being executed in the text-based computing environment may call a combination operation to calculate output and update state information (step 82). The calculated output is sent to a graphical model component (step 84) which executes using the output data processed by the stream object in the text-based computing environment as input data (step 86). In one implementation, the graphical model component may be in a data flow diagram or in a block diagram model.
In one exemplary implementation, the instantiation of the stream object 12 may be triggered by the execution of an embedded text block located within a graphical model. The embedded text block may be any block embedded within a graphical model that requires a call to a separate text-based computing environment in order to process the code in the block. For example, the execution of an Embedded MATLAB block located with a SIMULINK model may cause the instantiation of a stream object in a text-based computing environment to which stream data is then directed. FIG. 6 depicts a sequence of steps that may be followed by an illustrative embodiment to execute an embedded text block. The sequence begins with the execution of a graphical model (step 90). During the processing of the execution list for the graphical model, an embedded text block is encountered (step 92). The processing of the embedded text block triggers a call to a text-based computing environment (step 94). The embedded text block then executes in the text-based computing environment and instantiates a stream object 12 as discussed above to perform streaming operations (step 96).
In another aspect of the invention, the API 10 may support the use of ‘functor’ notation for a default operation. The support of the functor notation by the API 10 allows the use of an object as a function—that is, using the name of the variable that holds that object as a function call as illustrated below:
Original:
    • in=[1:5]′; % create an input signal
    • acf=splib.autocorrelation; % create an autocorrelation stream component
    • out=acf.process(in); % process the input to get the output
      Functor:
    • in=[1:5]′; % create an input signal
    • acf=splib.autocorrelation; % create an autocorrelation stream component
    • out=acf(in); % process the input to get the output
      Instead of explicitly calling the process operation as shown by the statement ‘out=acf.process(in)’, it is implicitly called by using the variable (acf) as a function as shown in the statement ‘out=acf(in)’. In complicated algorithms, this shorthand notation may improve readability of the algorithm. In one implementation of the present invention, this approach may be used to call the combination (process) operation 22.
The processing of an embedded textual block within a graphical modeling environment is further discussed with reference to FIG. 7. FIG. 7 shows a graphical model of an audio flanger—a system that offsets signals from each other—which includes an embedded textual block. The model includes a signal 100 containing a stream of audio data. The model also includes a sine wave block 102 and constant block 112 which together provide input to a sum block 104. The sum block 104 provides its output as the delay value for an embedded textual block providing a variable fraction delay 112. The signal 100 is provided as input to the embedded textual block providing a variable fraction delay 112. The delayed output from the embedded textual block providing a variable fraction delay 112 is then added to a sum block 106 and combined with the non-delayed audio signal 100. The output of the sum block 100 is provided to a gain block 108 which then returns its output to the originating workspace 110.
Execution of the embedded textual block may provide a variable fraction delay 112 that can cause the text-based computing environment to be called to execute the block. The execution of the block instantiates an instance of the stream object class discussed above. The stream object allows state information to be retained about the stream of audio data which in one implementation is being buffered and assembled into frames. The retention of the state information allows a desired amount of variable delay to be added to each frame and the calling of the stream object's update and output operations allows the state to be updated as necessary and the new output calculated respectively.
The embedded textual block providing a variable fraction delay 112 code being processed in the text-based computing environment may be represented as:
% Accepting default values for unspecified parameters in constructor calls
% In particular, inputs default to be interpreted as frame-based columns
load music_signal;     % loads audio input x_afxf, sample rate Fs,
    etc.
sineGen = dspSineGen(‘Freq’,0.25, ‘phase’,pi/4, ...
          ‘SampleRate’, Fs, ‘FrameSize’,128 );
varDelay = dspVariableDelay(‘MaxDelay’,100, ...
             ‘method’,‘FIR’, ‘Filter’, intfilt(8,10,0.5));
audioSrc = dspBufferedInput(‘Data’,x_afxf, ‘SampleRate’, Fs,
‘FrameSize’,128);
audioSink = dspBufferedOutput(‘Data’, ‘y_afxf’);
while( ~done ( audioSrc )),  % there exists a ‘done’ method...
 signalIn = output( audioSrc );  % invoke ‘output’ method on AudioIn
 delay = 20 + output(sineGen); % compute next output from sine
generator
 signalOut = 0.5 * ( signalIn + output(varDelay, delay, signalIn) );
 update( audioSnk, signalOut ); % invoke ‘update’ method on AudioOut
end
sound(y_afxf, Fs);  % play result when simulation finishes

High-Level M
% This simulation cannot be manipulated to execute as a
% sequence of single simulation steps on “all the data” for each operation
%
% The signal must be explicitly split into frames so that the variable delay
% can properly execute separately on each frame
load music_signal;      % loads audio input x_afxf, sample
     rate Fs, etc.
frame_size = 128;
dlyFilt = intfilt(8,10,0.5);  % pre-compute the interpolation filter
varDelayState = VarDelayInit; % initial state info for variable fractional
delay
% Slice data into frames, all at once, one frame per column.
%
% simulation initialization step:
all_input_data = buffer(x_afxf, 128);
for i=1:size(all_input_data,2),  % loop over each frame
 sigIn = all_input_data(:,i); % get next frame of audio data
 % compute next sine wave generator output (.25 Hz flanging rate)
 wt = 2*pi * 0.25 * ((0:frame_size−1) + (i−1)*frame_size))/Fs;
 dly = 20 + sin(wt + pi/4);
 %
 % assume a pair of functions named “VarDelayOutput/Update”:
 %
 dlyOut = VarDelayOutput(varDelayState, sigIn, dly);
 varDelayState = VarDelayUpdate(varDelayState, sigIn);
 y_afxf(:, i) = 0.5 * ( sigIn + dlyOut );
end
y_afxf = y_afxf(:);  % reshape frame matrix into one signal
sound(y_afxf, Fs);   % play result when simulation finishes
*****************************
In another aspect of the present invention, the model with the stream objects may be used to generate code as illustrated in the exemplary sequence depicted in FIG. 8. The sequence may begin with the providing of a model that includes an instance of the stream class discussed above (step 130). The model is then compiled to determine values for all essential model elements and to determine an ordering in which to execute the model blocks (step 132), and the compiled representation is transformed to a control flow graph intermediate representation (step 134). The code generation module may then generate code based on the control flow graph, this code may be generated for a particular target platform (step 136).
In addition to parameters that capture the particular hardware and operating system for which code is generated, the code can be generated based on parameters such as, but not limited to, whether it should be fixed-point or floating-point, whether memory usage should be minimized, whether debugging, profiling, and other instrumentation code should be included, whether function parameters should be stored locally or made available globally, whether functions should be reused wherever possible, whether argument lists to functions should be flat or are allowed to be structured.
Another aspect of the code generation technology is that it is very extensible. Provided with the SIMULINK product family is the Target Language Compiler (TLC). This technology enables the creation of “active scripts” that control how the generated code is produced for a model with stream objects. A user using TLC is able to customize the generated code to suit their specific needs.
Exemplary embodiments 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 Programmable ROM (PROM), a Magnetic RAM (MRAM), a Random Access Memory (RAM), a Read Only Memory (ROM), a magnetic tape, etc. In general, the computer-readable programs may be implemented in substantially any programming language. Examples of languages that can be used include but are not limited to, MATLAB language, FORTRAN, C, C++, C#, Python, JavaScript, Java, etc. Examples of graphical programming environments include, but are not limited to, Simulink, LabView, Hyperception, Signal Processing Designer, VisualSim, SCADE, etc. 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 Field Programmable Gate Array (FPGA), an Application Specific Instruction set Processor (ASIP), an Application Specific Integrated Circuit (ASIC), etc. 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 and multiple processors having two or more cores may be implemented on the same chip.
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 (30)

We claim:
1. A method comprising:
providing, by a device, a definition of a data stream processing class,
the definition of the data steam processing class identifying:
an output operation that produces an output value for an instance of the data stream processing class, and
an update operation that updates a state of the instance of the data stream processing class,
the output operation and the update operation being called using an Application Programming Interface (API) defined by the definition of the data steam processing class;
instantiating, by the device, the data stream processing class in a text-based computing environment to implement the API; and
processing, by the device, a data stream via the API,
processing the data stream including:
using the instance of the data stream processing class to perform one or more of the output operation or the update operation on the data stream.
2. The method of claim 1, where the definition of the data stream of processing class further identifies a reset operation, and
where the method further comprises performing the reset operation to reset the state of the instance.
3. The method of claim 1, where the definition of the data stream processing class further identifies a termination operation, and
where the method further comprises performing the termination operation to release resources that are associated with the instance of the data stream processing class.
4. The method of claim 1, where the definition of the data stream processing class further identifies a retrieve output operation, and
where the method further comprises performing the retrieve output operation to retrieve an output value calculated before the output value, for the instance of the data stream processing class, is produced.
5. The method of claim 1, where the data stream includes one or more of:
video data,
audio data,
radio frequency sensor data, or
digitized transducer data.
6. The method of claim 1, where the data stream includes one or more of:
stock data, or
gene sequence data.
7. The method of claim 1, where an object, associated with the instance of the data stream processing class, includes:
a filter object that provides a filtering of the data stream, or
a delay object that imposes a delay in the data stream.
8. The method of claim 1, where the data stream is provided as an input to the instance of the data stream processing class, and
where processing the data stream further includes:
calling, via the API, the output operation to calculate the output value,
where the output operation calculates the output value.
9. The method of claim 8, where the output value is calculated based on one or more parameters of the instance of the data stream processing class.
10. The method of claim 1, where the data stream is provided as an input to the instance of the data stream processing class, and
where processing the data stream includes:
calling, via the API, the update operation to update the state of the instance of the data stream processing class.
11. A device comprising:
a memory to store instructions; and
one or more processors to execute the instructions to:
generate a definition of a data stream processing class,
the definition of the data stream processing class identifying a plurality of operations,
the plurality of operations including:
an output operation that produces a value for an instance of the data stream processing class, and
an update operation that updates a state of the instance of the data stream processing class,
the output operation and the update operation being called using an Application Programming Interface (API),
the API being defined by the definition of the data stream processing class,
instantiate the data stream processing class to implement the API, and
process, using the instance of the data stream processing class and via the API, a data stream in a text-based computing environment or a graphical computing environment,
when processing the data stream, the one or more processors are to:
perform one or more of the output operation or the update operation on the data stream.
12. The device of claim 11, where the data stream processing class is instantiated in the text-based computing environment, and
where, when processing the data stream, the one or more processors are to process the data stream in the text-based computing environment.
13. The device of claim 11, where the data stream processing class is instantiated in the graphical computing environment, and
where, when processing the data stream, the one or more processors are to process the data stream in the graphical computing environment.
14. The device of claim 11, where the plurality of operations further includes a reset operation, and
where, when processing the data stream, the one or more processors are further to reset the state of the instance of the data stream processing class based on the reset operation.
15. The device of claim 11, where the plurality of operations further includes a termination operation, and
where, when processing the data stream, the one or more processors are further to release resources that are associated with the instance of the data stream processing class based on the termination operation.
16. The device of claim 11, where the plurality of operations further includes a retrieve output operation, and
where, when processing the data stream, the one or more processors are further to retrieve an output value calculated, before the value for the instance of the data stream processing class is produced, based on the retrieve output operation.
17. The device of claim 11, where the data stream includes one or more of:
video data,
audio data,
radio frequency sensor data,
digitized transducer data,
stock data, or
gene sequence data.
18. The device of claim 11, where the data stream is provided as an input to the instance of the data streaming processing class, and
where, when processing the data stream, the one or more processors are to:
call, via the API, the output operation to calculate the value,
where the output operation calculates the value.
19. The device of claim 18, where the value is calculated based on one or more parameters of the instance of the data stream processing class.
20. The device of claim 19, where, when processing the data stream, the one or more processors are to:
call, via the API and after the value is calculated, the update operation to update the state of the instance of the data stream processing class to obtain an updated state of the instance of the data stream processing class, and
store the updated state of the instance of the data stream processing class.
21. The device of claim 11, where the plurality of operations further includes a particular operation that combines functionalities of the output operation and the update operation,
where, when processing the data stream, the one or more processors are to call the particular operation, and
where, when calling the particular operation, the one or more processors are to call the output operation and the update operation.
22. A non-transitory computer-readable medium storing instructions, the instructions comprising:
a plurality of instructions which, when executed by one or more processors, cause the one or more processors to:
generate a definition of a data stream processing class,
the definition of the data stream processing class identifying a plurality of operations,
the plurality of operations including:
a first operation that produces a value for an instance of the data stream processing class, and
a second operation that updates a state of the instance of the data stream processing class,
the first operation and the second operation being called using an Application Programming Interface (API),
the API being defined by the definition of the data stream processing class,
instantiate the data stream processing class to implement the API, and
process, using the instance of the data stream processing class and via the API, a data stream in a text-based computing environment or a graphical computing environment,
one or more instructions, of the plurality of instructions, to process the data stream including:
one or more instructions to perform one or more of the first operation or the second operation on the data stream.
23. The non-transitory computer-readable medium of claim 22, where the data stream processing class is instantiated in the text-based computing environment, and
where the one or more instructions to process the data stream further include one or more instructions to process the data stream in the text-based computing environment.
24. The non-transitory computer-readable medium of claim 22, where the data stream processing class is instantiated in the graphical computing environment, and
where the one or more instructions to process the data stream further include one or more instructions to process the data stream in the graphical computing environment.
25. The non-transitory computer-readable medium of claim 22, where the plurality of operations further includes a third operation, and
where the one or more instructions to process the data stream further include one or more instructions to reset the state of the instance of the data stream processing class based on the third operation.
26. The non-transitory computer-readable medium of claim 22, where the plurality of operations further includes a third operation, and
where the one or more instructions to process the data stream further include one or more instructions to release resources that are associated with the instance of the data stream processing class based on the third operation.
27. The non-transitory computer-readable medium of claim 22, where the plurality of operations further includes a third operation, and
where the one or more instructions to process the data stream further include one or more instructions to retrieve an output value calculated, before the value for the instance of the data stream processing class is produced, based on the third operation.
28. The non-transitory computer-readable medium of claim 22, where the data stream includes one or more of:
video data,
audio data,
radio frequency sensor data,
digitized transducer data,
stock data, or
gene sequence data.
29. The non-transitory computer-readable medium of claim 22, where the data stream is provided as an input to the instance of the data stream processing class, and
where the one or more instructions to process the data stream further include:
one or more instructions to call, via the API, the first operation to calculate the value,
where the value is calculated based on one or more parameters of the instance of the data stream processing class,
one or more instructions to call, via the API and after the value is calculated, the second operation to update the state of the instance of the data stream processing class to obtain an updated state of the instance of the data stream processing class, and
one or more instructions to store the updated state of the instance of the data stream processing class.
30. The non-transitory computer-readable medium of claim 22, where the plurality of operations flirther includes a third operation, and
where the one or more instructions to process the data stream further include one or more instructions to call the third operation, and
where the one or more instructions to call the third operation include one or more instructions to call the first operation and the second operation based on calling the third operation.
US13/561,818 2006-09-11 2012-07-30 System and method for using stream objects to perform stream processing in a text-based computing environment Active US8789017B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/561,818 US8789017B2 (en) 2006-09-11 2012-07-30 System and method for using stream objects to perform stream processing in a text-based computing environment

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/519,255 US8234623B2 (en) 2006-09-11 2006-09-11 System and method for using stream objects to perform stream processing in a text-based computing environment
US13/561,818 US8789017B2 (en) 2006-09-11 2012-07-30 System and method for using stream objects to perform stream processing in a text-based computing environment

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/519,255 Continuation US8234623B2 (en) 2006-09-11 2006-09-11 System and method for using stream objects to perform stream processing in a text-based computing environment

Publications (2)

Publication Number Publication Date
US20120291054A1 US20120291054A1 (en) 2012-11-15
US8789017B2 true US8789017B2 (en) 2014-07-22

Family

ID=39145103

Family Applications (2)

Application Number Title Priority Date Filing Date
US11/519,255 Active 2030-09-09 US8234623B2 (en) 2006-09-11 2006-09-11 System and method for using stream objects to perform stream processing in a text-based computing environment
US13/561,818 Active US8789017B2 (en) 2006-09-11 2012-07-30 System and method for using stream objects to perform stream processing in a text-based computing environment

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US11/519,255 Active 2030-09-09 US8234623B2 (en) 2006-09-11 2006-09-11 System and method for using stream objects to perform stream processing in a text-based computing environment

Country Status (3)

Country Link
US (2) US8234623B2 (en)
EP (1) EP2062136B1 (en)
WO (1) WO2008033391A2 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9703532B1 (en) * 2014-09-30 2017-07-11 The Mathworks, Inc. Dynamically updating class instances based on class definition changes
US20230014435A1 (en) * 2021-07-14 2023-01-19 Capital One Services, Llc Filter class for querying operations

Families Citing this family (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8983823B1 (en) 2005-12-29 2015-03-17 The Mathworks, Inc. Verification harness for automatically generating a text-based representation of a graphical model
US8234623B2 (en) 2006-09-11 2012-07-31 The Mathworks, Inc. System and method for using stream objects to perform stream processing in a text-based computing environment
US8260602B1 (en) 2006-11-02 2012-09-04 The Math Works, Inc. Timer analysis and identification
US8098248B2 (en) * 2007-04-02 2012-01-17 International Business Machines Corporation Method for semantic modeling of stream processing components to enable automatic application composition
US8166465B2 (en) * 2007-04-02 2012-04-24 International Business Machines Corporation Method and system for composing stream processing applications according to a semantic description of a processing goal
US8863102B2 (en) 2007-04-02 2014-10-14 International Business Machines Corporation Method and system for assembling information processing applications based on declarative semantic specifications
US8370812B2 (en) 2007-04-02 2013-02-05 International Business Machines Corporation Method and system for automatically assembling processing graphs in information processing systems
US8307372B2 (en) 2007-04-02 2012-11-06 International Business Machines Corporation Method for declarative semantic expression of user intent to enable goal-driven information processing
US8117233B2 (en) 2007-05-14 2012-02-14 International Business Machines Corporation Method and system for message-oriented semantic web service composition based on artificial intelligence planning
US20110060993A1 (en) * 2009-09-08 2011-03-10 Classified Ventures, Llc Interactive Detailed Video Navigation System
US8595234B2 (en) * 2010-05-17 2013-11-26 Wal-Mart Stores, Inc. Processing data feeds
US8725592B2 (en) 2010-11-18 2014-05-13 Wal-Mart Stores, Inc. Method, system, and medium for recommending gift products based on textual information of a selected user
US9600411B2 (en) 2011-01-31 2017-03-21 The Mathworks, Inc. System and method for determining an object's lifetime in an object oriented environment
US9170783B1 (en) * 2011-12-15 2015-10-27 The Mathworks, Inc. Class creation assistant for textual programming languages
US9223614B2 (en) * 2012-06-26 2015-12-29 Wal-Mart Stores, Inc. Systems and methods for event stream processing
US10025566B1 (en) 2016-10-07 2018-07-17 The Mathworks, Inc. Scheduling technique to transform dataflow graph into efficient schedule
US10534337B2 (en) * 2017-05-04 2020-01-14 Servicenow, Inc. Flow engine for building automated flows within a cloud based developmental platform

Citations (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6163776A (en) 1998-03-23 2000-12-19 Software Tree, Inc. System and method for exchanging data and commands between an object oriented system and relational system
US6230200B1 (en) 1997-09-08 2001-05-08 Emc Corporation Dynamic modeling for resource allocation in a file server
US6260187B1 (en) 1998-08-20 2001-07-10 Wily Technology, Inc. System for modifying object oriented code
US6324682B1 (en) 1997-02-14 2001-11-27 Velocity.Com Organicware applications for computer systems
US20030005169A1 (en) 2001-06-28 2003-01-02 International Business Machines Corporation Method and system for maintaining forward and backward compatibility in flattened object streams
US6564368B1 (en) 1998-10-01 2003-05-13 Call Center Technology, Inc. System and method for visual application development without programming
WO2003052597A2 (en) 2001-12-14 2003-06-26 Koninklijke Philips Electronics N.V. Data processing system having multiple processors and task scheduler and corresponding method therefore
US20030140065A1 (en) * 2002-01-22 2003-07-24 Lovvik Paul A. Method and apparatus for processing a streamed zip file
US20030195865A1 (en) 2000-05-12 2003-10-16 Long David J. Transaction-aware caching for access control metadata
US6701367B1 (en) 1999-09-24 2004-03-02 Sun Microsystems, Inc. Mechanism for enabling customized session managers to interact with a network server
US20040054686A1 (en) 2002-09-14 2004-03-18 International Business Machines Corporation System and method for collecting and transferring sets of related data from a mainframe to a workstation
US20040075670A1 (en) 2000-07-31 2004-04-22 Bezine Eric Camille Pierre Method and system for receiving interactive dynamic overlays through a data stream and displaying it over a video content
US20040250239A1 (en) 2003-06-09 2004-12-09 International Business Machines Corporation Maintaining multiple valid concurrent serialized object versions
US20050055398A1 (en) 2001-03-27 2005-03-10 Microsoft Corporation Protocol agnostic request response pattern
US20050065972A1 (en) * 2003-05-02 2005-03-24 Entuity Ltd. Data collection in a computer network
US20050071341A1 (en) 2003-09-26 2005-03-31 Microsoft Corporation Method for maintaining information about multiple instances of an activity
US20050096894A1 (en) * 2003-10-31 2005-05-05 The Mathworks, Inc. Simplified data signal support for diagramming environment languages
US20050097187A1 (en) 2003-10-10 2005-05-05 Oracle International Corporation Object relational mapping layer
US20050108627A1 (en) 2003-11-13 2005-05-19 International Business Machines Corporation Serialization and preservation of objects
US20050108295A1 (en) * 2003-11-18 2005-05-19 Oracle International Corporation, A California Corporation Method of and system for committing a transaction to database
US20050187745A1 (en) 2004-02-20 2005-08-25 The Mathworks, Inc. Method and apparatus facilitating communication with a simulation environment
US20060059473A1 (en) * 2004-09-13 2006-03-16 The Mathworks, Inc. Methods and system for executing a program in multiple execution environments
US7103910B1 (en) 1999-11-22 2006-09-05 Sun Microsystems, Inc. Method and apparatus for verifying the legitimacy of an untrusted mechanism
US20060253792A1 (en) 2005-05-03 2006-11-09 The Mathworks, Inc. System and method for building graphical instrument panels
US20070294311A1 (en) * 2006-06-16 2007-12-20 Microsoft Corporation Application program interface to manage media files
US7370275B2 (en) 2003-10-24 2008-05-06 Microsoft Corporation System and method for providing context to an input method by tagging existing applications
US7640540B2 (en) 2003-10-24 2009-12-29 Microsoft Corporation Mechanism for providing extended functionality to command line instructions
US8234623B2 (en) 2006-09-11 2012-07-31 The Mathworks, Inc. System and method for using stream objects to perform stream processing in a text-based computing environment

Patent Citations (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6324682B1 (en) 1997-02-14 2001-11-27 Velocity.Com Organicware applications for computer systems
US6230200B1 (en) 1997-09-08 2001-05-08 Emc Corporation Dynamic modeling for resource allocation in a file server
US6163776A (en) 1998-03-23 2000-12-19 Software Tree, Inc. System and method for exchanging data and commands between an object oriented system and relational system
US6260187B1 (en) 1998-08-20 2001-07-10 Wily Technology, Inc. System for modifying object oriented code
US6564368B1 (en) 1998-10-01 2003-05-13 Call Center Technology, Inc. System and method for visual application development without programming
US6701367B1 (en) 1999-09-24 2004-03-02 Sun Microsystems, Inc. Mechanism for enabling customized session managers to interact with a network server
US20040064564A1 (en) * 1999-09-24 2004-04-01 Ruslan Belkin Mechanism for enabling customized session managers to interact with a network server
US7103910B1 (en) 1999-11-22 2006-09-05 Sun Microsystems, Inc. Method and apparatus for verifying the legitimacy of an untrusted mechanism
US20030195865A1 (en) 2000-05-12 2003-10-16 Long David J. Transaction-aware caching for access control metadata
US20040075670A1 (en) 2000-07-31 2004-04-22 Bezine Eric Camille Pierre Method and system for receiving interactive dynamic overlays through a data stream and displaying it over a video content
US20050055398A1 (en) 2001-03-27 2005-03-10 Microsoft Corporation Protocol agnostic request response pattern
US20030005169A1 (en) 2001-06-28 2003-01-02 International Business Machines Corporation Method and system for maintaining forward and backward compatibility in flattened object streams
WO2003052597A2 (en) 2001-12-14 2003-06-26 Koninklijke Philips Electronics N.V. Data processing system having multiple processors and task scheduler and corresponding method therefore
US20030140065A1 (en) * 2002-01-22 2003-07-24 Lovvik Paul A. Method and apparatus for processing a streamed zip file
US20040054686A1 (en) 2002-09-14 2004-03-18 International Business Machines Corporation System and method for collecting and transferring sets of related data from a mainframe to a workstation
US20050065972A1 (en) * 2003-05-02 2005-03-24 Entuity Ltd. Data collection in a computer network
US20040250239A1 (en) 2003-06-09 2004-12-09 International Business Machines Corporation Maintaining multiple valid concurrent serialized object versions
US20050071341A1 (en) 2003-09-26 2005-03-31 Microsoft Corporation Method for maintaining information about multiple instances of an activity
US20050097187A1 (en) 2003-10-10 2005-05-05 Oracle International Corporation Object relational mapping layer
US7640540B2 (en) 2003-10-24 2009-12-29 Microsoft Corporation Mechanism for providing extended functionality to command line instructions
US7370275B2 (en) 2003-10-24 2008-05-06 Microsoft Corporation System and method for providing context to an input method by tagging existing applications
US20050096894A1 (en) * 2003-10-31 2005-05-05 The Mathworks, Inc. Simplified data signal support for diagramming environment languages
US20050108627A1 (en) 2003-11-13 2005-05-19 International Business Machines Corporation Serialization and preservation of objects
US20050108295A1 (en) * 2003-11-18 2005-05-19 Oracle International Corporation, A California Corporation Method of and system for committing a transaction to database
US20050187745A1 (en) 2004-02-20 2005-08-25 The Mathworks, Inc. Method and apparatus facilitating communication with a simulation environment
US20060059473A1 (en) * 2004-09-13 2006-03-16 The Mathworks, Inc. Methods and system for executing a program in multiple execution environments
US20060253792A1 (en) 2005-05-03 2006-11-09 The Mathworks, Inc. System and method for building graphical instrument panels
US20070294311A1 (en) * 2006-06-16 2007-12-20 Microsoft Corporation Application program interface to manage media files
US8234623B2 (en) 2006-09-11 2012-07-31 The Mathworks, Inc. System and method for using stream objects to perform stream processing in a text-based computing environment

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
International Search Report for Application No. PCT/US2007/019803, 10 pages, dated Mar. 27, 2008.

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9703532B1 (en) * 2014-09-30 2017-07-11 The Mathworks, Inc. Dynamically updating class instances based on class definition changes
US20230014435A1 (en) * 2021-07-14 2023-01-19 Capital One Services, Llc Filter class for querying operations
US11847117B2 (en) * 2021-07-14 2023-12-19 Capital One Services, Llc Filter class for querying operations

Also Published As

Publication number Publication date
EP2062136A2 (en) 2009-05-27
EP2062136B1 (en) 2017-12-27
US8234623B2 (en) 2012-07-31
WO2008033391A3 (en) 2008-05-15
US20120291054A1 (en) 2012-11-15
WO2008033391A2 (en) 2008-03-20
US20080127064A1 (en) 2008-05-29

Similar Documents

Publication Publication Date Title
US8789017B2 (en) System and method for using stream objects to perform stream processing in a text-based computing environment
US8769485B2 (en) Data parallelism and parallel operations in stream processing
US8234630B2 (en) 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
US9038041B2 (en) Stream processor with compiled programs
Kim et al. Macsim: A cpu-gpu heterogeneous simulation framework user guide
US8200807B2 (en) Non-blocking local events in a state-diagramming environment
AU2012256399B2 (en) Registration and execution of highly concurrent processing tasks
US20080270979A1 (en) Methods and systems for using type models to generate an implementation of a type
EP2956862A1 (en) Call stacks for asynchronous programs
Van den Vonder et al. Tackling the awkward squad for reactive programming: the actor-reactor model
US9311111B2 (en) Programming environment with support for handle and non-handle user-created classes
CN112487019B (en) Method and system for analyzing dynamic SQL (structured query language) of OpenGauss database
US8041551B1 (en) Algorithm and architecture for multi-argument associative operations that minimizes the number of components using a latency of the components
Shen et al. A design tool for efficient mapping of multimedia applications onto heterogeneous platforms
US7636914B1 (en) System and method for providing context to operator overloading
Loidl Gransim user’s guide
Böhme et al. A Penny a Function: Towards Cost Transparent Cloud Programming
Lantreibecq et al. Model checking and co-simulation of a dynamic task dispatcher circuit using CADP
US8843906B1 (en) Inferring data types from compiler call site
Dastgeer et al. A Framework for Performance-aware Composition of Applications for GPU-based Systems
Patel HEMLOCK: HEterogeneous ModeL Of Computation Kernel for SystemC
Wu Modeling and mapping of optimized schedules for embedded signal processing systems
Mohammed et al. Development of coroutines usage model for cooperative multitasking implementation on the systems with limited resources
Garcia et al. CS 598 WG Project Report
Sideris et al. Building embedded DSP applications in a Java modeling framework

Legal Events

Date Code Title Description
AS Assignment

Owner name: THE MATHWORKS, INC., MASSACHUSETTS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:OROFINO, II, DONALD PAUL;LONGFRITZ, MICHAEL JAMES;REEL/FRAME:028700/0298

Effective date: 20061026

STCF Information on status: patent grant

Free format text: PATENTED CASE

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551)

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8