@ -3,6 +3,7 @@ 
		
	
		
			
				# include  "src/storage/SparseMatrix.h" 
 # include  "src/storage/SparseMatrix.h" 
  
		
	
		
			
				
 
		
	
		
			
				typedef  storm : : storage : : SparseMatrix < double > : : index_type  entry_index ; typedef  storm : : storage : : SparseMatrix < double > : : index_type  entry_index ;  
		
	
		
			
				typedef  storm : : storage : : SparseMatrix < storm : : RationalFunction > : : index_type  parametric_entry_index ;  
		
	
		
			
				
 
		
	
		
			
				void  define_sparse_matrix ( py : : module &  m )  { void  define_sparse_matrix ( py : : module &  m )  {  
		
	
		
			
				
 
		
	
	
		
			
				
					
					
					
						
							 
					
				 
				@ -19,6 +20,19 @@ void define_sparse_matrix(py::module& m) { 
		
	
		
			
				        . def ( " column " ,  & storm : : storage : : MatrixEntry < entry_index ,  double > : : getColumn ,  " Column " )         . def ( " column " ,  & storm : : storage : : MatrixEntry < entry_index ,  double > : : getColumn ,  " Column " )  
		
	
		
			
				    ;     ;  
		
	
		
			
				   
		
	
		
			
				    py : : class_ < storm : : storage : : MatrixEntry < entry_index ,  storm : : RationalFunction > > ( m ,  " ParametricSparseMatrixEntry " ,  " Entry of parametric sparse matrix " )  
		
	
		
			
				        . def ( " __str__ " ,  [ ] ( storm : : storage : : MatrixEntry < entry_index ,  storm : : RationalFunction >  const &  entry )  {  
		
	
		
			
				                std : : stringstream  stream ;  
		
	
		
			
				                stream  < <  entry ;  
		
	
		
			
				                return  stream . str ( ) ;  
		
	
		
			
				            } )  
		
	
		
			
				        //def_property threw "pointer being freed not allocated" after exiting
  
		
	
		
			
				        . def ( " value " ,  & storm : : storage : : MatrixEntry < entry_index ,  storm : : RationalFunction > : : getValue ,  " Value " )  
		
	
		
			
				        . def ( " set_value " ,  & storm : : storage : : MatrixEntry < entry_index ,  storm : : RationalFunction > : : setValue ,  py : : arg ( " value " ) ,  " Set value " )  
		
	
		
			
				        . def ( " column " ,  & storm : : storage : : MatrixEntry < entry_index ,  storm : : RationalFunction > : : getColumn ,  " Column " )  
		
	
		
			
				    ;  
		
	
		
			
				
 
		
	
		
			
				    // SparseMatrix
  
		
	
		
			
				    py : : class_ < storm : : storage : : SparseMatrix < double > > ( m ,  " SparseMatrix " ,  " Sparse matrix " )     py : : class_ < storm : : storage : : SparseMatrix < double > > ( m ,  " SparseMatrix " ,  " Sparse matrix " )  
		
	
		
			
				        . def ( " __iter__ " ,  [ ] ( storm : : storage : : SparseMatrix < double > &  matrix )  {         . def ( " __iter__ " ,  [ ] ( storm : : storage : : SparseMatrix < double > &  matrix )  {  
		
	
		
			
				                return  py : : make_iterator ( matrix . begin ( ) ,  matrix . end ( ) ) ;                 return  py : : make_iterator ( matrix . begin ( ) ,  matrix . end ( ) ) ;  
		
	
	
		
			
				
					
						
							 
					
					
						
							 
					
					
				 
				@ -45,7 +59,36 @@ void define_sparse_matrix(py::module& m) { 
		
	
		
			
				                    stream  < <  transition  < <  " ,  " ;                     stream  < <  transition  < <  " ,  " ;  
		
	
		
			
				                }                 }  
		
	
		
			
				                return  stream . str ( ) ;                 return  stream . str ( ) ;  
		
	
		
			
				            } ,  py : : arg ( " row " ) ,  " Print row " )  
		
	
		
			
				    ;  
		
	
		
			
				
 
		
	
		
			
				    py : : class_ < storm : : storage : : SparseMatrix < storm : : RationalFunction > > ( m ,  " ParametricSparseMatrix " ,  " Parametric sparse matrix " )  
		
	
		
			
				        . def ( " __iter__ " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction > &  matrix )  {  
		
	
		
			
				                return  py : : make_iterator ( matrix . begin ( ) ,  matrix . end ( ) ) ;  
		
	
		
			
				            } ,  py : : keep_alive < 0 ,  1 > ( )  /* Essential: keep object alive while iterator exists */ )  
		
	
		
			
				        . def ( " __str__ " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction >  const &  matrix )  {  
		
	
		
			
				                std : : stringstream  stream ;  
		
	
		
			
				                stream  < <  matrix ;  
		
	
		
			
				                return  stream . str ( ) ;  
		
	
		
			
				            } )             } )  
		
	
		
			
				        . def ( " nr_rows " ,  & storm : : storage : : SparseMatrix < storm : : RationalFunction > : : getRowCount ,  " Number of rows " )  
		
	
		
			
				        . def ( " nr_columns " ,  & storm : : storage : : SparseMatrix < storm : : RationalFunction > : : getColumnCount ,  " Number of columns " )  
		
	
		
			
				        . def ( " nr_entries " ,  & storm : : storage : : SparseMatrix < storm : : RationalFunction > : : getEntryCount ,  " Number of non-zero entries " )  
		
	
		
			
				        . def ( " _row_group_indices " ,  & storm : : storage : : SparseMatrix < storm : : RationalFunction > : : getRowGroupIndices ,  " Get starting rows of row groups " )  
		
	
		
			
				        . def ( " get_row " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction > &  matrix ,  entry_index  row )  {  
		
	
		
			
				                return  matrix . getRows ( row ,  row + 1 ) ;  
		
	
		
			
				            } ,  py : : return_value_policy : : reference ,  py : : keep_alive < 1 ,  0 > ( ) ,  py : : arg ( " row " ) ,  " Get row " )  
		
	
		
			
				        . def ( " get_rows " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction > &  matrix ,  entry_index  start ,  entry_index  end )  {  
		
	
		
			
				                return  matrix . getRows ( start ,  end ) ;  
		
	
		
			
				            } ,  py : : return_value_policy : : reference ,  py : : keep_alive < 1 ,  0 > ( ) ,  py : : arg ( " row_start " ) ,  py : : arg ( " row_end " ) ,  " Get rows from start to end " )  
		
	
		
			
				        . def ( " print_row " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction >  const &  matrix ,  entry_index  row )  {  
		
	
		
			
				                std : : stringstream  stream ;  
		
	
		
			
				                auto  rows  =  matrix . getRows ( row ,  row + 1 ) ;  
		
	
		
			
				                for  ( auto  transition  :  rows )  {  
		
	
		
			
				                    stream  < <  transition  < <  " ,  " ;  
		
	
		
			
				                }  
		
	
		
			
				                return  stream . str ( ) ;  
		
	
		
			
				            } ,  py : : arg ( " row " ) ,  " Print row " )  
		
	
		
			
				    ;     ;  
		
	
		
			
				
 
		
	
		
			
				    // Rows
     // Rows
  
		
	
	
		
			
				
					
					
					
						
							 
					
				 
				@ -53,7 +96,20 @@ void define_sparse_matrix(py::module& m) { 
		
	
		
			
				        . def ( " __iter__ " ,  [ ] ( storm : : storage : : SparseMatrix < double > : : rows &  rows )  {         . def ( " __iter__ " ,  [ ] ( storm : : storage : : SparseMatrix < double > : : rows &  rows )  {  
		
	
		
			
				                return  py : : make_iterator ( rows . begin ( ) ,  rows . end ( ) ) ;                 return  py : : make_iterator ( rows . begin ( ) ,  rows . end ( ) ) ;  
		
	
		
			
				            } ,  py : : keep_alive < 0 ,  1 > ( ) )             } ,  py : : keep_alive < 0 ,  1 > ( ) )  
		
	
		
			
				        . def ( " __str__ " ,  [ ] ( storm : : storage : : SparseMatrix < double > : : rows &  rows )  {  
		
	
		
			
				        . def ( " __str__ " ,  [ ] ( storm : : storage : : SparseMatrix < double > : : const_rows &  rows )  {  
		
	
		
			
				                std : : stringstream  stream ;  
		
	
		
			
				                for  ( auto  transition  :  rows )  {  
		
	
		
			
				                    stream  < <  transition  < <  " ,  " ;  
		
	
		
			
				                }  
		
	
		
			
				                return  stream . str ( ) ;  
		
	
		
			
				            } )  
		
	
		
			
				    ;  
		
	
		
			
				
 
		
	
		
			
				    py : : class_ < storm : : storage : : SparseMatrix < storm : : RationalFunction > : : rows > ( m ,  " ParametricSparseMatrixRows " ,  " Set of rows in a parametric sparse matrix " )  
		
	
		
			
				        . def ( " __iter__ " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction > : : rows &  rows )  {  
		
	
		
			
				                return  py : : make_iterator ( rows . begin ( ) ,  rows . end ( ) ) ;  
		
	
		
			
				            } ,  py : : keep_alive < 0 ,  1 > ( ) )  
		
	
		
			
				        . def ( " __str__ " ,  [ ] ( storm : : storage : : SparseMatrix < storm : : RationalFunction > : : const_rows &  rows )  {  
		
	
		
			
				                std : : stringstream  stream ;                 std : : stringstream  stream ;  
		
	
		
			
				                for  ( auto  transition  :  rows )  {                 for  ( auto  transition  :  rows )  {  
		
	
		
			
				                    stream  < <  transition  < <  " ,  " ;                     stream  < <  transition  < <  " ,  " ;