mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-26 02:20:20 -04:00 
			
		
		
		
	
		
			
	
	
		
			63 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			63 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|  | [/============================================================================ | ||
|  |   Boost.odeint | ||
|  | 
 | ||
|  |   Copyright 2011-2013 Karsten Ahnert | ||
|  |   Copyright 2011-2012 Mario Mulansky | ||
|  |   Copyright 2012 Sylwester Arabas | ||
|  | 
 | ||
|  |   Use, modification and distribution is subject to the Boost Software License, | ||
|  |   Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | ||
|  |   http://www.boost.org/LICENSE_1_0.txt) | ||
|  | =============================================================================/] | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | [section Stiff systems] | ||
|  | 
 | ||
|  | [import ../examples/stiff_system.cpp] | ||
|  | 
 | ||
|  | An important class of ordinary differential equations are so called stiff | ||
|  | system which are characterized by two or more time scales of different | ||
|  | order. Examples of such systems are found in chemical systems where reaction | ||
|  | rates of individual sub-reaction might differ over large ranges, for example: | ||
|  | 
 | ||
|  | ['d S[subl 1] / dt = - 101 S[subl 2] - 100 S[subl 1]] | ||
|  | 
 | ||
|  | ['d S[subl 2] / dt = S[subl 1]] | ||
|  | 
 | ||
|  | 
 | ||
|  | In order to efficiently solve stiff systems numerically the Jacobian | ||
|  | 
 | ||
|  | ['J = d f[subl i] / d x[subl j]] | ||
|  | 
 | ||
|  | is needed. Here is the definition of the above example | ||
|  | 
 | ||
|  | [stiff_system_definition] | ||
|  | 
 | ||
|  | The state type has to be a `ublas::vector` and the matrix type must by a | ||
|  | `ublas::matrix` since the stiff integrator only accepts these types.  | ||
|  | However, you might want use non-stiff integrators on this system, too - we will | ||
|  | do so later for demonstration. Therefore we want to use the same function also | ||
|  | with other state_types, realized by templatizing the `operator()`: | ||
|  | 
 | ||
|  | [stiff_system_alternative_definition] | ||
|  | 
 | ||
|  | Now you can use `stiff_system` in combination with `std::vector` or | ||
|  | `boost::array`. In the example the explicit time derivative of ['f(x,t)] is | ||
|  | introduced separately in the Jacobian. If ['df / dt = 0] simply fill `dfdt` with zeros. | ||
|  | 
 | ||
|  | A well know solver for stiff systems is the Rosenbrock method. It has a step size control and dense output facilities and can be used like all the other steppers: | ||
|  | 
 | ||
|  | [integrate_stiff_system] | ||
|  | 
 | ||
|  | During the integration 71 steps have been done. Comparing to a classical Runge-Kutta solver this is a very good result. For example the Dormand-Prince 5 method with step size control and dense output yields 1531 steps. | ||
|  | 
 | ||
|  | [integrate_stiff_system_alternative] | ||
|  | 
 | ||
|  | Note, that we have used __boost_phoenix, a great functional programming library, to create and compose the observer. | ||
|  | 
 | ||
|  | The full example can be found here: [github_link examples/stiff_system.cpp stiff_system.cpp] | ||
|  | 
 | ||
|  | 
 | ||
|  | [endsect] |