Shadowrun: Awakened 29 September 2011 - Build 871
Graph.h
Go to the documentation of this file.
00001 /*
00002     Copyright 2005-2010 Intel Corporation.  All Rights Reserved.
00003 
00004     This file is part of Threading Building Blocks.
00005 
00006     Threading Building Blocks is free software; you can redistribute it
00007     and/or modify it under the terms of the GNU General Public License
00008     version 2 as published by the Free Software Foundation.
00009 
00010     Threading Building Blocks is distributed in the hope that it will be
00011     useful, but WITHOUT ANY WARRANTY; without even the implied warranty
00012     of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013     GNU General Public License for more details.
00014 
00015     You should have received a copy of the GNU General Public License
00016     along with Threading Building Blocks; if not, write to the Free Software
00017     Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
00018 
00019     As a special exception, you may use this file as part of a free software
00020     library without restriction.  Specifically, if other files instantiate
00021     templates or use macros or inline functions from this file, or you compile
00022     this file and link it with other files to produce an executable, this
00023     file does not by itself cause the resulting executable to be covered by
00024     the GNU General Public License.  This exception does not however
00025     invalidate any other reasons why the executable file might be covered by
00026     the GNU General Public License.
00027 */
00028 
00029 #include "Matrix.h"
00030 #include "tbb/atomic.h"
00031 #include <vector>
00032 
00033 enum OpKind {
00034     // Use Cell's value
00035     OP_VALUE,
00036     // Unary negation
00037     OP_NEGATE,
00038     // Addition
00039     OP_ADD,
00040     // Subtraction
00041     OP_SUB,
00042     // Multiplication
00043     OP_MUL
00044 };
00045 
00046 static const int ArityOfOp[] = {0,1,2,2,2};
00047 
00048 class Cell {
00049 public:
00051     OpKind op;
00052 
00054     Cell* input[2];
00055    
00057     typedef Matrix value_type;
00058 
00060     value_type value;
00061 
00063     std::vector<Cell*> successor;
00064 
00066     tbb::atomic<int> ref_count;
00067 
00069     void update();
00070 
00072     Cell() {}
00073 };
00074 
00076 class Graph {
00077     std::vector<Cell> my_vertex_set;
00078 public:
00080     void create_random_dag( size_t number_of_nodes );
00081 
00083     void print();
00084 
00086     void get_root_set( std::vector<Cell*>& root_set );
00087 };
00088 

Copyright © 2007-2010 by The Shadowrun: Awakened Team. This work is licensed under the GNU Lesser General Public License 3.

GNU Lesser General Public License 3 Sourceforge.net