@ -70,7 +70,7 @@ public: 
			
		
	
		
			
				
							 *  
			
		
	
		
			
				
							 *  @ param  matrix  The  matrix  on  which  this  iterator  operates .  
			
		
	
		
			
				
							 */  
			
		
	
		
			
				
							ConstRowsIterator ( SparseMatrix < T >  const &  matrix )  :  matrix ( matrix ) ,  i ndex( 0 ) ,  rowIndex ( 0 )  {  
			
		
	
		
			
				
							ConstRowsIterator ( SparseMatrix < T >  const &  matrix ,  uint_fast64_t  rowIndex  =  0 )  :  matrix ( matrix ) ,  posI ndex( 0 ) ,  rowIndex ( 0 )  {  
			
		
	
		
			
				
								/ /  Intentionally  left  empty .  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -80,8 +80,8 @@ public: 
			
		
	
		
			
				
							 *  @ returns  A  reference  to  itself .  
			
		
	
		
			
				
							 */  
			
		
	
		
			
				
							ConstRowsIterator &  operator + + ( )  {  
			
		
	
		
			
				
								+ + i ndex;  
			
		
	
		
			
				
								if  ( i ndex> =  matrix . rowIndications [ rowIndex  +  1 ] )  {  
			
		
	
		
			
				
								+ + posI ndex;  
			
		
	
		
			
				
								if  ( posI ndex> =  matrix . rowIndications [ rowIndex  +  1 ] )  {  
			
		
	
		
			
				
									+ + rowIndex ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
								return  * this ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -105,7 +105,7 @@ public: 
			
		
	
		
			
				
							 *  @ return  True  iff  the  given  iterator  points  to  the  same  index  as  the  current  iterator .  
			
		
	
		
			
				
							 */  
			
		
	
		
			
				
							bool  operator = = ( ConstRowsIterator  const &  other )  const  {  
			
		
	
		
			
				
								return  this - > i ndex= =  other . i ndex;  
			
		
	
		
			
				
								return  this - > posI ndex= =  other . posI ndex;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/*!  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -116,7 +116,7 @@ public: 
			
		
	
		
			
				
							 *  @ return  True  iff  the  given  iterator  points  to  a  differnent  index  as  the  current  iterator .  
			
		
	
		
			
				
							 */  
			
		
	
		
			
				
							bool  operator ! = ( ConstRowsIterator  const &  other )  const  {  
			
		
	
		
			
				
								return  this - > i ndex! =  other . i ndex;  
			
		
	
		
			
				
								return  this - > posI ndex! =  other . posI ndex;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					        /*!  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -138,14 +138,22 @@ public: 
			
		
	
		
			
				
							uint_fast64_t  column ( )  const  {  
			
		
	
		
			
				
								return  matrix . columnIndications [ index ] ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							 
			
		
	
		
			
				
							/*!  
			
		
	
		
			
				
							 *  Retrieves  the  internal  index  of  this  iterator .  This  index  corresponds  to  the  position  of  
			
		
	
		
			
				
							 *  the  current  element  in  the  vector  of  non - zero  values  of  the  matrix .  
			
		
	
		
			
				
							 */  
			
		
	
		
			
				
							uint_fast64_t  index ( )  const  {  
			
		
	
		
			
				
								return  this - > posIndex ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							 
			
		
	
		
			
				
					        /*!  
			
		
	
		
			
				
					         *  Retrieves  the  value  of  the  current  non - zero  element  this  iterator  points  to .  
			
		
	
		
			
				
							 *  
			
		
	
		
			
				
							 *  @ returns  The  value  of  the  current  non - zero  element  this  iterator  points  to .  
			
		
	
		
			
				
					         */  
			
		
	
		
			
				
							T  const &  value ( )  const  {  
			
		
	
		
			
				
								return  matrix . valueStorage [ index ] ;  
			
		
	
		
			
				
								return  matrix . valueStorage [ posI ndex] ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					        /*!  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -155,7 +163,7 @@ public: 
			
		
	
		
			
				
					         */  
			
		
	
		
			
				
							void  moveToRow ( uint_fast64_t  row )  {  
			
		
	
		
			
				
								this - > rowIndex  =  row ;  
			
		
	
		
			
				
								this - > i ndex=  matrix . rowIndications [ row ] ;  
			
		
	
		
			
				
								this - > posI ndex=  matrix . rowIndications [ row ] ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					        /*!  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -170,7 +178,7 @@ public: 
			
		
	
		
			
				
							SparseMatrix < T >  const &  matrix ;  
			
		
	
		
			
				
					         
			
		
	
		
			
				
					        / /  The  current  index  in  the  list  of  all  non - zero  elements  of  the  matrix  this  iterator  points  to .  
			
		
	
		
			
				
							uint_fast64_t  i ndex;  
			
		
	
		
			
				
							uint_fast64_t  posI ndex;  
			
		
	
		
			
				
					         
			
		
	
		
			
				
					        / /  The  row  of  the  element  this  iterator  currently  points  to .  
			
		
	
		
			
				
							uint_fast64_t  rowIndex ;  
			
		
	
	
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
				
				@ -489,14 +497,16 @@ public: 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  This  function  makes  the  groups  of  rows  given  by  the  bit  vector  absorbing .  
			
		
	
		
			
				
						 *  @ param  rows  A  bit  vector  indicating  which  row  groups  to  make  absorbing .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  rowGroupConstraint  A  bit  vector  indicating  which  row  groups  to  make  absorbing .  
			
		
	
		
			
				
						 *  @ param  rowGroupIndices  A  vector  indicating  which  rows  belong  to  a  given  row  group .  
			
		
	
		
			
				
						 *  @ return  True  iff  the  operation  was  successful .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						bool  makeRowsAbsorbing ( storm : : storage : : BitVector  const &  rows ,  std : : vector < uint_fast64_t >  const &  nondeterministicCho ices)  {  
			
		
	
		
			
				
						bool  makeRowsAbsorbing ( storm : : storage : : BitVector  const &  rowGroupCon straint  ,  std : : vector < uint_fast64_t >  const &  rowGroupInd ices)  {  
			
		
	
		
			
				
							bool  result  =  true ;  
			
		
	
		
			
				
							for  ( auto  index :  rows )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  row  =  nondeterministicChoices [ index ] ;  row  <  nondeterministicChoices [ index +  1 ] ;  + + row )  {  
			
		
	
		
			
				
									result  & =  makeRowAbsorbing ( row ,  index ) ;  
			
		
	
		
			
				
							for  ( auto  rowGroup :  rowGroupCon straint  )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  row  =  rowGroupIndices [ rowGroup ] ;  row  <  rowGroupIndices [ rowGroup +  1 ] ;  + + row )  {  
			
		
	
		
			
				
									result  & =  makeRowAbsorbing ( row ,  rowGroup ) ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							return  result ;  
			
		
	
	
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
				
				@ -550,7 +560,7 @@ public: 
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  row  The  row  whose  elements  to  add .  
			
		
	
		
			
				
						 *  @ param  constraint  A  bit  vector  that  indicates  which  columns  to  add .  
			
		
	
		
			
				
						 *  @ return The  sum  of  the  elements  in  the  given  row  whose  column  bits  
			
		
	
		
			
				
						 *  @ returns The  sum  of  the  elements  in  the  given  row  whose  column  bits  
			
		
	
		
			
				
						 *  are  set  to  one  on  the  given  constraint .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						T  getConstrainedRowSum ( uint_fast64_t  row ,  storm : : storage : : BitVector  const &  constraint )  const  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -564,44 +574,55 @@ public: 
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Computes  a  vector  in  which  each  element  is  the  sum  of  those  elements  in  the  
			
		
	
		
			
				
						 *  corresponding  row  whose  column  bits  are  set  to  one  in  the  given  constraint .  
			
		
	
		
			
				
						 *  Computes  a  vector  whose  ith  element  is  the  sum  of  the  elements  in  the  ith  row  where  only  
			
		
	
		
			
				
						 *  those  elements  are  added  whose  bits  are  set  to  true  in  the  given  column  constraint  and  only  
			
		
	
		
			
				
						 *  those  rows  are  treated  whose  bits  are  set  to  true  in  the  given  row  constraint .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  rowConstraint  A  bit  vector  that  indicates  for  which  rows  to  perform  summation .  
			
		
	
		
			
				
						 *  @ param  columnConstraint  A  bit  vector  that  indicates  which  columns  to  add .  
			
		
	
		
			
				
						 *  @ param  resultVector  A  pointer  to  the  resulting  vector  that  has  at  least  
			
		
	
		
			
				
						 *  as  many  elements  as  there  are  bits  set  to  true  in  the  constraint .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  A  vector  whose  ith  element  is  the  sum  of  the  elements  in  the  ith  row  where  only  
			
		
	
		
			
				
						 *  those  elements  are  added  whose  bits  are  set  to  true  in  the  given  column  constraint  and  only  
			
		
	
		
			
				
						 *  those  rows  are  treated  whose  bits  are  set  to  true  in  the  given  row  constraint .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						void  getConstrainedRowSumVector ( const  storm : : storage : : BitVector &  rowConstraint ,  const  storm : : storage : : BitVector &  columnConstraint ,  std : : vector < T > *  resultVector )  const  {  
			
		
	
		
			
				
						std : : vector < T >  getConstrainedRowSumVector ( storm : : storage : : BitVector  const &  rowConstraint ,  storm : : storage : : BitVector  const &  columnConstraint )  const  {  
			
		
	
		
			
				
							std : : vector < T >  result ( rowConstraint . getNumberOfSetBits ( ) ) ;  
			
		
	
		
			
				
							uint_fast64_t  currentRowCount  =  0 ;  
			
		
	
		
			
				
							for  ( auto  row  :  rowConstraint )  {  
			
		
	
		
			
				
								( * resultVector )  [ currentRowCount + + ]  =  getConstrainedRowSum ( row ,  columnConstraint ) ;  
			
		
	
		
			
				
								result [ currentRowCount + + ]  =  getConstrainedRowSum ( row ,  columnConstraint ) ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							return  result ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Computes  a  vector  in  which  each  element  is  the  sum  of  those  elements  in  the  
			
		
	
		
			
				
						 *  corresponding  row  whose  column  bits  are  set  to  one  in  the  given  constraint .  
			
		
	
		
			
				
						 *  @ param  rowConstraint  A  bit  vector  that  indicates  for  which  rows  to  perform  summation .  
			
		
	
		
			
				
						 *  Computes  a  vector  whose  elements  represent  the  sums  of  selected  ( given  by  the  column  
			
		
	
		
			
				
						 *  constraint )  entries  for  all  rows  in  selected  row  groups  given  by  the  row  group  constraint .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  rowGroupConstraint  A  bit  vector  that  indicates  which  row  groups  are  to  be  considered .  
			
		
	
		
			
				
						 *  @ param  rowGroupIndices  A  vector  indicating  which  rows  belong  to  a  given  row  group .  
			
		
	
		
			
				
						 *  @ param  columnConstraint  A  bit  vector  that  indicates  which  columns  to  add .  
			
		
	
		
			
				
						 *  @ param  resultVector  A  pointer  to  the  resulting  vector  that  has  at  least  
			
		
	
		
			
				
						 *  as  many  elements  as  there  are  bits  set  to  true  in  the  constraint .  
			
		
	
		
			
				
						 *  @ returns   
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						void  getConstrainedRowSumVector ( const  storm : : storage : : BitVector &  rowConstraint ,  std : : vector < uint_fast64_t >  const &  nondeterministicChoiceIndices ,  const  storm : : storage : : BitVector &  columnConstraint ,  std : : vector < T > *  resultVector )  const  {  
			
		
	
		
			
				
						std : : vector < T >  getConstrainedRowSumVector ( storm : : storage : : BitVector  const &  rowGroupConstraint ,  std : : vector < uint_fast64_t >  const &  rowGroupIndices ,  storm : : storage : : BitVector  const &  columnConstraint ,  uint_fast64_t  numberOfRows )  const  {  
			
		
	
		
			
				
							std : : vector < T >  result ( numberOfRows ) ;  
			
		
	
		
			
				
							uint_fast64_t  currentRowCount  =  0 ;  
			
		
	
		
			
				
							for  ( auto  index :  rowConstraint )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  row  =  nondeterministicChoiceIndices [ index ] ;  row  <  nondeterministicChoiceIndices [ index +  1 ] ;  + + row )  {  
			
		
	
		
			
				
									( * resultVector )  [ currentRowCount + + ]  =  getConstrainedRowSum ( row ,  columnConstraint ) ;  
			
		
	
		
			
				
							for  ( auto  rowGroup :  rowGroup Constraint )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  row  =  rowGroupIndices [ rowGroup ] ;  row  <  rowGroupIndices [ rowGroup +  1 ] ;  + + row )  {  
			
		
	
		
			
				
									result [ currentRowCount + + ]  =  getConstrainedRowSum ( row ,  columnConstraint ) ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							return  result ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Creates  a  sub - matrix  of  the  current  matrix  by  dropping  all  rows  and  
			
		
	
		
			
				
						 *  columns  whose  bits  are  not  set  to  one  in  the  given  bit  vector .  
			
		
	
		
			
				
						 *  @ param  constraint  A  bit  vector  indicating  which  rows  and  columns  to  drop .  
			
		
	
		
			
				
						 *  @ return  A  pointer  to  a  sparse  matrix  that  is  a  sub - matrix  of  the  current  one .  
			
		
	
		
			
				
						 *  Creates  a  submatrix  of  the  current  matrix  by  dropping  all  rows  and  columns  whose  bits  are  not  
			
		
	
		
			
				
						 *  set  to  one  in  the  given  bit  vector .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  constraint  A  bit  vector  indicating  which  rows  and  columns  to  keep .  
			
		
	
		
			
				
						 *  @ returns  A  matrix  corresponding  to  a  submatrix  of  the  current  matrix  in  which  only  rows  and  
			
		
	
		
			
				
						 *  columns  given  by  the  constraint  are  kept  and  all  others  are  dropped .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						SparseMatrix *  getSubmatrix ( storm : : storage : : BitVector &  constraint )  const  {  
			
		
	
		
			
				
						SparseMatrix  getSubmatrix ( storm : : storage : : BitVector  const  &  constraint )  const  {  
			
		
	
		
			
				
							LOG4CPLUS_DEBUG ( logger ,  " Creating a sub-matrix with  "  < <  constraint . getNumberOfSetBits ( )  < <  "  rows. " ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Check  for  valid  constraint .  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -622,8 +643,8 @@ public: 
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Create  and  initialize  resulting  matrix .  
			
		
	
		
			
				
							SparseMatrix * result  =  new  SparseMatrix  ( constraint . getNumberOfSetBits ( ) ) ;  
			
		
	
		
			
				
							result - > initialize ( subNonZeroEntries ) ;  
			
		
	
		
			
				
							SparseMatrix  result ( constraint . getNumberOfSetBits ( ) ) ;  
			
		
	
		
			
				
							result . initialize ( subNonZeroEntries ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Create  a  temporary  array  that  stores  for  each  index  whose  bit  is  set  
			
		
	
		
			
				
							/ /  to  true  the  number  of  bits  that  were  set  before  that  particular  index .  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -642,7 +663,7 @@ public: 
			
		
	
		
			
				
							for  ( auto  rowIndex  :  constraint )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  i  =  rowIndications [ rowIndex ] ;  i  <  rowIndications [ rowIndex  +  1 ] ;  + + i )  {  
			
		
	
		
			
				
									if  ( constraint . get ( columnIndications [ i ] ) )  {  
			
		
	
		
			
				
										result - > addNextValue ( rowCount ,  bitsSetBeforeIndex [ columnIndications [ i ] ] ,  valueStorage [ i ] ) ;  
			
		
	
		
			
				
										result . addNextValue ( rowCount ,  bitsSetBeforeIndex [ columnIndications [ i ] ] ,  valueStorage [ i ] ) ;  
			
		
	
		
			
				
									}  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
					
 
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -653,47 +674,50 @@ public: 
			
		
	
		
			
				
							delete [ ]  bitsSetBeforeIndex ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Finalize  sub - matrix  and  return  result .  
			
		
	
		
			
				
							result - > finalize ( ) ;  
			
		
	
		
			
				
							result . finalize ( ) ;  
			
		
	
		
			
				
							LOG4CPLUS_DEBUG ( logger ,  " Done creating sub-matrix. " ) ;  
			
		
	
		
			
				
							return  result ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						SparseMatrix *  getSubmatrix ( storm : : storage : : BitVector &  constraint ,  std : : vector < uint_fast64_t >  const &  rowIndices )  const  {  
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Creates  a  submatrix  of  the  current  matrix  by  keeping  only  row  groups  and  columns  in  the  given  
			
		
	
		
			
				
						 *  row  group  constraint .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  rowGroupConstraint  A  bit  vector  indicating  which  row  groups  and  columns  to  keep .  
			
		
	
		
			
				
						 *  @ param  rowGroupIndices  A  vector  indicating  which  rows  belong  to  a  given  row  group .  
			
		
	
		
			
				
						 *  @ returns  A  matrix  corresponding  to  a  submatrix  of  the  current  matrix  in  which  only  row  groups  
			
		
	
		
			
				
						 *  and  columns  given  by  the  row  group  constraint  are  kept  and  all  others  are  dropped .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						SparseMatrix  getSubmatrix ( storm : : storage : : BitVector  const &  rowGroupConstraint ,  std : : vector < uint_fast64_t >  const &  rowGroupIndices )  const  {  
			
		
	
		
			
				
							LOG4CPLUS_DEBUG ( logger ,  " Creating a sub-matrix (of unknown size). " ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Check  for  valid  constraint .  
			
		
	
		
			
				
							if  ( constraint . getNumberOfSetBits ( )  = =  0 )  {  
			
		
	
		
			
				
								LOG4CPLUS_ERROR ( logger ,  " Trying to create a sub-matrix of size 0. " ) ;  
			
		
	
		
			
				
								throw  storm : : exceptions : : InvalidArgumentException ( " Trying to create a sub-matrix of size 0. " ) ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  First ,  we  need  to  determine  the  number  of  non - zero  entries  and  the  number  of  rows  of  the  
			
		
	
		
			
				
							/ /  sub - matrix .  
			
		
	
		
			
				
							uint_fast64_t  subNonZeroEntries  =  0 ;  
			
		
	
		
			
				
							uint_fast64_t  subRowCount  =  0 ;  
			
		
	
		
			
				
							for  ( auto  index  :  c onstraint)  {  
			
		
	
		
			
				
								subRowCount  + =  rowIndices [ index  +  1 ]  -  rowIndices [ index ] ;  
			
		
	
		
			
				
								for  ( uint_fast64_t  i  =  rowIndices [ index ] ;  i  <  rowIndices [ index  +  1 ] ;  + + i )  {  
			
		
	
		
			
				
							for  ( auto  index  :  rowGroupConstraint )  {  
			
		
	
		
			
				
								subRowCount  + =  rowGroupIndices [ index  +  1 ]  -  rowGroupIndices [ index ] ;  
			
		
	
		
			
				
								for  ( uint_fast64_t  i  =  rowGroup Indices [ index ] ;  i  <  rowGroup Indices [ index  +  1 ] ;  + + i )  {  
			
		
	
		
			
				
									for  ( uint_fast64_t  j  =  rowIndications [ i ] ;  j  <  rowIndications [ i  +  1 ] ;  + + j )  {  
			
		
	
		
			
				
										if  ( c onstraint. get ( columnIndications [ j ] ) )  {  
			
		
	
		
			
				
										if  ( rowGroupC onstraint. get ( columnIndications [ j ] ) )  {  
			
		
	
		
			
				
											+ + subNonZeroEntries ;  
			
		
	
		
			
				
										}  
			
		
	
		
			
				
									}  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							LOG4CPLUS_DEBUG ( logger ,  " Determined size of submatrix to be  "  < <  subRowCount  < <  " x "  < <  c onstraint. getNumberOfSetBits ( )  < <  " . " ) ;  
			
		
	
		
			
				
							LOG4CPLUS_DEBUG ( logger ,  " Determined size of submatrix to be  "  < <  subRowCount  < <  " x "  < <  rowGroupC onstraint. getNumberOfSetBits ( )  < <  " . " ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Create  and  initialize  resulting  matrix .  
			
		
	
		
			
				
							SparseMatrix * result  =  new  SparseMatrix  ( subRowCount ,  c onstraint. getNumberOfSetBits ( ) ) ;  
			
		
	
		
			
				
							result - > initialize ( subNonZeroEntries ) ;  
			
		
	
		
			
				
							SparseMatrix  result ( subRowCount ,  rowGroupC onstraint. getNumberOfSetBits ( ) ) ;  
			
		
	
		
			
				
							result . initialize ( subNonZeroEntries ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Create  a  temporary  array  that  stores  for  each  index  whose  bit  is  set  
			
		
	
		
			
				
							/ /  to  true  the  number  of  bits  that  were  set  before  that  particular  index .  
			
		
	
		
			
				
							uint_fast64_t *  bitsSetBeforeIndex  =  new  uint_fast64_t [ colCount ] ;  
			
		
	
		
			
				
							uint_fast64_t  lastIndex  =  0 ;  
			
		
	
		
			
				
							uint_fast64_t  currentNumberOfSetBits  =  0 ;  
			
		
	
		
			
				
							for  ( auto  index  :  constraint )  {  
			
		
	
		
			
				
							for  ( auto  index  :  rowGroupIndices )  {  
			
		
	
		
			
				
								while  ( lastIndex  < =  index )  {  
			
		
	
		
			
				
									bitsSetBeforeIndex [ lastIndex + + ]  =  currentNumberOfSetBits ;  
			
		
	
		
			
				
								}  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -702,11 +726,11 @@ public: 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Copy  over  selected  entries .  
			
		
	
		
			
				
							uint_fast64_t  rowCount  =  0 ;  
			
		
	
		
			
				
							for  ( auto  index  :  constraint )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  i  =  rowIndices [ index ] ;  i  <  rowIndices [ index  +  1 ] ;  + + i )  {  
			
		
	
		
			
				
							for  ( auto  index  :  rowGroupIndices )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  i  =  rowGroup Indices [ index ] ;  i  <  rowGroup Indices [ index  +  1 ] ;  + + i )  {  
			
		
	
		
			
				
									for  ( uint_fast64_t  j  =  rowIndications [ i ] ;  j  <  rowIndications [ i  +  1 ] ;  + + j )  {  
			
		
	
		
			
				
										if  ( c onstraint. get ( columnIndications [ j ] ) )  {  
			
		
	
		
			
				
											result - > addNextValue ( rowCount ,  bitsSetBeforeIndex [ columnIndications [ j ] ] ,  valueStorage [ j ] ) ;  
			
		
	
		
			
				
										if  ( rowGroupC onstraint. get ( columnIndications [ j ] ) )  {  
			
		
	
		
			
				
											result . addNextValue ( rowCount ,  bitsSetBeforeIndex [ columnIndications [ j ] ] ,  valueStorage [ j ] ) ;  
			
		
	
		
			
				
										}  
			
		
	
		
			
				
									}  
			
		
	
		
			
				
									+ + rowCount ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -717,11 +741,16 @@ public: 
			
		
	
		
			
				
							delete [ ]  bitsSetBeforeIndex ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Finalize  sub - matrix  and  return  result .  
			
		
	
		
			
				
							result - > finalize ( ) ;  
			
		
	
		
			
				
							result . finalize ( ) ;  
			
		
	
		
			
				
							LOG4CPLUS_DEBUG ( logger ,  " Done creating sub-matrix. " ) ;  
			
		
	
		
			
				
							return  result ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Performs  a  change  to  the  matrix  that  is  needed  if  this  matrix  is  to  be  interpreted  as  a  
			
		
	
		
			
				
						 *  set  of  linear  equations .  In  particular ,  it  transforms  A  to  ( 1 - A ) ,  meaning  that  the  elements  
			
		
	
		
			
				
						 *  on  the  diagonal  are  inverted  with  respect  to  addition  and  the  other  elements  are  negated .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						void  convertToEquationSystem ( )  {  
			
		
	
		
			
				
							invertDiagonal ( ) ;  
			
		
	
		
			
				
							negateAllNonDiagonalElements ( ) ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -729,28 +758,34 @@ public: 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Inverts  all  elements  on  the  diagonal ,  i . e .  sets  the  diagonal  values  to  1  minus  their  previous  
			
		
	
		
			
				
						 *  value .  
			
		
	
		
			
				
						 *  Requires  the  matrix  to  contain  each  diagonal  element  AND  to  be  square !  
			
		
	
		
			
				
						 *  value .  Requires  the  matrix  to  contain  each  diagonal  element  and  to  be  square .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						void  invertDiagonal ( )  {  
			
		
	
		
			
				
							/ /  Check  if  the  matrix  is  square ,  because  only  then  it  makes  sense  to  perform  this  
			
		
	
		
			
				
							/ /  transformation .  
			
		
	
		
			
				
							if  ( this - > getRowCount ( )  ! =  this - > getColumnCount ( ) )  {  
			
		
	
		
			
				
								throw  storm : : exceptions : : InvalidArgumentException ( )  < <  " SparseMatrix::invertDiagonal requires the Matrix to be square! " ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							 
			
		
	
		
			
				
							/ /  Now  iterate  over  all  rows  and  set  the  diagonal  elements  to  the  inverted  value .  
			
		
	
		
			
				
							/ /  If  there  is  a  row  without  the  diagonal  element ,  an  exception  is  thrown .  
			
		
	
		
			
				
							T  one  =  storm : : utility : : constGetOne < T > ( ) ;  
			
		
	
		
			
				
							bool  foundRow ;  
			
		
	
		
			
				
							bool  foundDiagonalElement  =  false  ;  
			
		
	
		
			
				
							for  ( uint_fast64_t  row  =  0 ;  row  <  rowCount ;  + + row )  {  
			
		
	
		
			
				
								uint_fast64_t  rowStart  =  rowIndications [ row ] ;  
			
		
	
		
			
				
								uint_fast64_t  rowEnd  =  rowIndications [ row  +  1 ] ;  
			
		
	
		
			
				
								foundRow   =  false ;  
			
		
	
		
			
				
								foundDiagonalElement   =  false ;  
			
		
	
		
			
				
								while  ( rowStart  <  rowEnd )  {  
			
		
	
		
			
				
									if  ( columnIndications [ rowStart ]  = =  row )  {  
			
		
	
		
			
				
										valueStorage [ rowStart ]  =  one  -  valueStorage [ rowStart ] ;  
			
		
	
		
			
				
										foundRow   =  true ;  
			
		
	
		
			
				
										foundDiagonalElement   =  true ;  
			
		
	
		
			
				
										break ;  
			
		
	
		
			
				
									}  
			
		
	
		
			
				
									+ + rowStart ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
								if  ( ! foundRow )  {  
			
		
	
		
			
				
								 
			
		
	
		
			
				
								/ /  Throw  an  exception  if  a  row  did  not  have  an  element  on  the  diagonal .  
			
		
	
		
			
				
								if  ( ! foundDiagonalElement )  {  
			
		
	
		
			
				
									throw  storm : : exceptions : : InvalidArgumentException ( )  < <  " SparseMatrix::invertDiagonal requires the Matrix to contain all diagonal entries! " ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -760,9 +795,13 @@ public: 
			
		
	
		
			
				
						 *  Negates  all  non - zero  elements  that  are  not  on  the  diagonal .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						void  negateAllNonDiagonalElements ( )  {  
			
		
	
		
			
				
							/ /  Check  if  the  matrix  is  square ,  because  only  then  it  makes  sense  to  perform  this  
			
		
	
		
			
				
							/ /  transformation .  
			
		
	
		
			
				
							if  ( this - > getRowCount ( )  ! =  this - > getColumnCount ( ) )  {  
			
		
	
		
			
				
								throw  storm : : exceptions : : InvalidArgumentException ( )  < <  " SparseMatrix::invertDiagonal requires the Matrix to be square! " ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							 
			
		
	
		
			
				
							/ /  Iterate  over  all  rows  and  negate  all  the  elements  that  are  not  on  the  diagonal .  
			
		
	
		
			
				
							for  ( uint_fast64_t  row  =  0 ;  row  <  rowCount ;  + + row )  {  
			
		
	
		
			
				
								uint_fast64_t  rowStart  =  rowIndications [ row ] ;  
			
		
	
		
			
				
								uint_fast64_t  rowEnd  =  rowIndications [ row  +  1 ] ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -784,7 +823,7 @@ public: 
			
		
	
		
			
				
							uint_fast64_t  rowCount  =  this - > getRowCount ( ) ;  
			
		
	
		
			
				
							uint_fast64_t  colCount  =  this - > getColumnCount ( ) ;  
			
		
	
		
			
				
							if  ( rowCount  ! =  colCount )  {  
			
		
	
		
			
				
								throw  storm : : exceptions : : InvalidArgumentException ( )  < <  " SparseMatrix::getJacobiDecomposition requires the Matrix to be square!  " ;  
			
		
	
		
			
				
								throw  storm : : exceptions : : InvalidArgumentException ( )  < <  " SparseMatrix::getJacobiDecomposition requires the Matrix to be square.  " ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							storm : : storage : : SparseMatrix < T >  * resultLU  =  new  storm : : storage : : SparseMatrix < T > ( * this ) ;  
			
		
	
		
			
				
							storm : : storage : : SparseMatrix < T >  * resultDinv  =  new  storm : : storage : : SparseMatrix < T > ( rowCount ,  colCount ) ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -806,15 +845,16 @@ public: 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Performs  a  pointwise  matrix  multiplication  of  the  matrix  with  the  given  matrix  and  returns  a  
			
		
	
		
			
				
						 *  vector  containing  the  sum  of  the  elements  in  each  row  of  the  resulting  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  otherMatrix  A  reference  to  the  matrix  with  which  to  perform  the  pointwise  multiplication .  
			
		
	
		
			
				
						 *  This  matrix  must  be  a  submatrix  of  the  current  matrix  in  the  sense  that  it  may  not  have  
			
		
	
		
			
				
						 *  non - zero  entries  at  indices  where  there  is  a  zero  in  the  current  matrix .  
			
		
	
		
			
				
						 *  @ return A  vector  containing  the  sum  of  the  elements  in  each  row  of  the  matrix  resulting  from  
			
		
	
		
			
				
						 *  @ returns A  vector  containing  the  sum  of  the  elements  in  each  row  of  the  matrix  resulting  from  
			
		
	
		
			
				
						 *  pointwise  multiplication  of  the  current  matrix  with  the  given  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						std : : vector < T > * getPointwiseProductRowSumVector ( storm : : storage : : SparseMatrix < T >  const &  otherMatrix )  {  
			
		
	
		
			
				
						std : : vector < T >  getPointwiseProductRowSumVector ( storm : : storage : : SparseMatrix < T >  const &  otherMatrix )  {  
			
		
	
		
			
				
							/ /  Prepare  result .  
			
		
	
		
			
				
							std : : vector < T > * result  =  new  std : : vector < T >  ( rowCount ,  storm : : utility : : constGetZero < T > ( ) ) ;  
			
		
	
		
			
				
							std : : vector < T >  result ( rowCount ,  storm : : utility : : constGetZero < T > ( ) ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Iterate  over  all  elements  of  the  current  matrix  and  either  continue  with  the  next  element  
			
		
	
		
			
				
							/ /  in  case  the  given  matrix  does  not  have  a  non - zero  element  at  this  column  position ,  or  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -827,7 +867,7 @@ public: 
			
		
	
		
			
				
										/ /  If  the  precondition  of  this  method  ( i . e .  that  the  given  matrix  is  a  submatrix  
			
		
	
		
			
				
										/ /  of  the  current  one )  was  fulfilled ,  we  know  now  that  the  two  elements  are  in  
			
		
	
		
			
				
										/ /  the  same  column ,  so  we  can  multiply  and  add  them  to  the  row  sum  vector .  
			
		
	
		
			
				
										( * result ) [ row ]  + =  otherMatrix . valueStorage [ nextOtherElement ]  *  valueStorage [ element ] ;  
			
		
	
		
			
				
										result [ row ]  + =  otherMatrix . valueStorage [ nextOtherElement ]  *  valueStorage [ element ] ;  
			
		
	
		
			
				
										+ + nextOtherElement ;  
			
		
	
		
			
				
									}  
			
		
	
		
			
				
								}  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -835,84 +875,39 @@ public: 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							return  result ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						T  multiplyRowWithVector ( constRowsIterator &  rowsIt ,  uint_fast64_t  rowsIte ,  std : : vector < T > &  vector )  const  {  
			
		
	
		
			
				
							T  result  =  storm : : utility : : constGetZero < T > ( ) ;  
			
		
	
		
			
				
							for  ( ;  rowsIt  ! =  rowsIte ;  + + rowsIt )  {  
			
		
	
		
			
				
								result  + =  ( rowsIt . value ( ) )  *  vector [ rowsIt . column ( ) ] ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							return  result ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						void  multiplyWithVector ( std : : vector < T > &  vector ,  std : : vector < T > &  result )  const  {  
			
		
	
		
			
				
							typename  std : : vector < T > : : iterator  resultIt  =  result . begin ( ) ;  
			
		
	
		
			
				
							typename  std : : vector < T > : : iterator  resultIte  =  result . end ( ) ;  
			
		
	
		
			
				
							constRowsIterator  rowIt  =  this - > constRowsIteratorBegin ( ) ;  
			
		
	
		
			
				
							uint_fast64_t  nextRow  =  1 ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							for  ( ;  resultIt  ! =  resultIte ;  + + resultIt ,  + + nextRow )  {  
			
		
	
		
			
				
								* resultIt  =  multiplyRowWithVector ( rowIt ,  this - > rowIndications [ nextRow ] ,  vector ) ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						void  multiplyWithVectorInPlace ( std : : vector < T > &  vector )  const  {  
			
		
	
		
			
				
							typename  std : : vector < T > : : iterator  resultIt  =  vector . begin ( ) ;  
			
		
	
		
			
				
							typename  std : : vector < T > : : iterator  resultIte  =  vector . end ( ) ;  
			
		
	
		
			
				
							constRowsIterator  rowIt  =  this - > constRowsIteratorBegin ( ) ;  
			
		
	
		
			
				
							uint_fast64_t  nextRow  =  1 ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							for  ( ;  resultIt  ! =  resultIte ;  + + resultIt ,  + + nextRow )  {  
			
		
	
		
			
				
								* resultIt  =  multiplyRowWithVector ( rowIt ,  this - > rowIndications [ nextRow ] ,  vector ) ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						void  multiplyWithVector ( std : : vector < uint_fast64_t >  const &  states ,  std : : vector < uint_fast64_t >  const &  nondeterministicChoiceIndices ,  std : : vector < T > &  vector ,  std : : vector < T > &  result )  const  {  
			
		
	
		
			
				
							constRowsIterator  rowsIt  =  this - > constRowsIteratorBegin ( ) ;  
			
		
	
		
			
				
							uint_fast64_t  nextRow  =  1 ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							for  ( auto  stateIt  =  states . cbegin ( ) ,  stateIte  =  states . cend ( ) ;  stateIt  ! =  stateIte ;  + + stateIt )  {  
			
		
	
		
			
				
								rowsIt . setOffset ( this - > rowIndications [ nondeterministicChoiceIndices [ * stateIt ] ] ) ;  
			
		
	
		
			
				
								nextRow  =  nondeterministicChoiceIndices [ * stateIt ]  +  1 ;  
			
		
	
		
			
				
								for  ( auto  rowIt  =  nondeterministicChoiceIndices [ * stateIt ] ,  rowIte  =  nondeterministicChoiceIndices [ * stateIt  +  1 ] ;  rowIt  ! =  rowIte ;  + + rowIt ,  + + nextRow )  {  
			
		
	
		
			
				
									result [ rowIt ]  =  multiplyRowWithVector ( rowsIt ,  this - > rowIndications [ nextRow ] ,  vector ) ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						void  multiplyWithVectorInPlace ( std : : vector < uint_fast64_t >  const &  states ,  std : : vector < uint_fast64_t >  const &  nondeterministicChoiceIndices ,  std : : vector < T > &  vector )  const  {  
			
		
	
		
			
				
							constRowsIterator  rowsIt  =  this - > constRowsIteratorBegin ( ) ;  
			
		
	
		
			
				
							uint_fast64_t  nextRow  =  1 ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							for  ( auto  stateIt  =  states . cbegin ( ) ,  stateIte  =  states . cend ( ) ;  stateIt  ! =  stateIte ;  + + stateIt )  {  
			
		
	
		
			
				
								rowsIt . setOffset ( this - > rowIndications [ nondeterministicChoiceIndices [ * stateIt ] ] ) ;  
			
		
	
		
			
				
								nextRow  =  nondeterministicChoiceIndices [ * stateIt ]  +  1 ;  
			
		
	
		
			
				
								for  ( auto  rowIt  =  nondeterministicChoiceIndices [ * stateIt ] ,  rowIte  =  nondeterministicChoiceIndices [ * stateIt  +  1 ] ;  rowIt  ! =  rowIte ;  + + rowIt ,  + + nextRow )  {  
			
		
	
		
			
				
									vector [ rowIt ]  =  multiplyRowWithVector ( rowsIt ,  this - > rowIndications [ nextRow ] ,  vector ) ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						void  multiplyAddAndReduceInPlace ( std : : vector < uint_fast64_t >  const &  nondeterministicChoiceIndices ,  std : : vector < T > &  vector ,  std : : vector < T >  const &  summand ,  bool  minimize )  const  {  
			
		
	
		
			
				
							constRowsIterator  rowsIt  =  this - > constRowsIteratorBegin ( ) ;  
			
		
	
		
			
				
							uint_fast64_t  nextRow  =  1 ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							for  ( uint_fast64_t  stateIt  =  0 ,  stateIte  =  nondeterministicChoiceIndices . size ( )  -  1 ;  stateIt  <  stateIte ;  + + stateIt )  {  
			
		
	
		
			
				
								vector [ stateIt ]  =  multiplyRowWithVector ( rowsIt ,  this - > rowIndications [ nextRow ] ,  vector )  +  summand [ nondeterministicChoiceIndices [ stateIt ] ] ;  
			
		
	
		
			
				
								+ + nextRow ;  
			
		
	
		
			
				
								for  ( uint_fast64_t  rowIt  =  nondeterministicChoiceIndices [ stateIt ]  +  1 ,  rowIte  =  nondeterministicChoiceIndices [ stateIt  +  1 ] ;  rowIt  ! =  rowIte ;  + + rowIt ,  + + nextRow )  {  
			
		
	
		
			
				
									T  value  =  multiplyRowWithVector ( rowsIt ,  this - > rowIndications [ nextRow ] ,  vector )  +  summand [ rowIt ] ;  
			
		
	
		
			
				
									if  ( minimize  & &  value  <  vector [ stateIt ] )  {  
			
		
	
		
			
				
										vector [ stateIt ]  =  value ;  
			
		
	
		
			
				
									}  else  if  ( ! minimize  & &  value  >  vector [ stateIt ] )  {  
			
		
	
		
			
				
										vector [ stateIt ]  =  value ;  
			
		
	
		
			
				
									}  
			
		
	
		
			
				
						 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Multiplies  the  matrix  with  the  given  vector  and  writes  the  result  to  given  result  vector .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  vector  The  vector  with  which  to  multiply  the  matrix .  
			
		
	
		
			
				
						 *  @ param  result  The  vector  that  is  supposed  to  hold  the  result  of  the  multiplication  after  the  
			
		
	
		
			
				
						 *  operation .  
			
		
	
		
			
				
						 *  @ returns  The  product  of  the  matrix  and  the  given  vector  as  the  content  of  the  given  result  
			
		
	
		
			
				
						 *  vector .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						void  multiplyWithVector ( std : : vector < T >  const &  vector ,  std : : vector < T > &  result )  const  {  
			
		
	
		
			
				
							/ /  Initialize  two  iterators  that   
			
		
	
		
			
				
							ConstRowsIterator  elementIt ( * this ) ;  
			
		
	
		
			
				
							ConstRowsIterator  elementIte ( * this ,  1 ) ;  
			
		
	
		
			
				
							 
			
		
	
		
			
				
							/ /  Iterate  over  all  positions  of  the  result  vector  and  compute  its  value  as  the  scalar  
			
		
	
		
			
				
							/ /  product  of  the  corresponding  row  with  the  input  vector .  
			
		
	
		
			
				
							/ /  Note  that  only  the  end  iterator  has  to  be  moved  by  one  row ,  because  the  other  iterator  
			
		
	
		
			
				
							/ /  is  automatically  moved  forward  one  row  by  the  inner  loop .  
			
		
	
		
			
				
							for  ( uint_fast64_t  i  =  0 ;  i  <  result . size ( ) ;  + + i ,  elementIte . moveToNextRow ( ) )  {  
			
		
	
		
			
				
								result [ i ]  =  storm : : utility : : constGetZero < T > ( ) ;  
			
		
	
		
			
				
								 
			
		
	
		
			
				
								/ /  Perform  the  scalar  product .  
			
		
	
		
			
				
								for  ( ;  elementIt  ! =  elementIte ;  + + elementIt )  {  
			
		
	
		
			
				
									result [ i ]  + =  elementIt . value ( )  *  vector [ elementIt . column ( ) ] ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  the  size  of  the  matrix  in  memory  measured  in  bytes .  
			
		
	
		
			
				
						 *  @ return  The  size  of  the  matrix  in  memory  measured  in  bytes .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  The  size  of  the  matrix  in  memory  measured  in  bytes .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						uint_fast64_t  getSizeInMemory ( )  const  {  
			
		
	
		
			
				
							uint_fast64_t  size  =  sizeof ( * this ) ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -925,87 +920,122 @@ public: 
			
		
	
		
			
				
							return  size ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						constRowsIterator  constRowsIteratorBegin ( )  const  {  
			
		
	
		
			
				
							return  constRowsIterator ( * this ) ;  
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  a  const  iterator  to  the  elements  of  the  matrix .  
			
		
	
		
			
				
						 *  @ param  row  If  given ,  this  specifies  the  starting  row  of  the  iterator .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  An  iterator  to  the  elements  of  the  matrix  that  cannot  be  used  for  modifying  the  
			
		
	
		
			
				
						 *  contents .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						ConstRowsIterator  begin ( uint_fast64_t  row  =  0 )  const  {  
			
		
	
		
			
				
							return  ConstRowsIterator ( * this ,  row ) ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
						 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  a  const  iterator  that  points  to  the  first  element  after  the  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  A  const  iterator  that  points  past  the  last  element  of  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						ConstRowsIterator  end ( )  const  {  
			
		
	
		
			
				
							return  ConstRowsIterator ( this - > rowCount ) ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
						 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  a  const  iterator  that  points  to  the  first  element  after  the  given  row .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  row  The  row  past  which  this  iterator  has  to  point .  
			
		
	
		
			
				
						 *  @ returns  A  const  iterator  that  points  to  the  first  element  after  the  given  row .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						ConstRowsIterator  end ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
							return  ConstRowsIterator ( row  +  1 ) ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  an  iterator  to  the  columns  of  the  non - zero  entries  of  the  given  
			
		
	
		
			
				
						 *  row .  
			
		
	
		
			
				
						 *  @ param  row  The  row  whose  columns  the  iterator  will  return .  
			
		
	
		
			
				
						 *  @ return  An  iterator  to  the  columns  of  the  non - zero  entries  of  the  given  
			
		
	
		
			
				
						 *  row .  
			
		
	
		
			
				
						 *  Returns  an  iterator  to  the  columns  of  the  non - zero  entries  of  the  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  row  If  given ,  the  iterator  will  start  at  the  specified  row .  
			
		
	
		
			
				
						 *  @ returns  An  iterator  to  the  columns  of  the  non - zero  entries  of  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						constIndexIterator  beginConstColumnIterator ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
						ConstIndexIterator  constColumnIteratorBegin ( uint_fast64_t  row  =  0  )  const  {  
			
		
	
		
			
				
							return  & ( this - > columnIndications [ 0 ] )  +  this - > rowIndications [ row ] ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  an  iterator  referring  to  the  element  after  the  given  row .  
			
		
	
		
			
				
						 *  @ param  row  The  row  for  which  the  iterator  should  point  to  the  past - the - end  
			
		
	
		
			
				
						 *  element .  
			
		
	
		
			
				
						 *  Returns  an  iterator  that  points to  the  first   element  after  the  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  An  iterator  that  points  to  the  first  element  after  the  matrix  .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						constIndexIterator  endConstColumnIterator ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
							return  & ( this - > columnIndications [ 0 ] )  +  this - > rowIndications [ row  +  1 ] ;  
			
		
	
		
			
				
						ConstIndexIterator  constColumnIteratorEnd ( )  const  {  
			
		
	
		
			
				
							return  & ( this - > columnIndications [ 0 ] )  +  this - > rowIndications [ rowCount  ] ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						  
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 * 	Returns  an  iterator  over  the  elements  of  the  given  row .  The  iterator  
			
		
	
		
			
				
						 * 	will  include  no  zero  entries .  
			
		
	
		
			
				
						 * 	@ param  row  The  row  whose  elements  the  iterator  will  return .  
			
		
	
		
			
				
						 * 	@ return  An  iterator  over  the  elements  of  the  given  row  .  
			
		
	
		
			
				
						 *   Returns  an  iterator  that  points  to  the  first  element  after  the  given  row .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *   @ param  row  The  row  past  which  this  iterator  has  to  point .  
			
		
	
		
			
				
						 *  @ returns  An  iterator  that  points  to  the  first  element  after  the  matrix  .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						constIterator  beginConstIterator ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
						ConstIndexIterator  constColumnIteratorEnd ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
							return  & ( this - > columnIndications [ 0 ] )  +  this - > rowIndications [ row ] ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
						 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Returns  an  iterator  to  the  values  of  the  non - zero  entries  of  the  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  row  If  given ,  the  iterator  will  start  at  the  specified  row .  
			
		
	
		
			
				
						 *  @ returns  An  iterator  to  the  values  of  the  non - zero  entries  of  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						ConstValueIterator  constValueIteratorBegin ( uint_fast64_t  row  =  0 )  const  {  
			
		
	
		
			
				
							return  & ( this - > valueStorage [ 0 ] )  +  this - > rowIndications [ row ] ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
						 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 * 	Returns  an  iterator  pointing  to  the  first  element  after  the  given  
			
		
	
		
			
				
						 * 	row .  
			
		
	
		
			
				
						 * 	@ param  row  The  row  for  which  the  iterator  should  point  to  the  
			
		
	
		
			
				
						 * 	past - the - end  element .  
			
		
	
		
			
				
						 * 	@ return  An  iterator  to  the  element  after  the  given  row .  
			
		
	
		
			
				
						 *  Returns  an  iterator  that  points  to  the  first  element  after  the  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  An  iterator  that  points  to  the  first  element  after  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						constIterator  endConstIterator ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
							return  & ( this - > valueStorage [ 0 ] )  +  this - > rowIndications [ row  +  1  ] ;  
			
		
	
		
			
				
						ConstValueIterator  constValueIteratorEnd ( )  const  {  
			
		
	
		
			
				
							return  & ( this - > valueStorage [ 0 ] )  +  this - > rowIndications [ rowCount  ] ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
  
			
		
	
		
			
				
						  
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 * 	@ brief  Calculate  sum  of  all  entries  in   given  row .  
			
		
	
		
			
				
						 *  Returns  an  iterator  that  points  to  the  first  element  after  the   given  row .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 * 	Adds  up  all  values  in  the  given  row  
			
		
	
		
			
				
						 * 	and  returns  the  sum .  
			
		
	
		
			
				
						 * 	@ param  row  The  row  that  should  be  added  up .  
			
		
	
		
			
				
						 * 	@ return  Sum  of  the  row .  
			
		
	
		
			
				
						 *  @ param  row  The  row  past  which  this  iterator  has  to  point .  
			
		
	
		
			
				
						 *  @ returns  An  iterator  that  points  to  the  first  element  after  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						ConstValueIterator  constValueIteratorEnd ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
							return  & ( this - > valueStorage [ 0 ] )  +  this - > rowIndications [ row ] ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
						 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Computes  the  sum  of  the  elements  in  a  given  row .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  row  The  row  that  should  be  summed .  
			
		
	
		
			
				
						 *  @ return  Sum  of  the  row .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						T  getRowSum ( uint_fast64_t  row )  const  {  
			
		
	
		
			
				
							T  sum  =  storm : : utility : : constGetZero < T > ( ) ;  
			
		
	
		
			
				
							for  ( auto  it  =  this - > beginConstIterator ( row ) ;  it  ! =  this - > endConstIterator ( row ) ;  it + + )  {  
			
		
	
		
			
				
							for  ( auto  it  =  this - > constValueIteratorBegin ( row ) ,  ite  =  this - > constValueIteratorEnd ( row ) ;  it  ! =  ite ;   + + it )  {  
			
		
	
		
			
				
								sum  + =  * it ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							return  sum ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 * 	@ brief  Checks  if  it  is  a  submatrix  of  the  given  matrix .  
			
		
	
		
			
				
						 *  Checks  if  the  given  matrix  is  a  submatrix  of  the  current  matrix ,  where  A  matrix  A  is  called  a  
			
		
	
		
			
				
						 *  submatrix  of  B  if  a  value  in  A  is  only  nonzero ,  if  the  value  in  B  at  the  same  position  is  
			
		
	
		
			
				
						 *  also  nonzero .  Furthermore ,  A  and  B  have  to  have  the  same  size .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 * 	A  matrix  A  is  a  submatrix  of  B  if  a  value  in  A  is  only  nonzero ,  if  
			
		
	
		
			
				
						 * 	the  value  in  B  at  the  same  position  is  also  nonzero .  Furthermore ,  A  
			
		
	
		
			
				
						 * 	and  B  have  to  have  the  same  size .  
			
		
	
		
			
				
						 * 	@ param  matrix  Matrix  to  check  against .  
			
		
	
		
			
				
						 * 	@ return  True  iff  this  is  a  submatrix  of  matrix .  
			
		
	
		
			
				
						 *  @ param  matrix  The  matrix  that  is  possibly  a  submatrix  of  the  current  matrix .  
			
		
	
		
			
				
						 *  @ returns  True  iff  the  given  matrix  is  a  submatrix  of  the  current  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						bool  isSubmatrixOf ( SparseMatrix < T >  const &  matrix )  const  {  
			
		
	
		
			
				
						bool  containsAllPositionsOf ( SparseMatrix < T >  const &  matrix )  const  {  
			
		
	
		
			
				
							/ /  Check  for  mismatching  sizes .  
			
		
	
		
			
				
							if  ( this - > getRowCount ( )  ! =  matrix . getRowCount ( ) )  return  false ;  
			
		
	
		
			
				
							if  ( this - > getColumnCount ( )  ! =  matrix . getColumnCount ( ) )  return  false ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/*  
			
		
	
		
			
				
							for  ( uint_fast64_t  row  =  0 ;  row  <  this - > getRowCount ( ) ;  + + row )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  elem  =  rowIndications [ row ] ,  elem2  =  matrix . rowIndications [ row ] ;  elem  <  rowIndications [ row  +  1 ]  & &  elem  <  matrix . rowIndications [ row  +  1 ] ;  + + elem ,  + + elem2 )  {  
			
		
	
		
			
				
									if  ( columnIndications [ elem ]  <  matrix . columnIndications [ elem2 ] )  return  false ;  
			
		
	
		
			
				
								}  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
							*/  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
							/ /  Check  the  subset  property  for  all  rows  individually .  
			
		
	
		
			
				
							for  ( uint_fast64_t  row  =  0 ;  row  <  this - > getRowCount ( ) ;  + + row )  {  
			
		
	
		
			
				
								for  ( uint_fast64_t  elem  =  rowIndications [ row ] ,  elem2  =  matrix . rowIndications [ row ] ;  elem  <  rowIndications [ row  +  1 ]  & &  elem  <  matrix . rowIndications [ row  +  1 ] ;  + + elem )  {  
			
		
	
		
			
				
									/ /  Skip  over  all  entries  of  the  other  matrix  that  are  before  the  current  entry  in  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -1021,7 +1051,8 @@ public: 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Retrieves  a  compressed  string  representation  of  the  matrix .  
			
		
	
		
			
				
						 *  @ return  a  compressed  string  representation  of  the  matrix .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ returns  a  compressed  string  representation  of  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						std : : string  toStringCompressed ( )  const  {  
			
		
	
		
			
				
							std : : stringstream  result ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -1033,13 +1064,14 @@ public: 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Retrieves  a  ( non - compressed )  string  representation  of  the  matrix .  
			
		
	
		
			
				
						 *  Note :  the  matrix  is  presented  densely .  That  is ,  all  zeros  are  filled  in  and  are  part  of  the  string  
			
		
	
		
			
				
						 *  representation .  
			
		
	
		
			
				
						 *  @ param  nondeterministicChoiceIndices  A  vector  indicating  which  rows  belong  together .  If  given ,  rows  belonging  
			
		
	
		
			
				
						 *  to  separate  groups  will  be  separated  by  a  dashed  line .  
			
		
	
		
			
				
						 *  @ return  a  ( non - compressed )  string  representation  of  the  matrix .  
			
		
	
		
			
				
						 *  Note :  the  matrix  is  presented  densely .  That  is ,  all  zeros  are  filled  in  and  are  part  of  the  
			
		
	
		
			
				
						 *  string  representation ,  so  calling  this  method  on  big  matrices  should  be  done  with  care .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  rowGroupIndices  A  vector  indicating  to  which  group  of  rows  a  given  row  belongs .  If  
			
		
	
		
			
				
						 *  given ,  rows  of  different  groups  will  be  separated  by  a  dashed  line .  
			
		
	
		
			
				
						 *  @ returns  A  ( non - compressed )  string  representation  of  the  matrix .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						std : : string  toString ( std : : vector < uint_fast64_t >  const *  nondeterministicChoice Indices)  const  {  
			
		
	
		
			
				
						std : : string  toString ( std : : vector < uint_fast64_t >  const *  rowGroup Indices)  const  {  
			
		
	
		
			
				
							std : : stringstream  result ;  
			
		
	
		
			
				
							uint_fast64_t  currentNondeterministicChoiceIndex  =  0 ;  
			
		
	
		
			
				
					
 
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -1054,9 +1086,9 @@ public: 
			
		
	
		
			
				
							for  ( uint_fast64_t  i  =  0 ;  i  <  rowCount ;  + + i )  {  
			
		
	
		
			
				
								uint_fast64_t  nextIndex  =  rowIndications [ i ] ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
								/ /  If  we  need  to  group  of  rows ,  print  a  dashed  line  in  case  we  have  moved  to  the  next  group  of  rows .  
			
		
	
		
			
				
								if  ( nondeterministicChoice Indices! =  nullptr )  {  
			
		
	
		
			
				
									if  ( i  = =  ( * nondeterministicChoice Indices) [ currentNondeterministicChoiceIndex ] )  {  
			
		
	
		
			
				
								/ /  If  we  need  to  group  rows ,  print  a  dashed  line  in  case  we  have  moved  to  the  next  group  of  rows .  
			
		
	
		
			
				
								if  ( rowGroup Indices! =  nullptr )  {  
			
		
	
		
			
				
									if  ( i  = =  ( * rowGroup Indices) [ currentNondeterministicChoiceIndex ] )  {  
			
		
	
		
			
				
										if  ( i  ! =  0 )  {  
			
		
	
		
			
				
											result  < <  " \t ( \t " ;  
			
		
	
		
			
				
											for  ( uint_fast64_t  j  =  0 ;  j  <  colCount  -  2 ;  + + j )  {  
			
		
	
	
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
				
				@ -1165,45 +1197,36 @@ private: 
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Prepares  the  internal  CSR  storage .  For  this ,  it  requires  
			
		
	
		
			
				
						 *  non_zero_entry_count  and  row_count  to  be  set  correctly .  
			
		
	
		
			
				
						 *  @ param  alsoPerformAllocation  If  set  to  true ,  all  entries  are  pre - allocated .  This  is  the  default .  
			
		
	
		
			
				
						 *  Prepares  the  internal  storage .  For  this ,  it  requires  the  number  of  non - zero  entries  and  the  
			
		
	
		
			
				
						 *  amount  of  rows  to  be  set  correctly .  
			
		
	
		
			
				
						 *  
			
		
	
		
			
				
						 *  @ param  initializeElements  If  set  to  true ,  all  entries  are  initialized .  
			
		
	
		
			
				
						 *  @ return  True  on  success ,  false  otherwise  ( allocation  failed ) .  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						bool  prepareInternalStorage ( const  bool  alsoPerformAllocation )  {  
			
		
	
		
			
				
							if  ( alsoPerformAllocation )  {  
			
		
	
		
			
				
						bool  prepareInternalStorage ( bool  initializeElements  =  true )  {  
			
		
	
		
			
				
							if  ( initializeElements )  {  
			
		
	
		
			
				
								/ /  Set  up  the  arrays  for  the  elements  that  are  not  on  the  diagonal .  
			
		
	
		
			
				
								valueStorage . resize ( nonZeroEntryCount ,  storm : : utility : : constGetZero < T > ( ) ) ;  
			
		
	
		
			
				
								columnIndications . resize ( nonZeroEntryCount ,  0 ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
								/ /  Set  up  the  row_indications  vector  and  reserve  one  element  more  than  
			
		
	
		
			
				
								/ /  there  are  rows  in  order  to  put  a  sentinel  element  at  the  end ,  
			
		
	
		
			
				
								/ /  which  eases  iteration  process .  
			
		
	
		
			
				
								/ /  Set  up  the  rowIndications  vector  and  reserve  one  element  more  than  there  are  rows  in  
			
		
	
		
			
				
								/ /  order  to  put  a  sentinel  element  at  the  end ,  which  eases  iteration  process .  
			
		
	
		
			
				
								rowIndications . resize ( rowCount  +  1 ,  0 ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
								/ /  Return  whether  all  the  allocations  could  be  made  without  error .  
			
		
	
		
			
				
								return  ( ( valueStorage . capacity ( )  > =  nonZeroEntryCount )  & &  ( columnIndications . capacity ( )  > =  nonZeroEntryCount )  
			
		
	
		
			
				
									& &  ( rowIndications . capacity ( )  > =  ( rowCount  +  1 ) ) ) ;  
			
		
	
		
			
				
							}  else  {  
			
		
	
		
			
				
								/ /  If  it  was  not  requested  to  initialize  the  elements ,  we  simply  reserve  the  space .  
			
		
	
		
			
				
								valueStorage . reserve ( nonZeroEntryCount ) ;  
			
		
	
		
			
				
								columnIndications . reserve ( nonZeroEntryCount ) ;  
			
		
	
		
			
				
								rowIndications . reserve ( rowCount  +  1 ) ;  
			
		
	
		
			
				
								return  true ;  
			
		
	
		
			
				
							}  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
						/*!  
			
		
	
		
			
				
						 *  Shorthand  for  prepareInternalStorage ( true )  
			
		
	
		
			
				
						 *  @ see  prepareInternalStorage ( const  bool )  
			
		
	
		
			
				
						 */  
			
		
	
		
			
				
						bool  prepareInternalStorage ( )  {  
			
		
	
		
			
				
							return  this - > prepareInternalStorage ( true ) ;  
			
		
	
		
			
				
						}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					} ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					}  / /  namespace  storage  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					}  / /  namespace  storm  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					# endif  / /  STORM_STORAGE_SPARSEMATRIX_H_