00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 #ifndef _PROPAGATIONPROPERTIESCALCULATOR_HPP_
00031 #define _PROPAGATIONPROPERTIESCALCULATOR_HPP_
00032
00033 #include "Hdf5DataReader.hpp"
00034
00035 #include <string>
00044 class PropagationPropertiesCalculator
00045 {
00046 private:
00048 Hdf5DataReader *mpDataReader;
00050 const std::string mVoltageName;
00051
00052 public:
00060 PropagationPropertiesCalculator(Hdf5DataReader* pDataReader,
00061 const std::string voltageName = "V");
00062 virtual ~PropagationPropertiesCalculator();
00063
00070 double CalculateMaximumUpstrokeVelocity(unsigned globalNodeIndex);
00071
00079 std::vector<double> CalculateAllMaximumUpstrokeVelocities(unsigned globalNodeIndex, double threshold);
00080
00088 std::vector<double> CalculateUpstrokeTimes(unsigned globalNodeIndex, double threshold);
00089
00102 double CalculateConductionVelocity(unsigned globalNearNodeIndex,
00103 unsigned globalFarNodeIndex,
00104 const double euclideanDistance);
00105
00118 std::vector<double> CalculateAllConductionVelocities(unsigned globalNearNodeIndex,
00119 unsigned globalFarNodeIndex,
00120 const double euclideanDistance);
00128 double CalculateActionPotentialDuration(const double percentage,
00129 unsigned globalNodeIndex);
00137 double CalculatePeakMembranePotential(unsigned globalNodeIndex);
00138
00146 std::vector<double> CalculateAllActionPotentialDurations(const double percentage,
00147 unsigned globalNodeIndex,
00148 double threshold);
00156 std::vector<unsigned> CalculateAllAboveThresholdDepolarisations(unsigned globalNodeIndex,
00157 double threshold);
00158
00166 unsigned CalculateAboveThresholdDepolarisationsForLastAp(unsigned globalNodeIndex,
00167 double threshold);
00168
00169 };
00170
00171 #endif //_PROPAGATIONPROPERTIESCALCULATOR_HPP_