×

General purpose distributed data parallel computing using a high level language

  • US 9,110,706 B2
  • Filed: 02/09/2009
  • Issued: 08/18/2015
  • Est. Priority Date: 02/09/2009
  • Status: Active Grant
First Claim
Patent Images

1. A system, comprising:

  • a processor readable storage hardware device;

    a user interface; and

    a processor coupled to the processor readable hardware storage device and to the user interface, wherein the processor readable hardware storage device includes instructions that cause the processor to;

    execute a sequential application program comprising a data parallel portion that includes an expression, wherein the application is written in a high-level language and comprises both imperative operations and declarative operations;

    access the expression from a portion of the sequential application program that comprises a declarative operation;

    based on the expression, automatically generate an execution plan graph, the execution plan graph including a directed graph having vertices that represent processes and edges between the vertices that represent data channels, the execution plan graph for executing the expression in parallel at nodes of a compute cluster, including causing the processor to break the expression into a plurality of sub-expressions, each of the sub-expressions is a vertex in the directed graph;

    automatically generate vertex code for the vertices of the execution plan graph;

    automatically generate serialization code that allows data to be passed in the data channels between the vertices;

    provide the execution plan graph, the serialization code, and the vertex code to an execution engine of the compute cluster that manages parallel execution of the expression in the compute cluster based on the execution plan graph, the serialization code, and the vertex code;

    receive results of executing the execution plan graph in the compute cluster; and

    execute a portion of the sequential application program that comprises an imperative operation to present the results in the user interface.

View all claims
  • 2 Assignments
Timeline View
Assignment View
    ×
    ×