123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
-
-
-
-
-
-
- #ifndef KERNELEM1DMANAGER_INC
- #define KERNELEM1DMANAGER_INC
-
- #include "KernelEM1DBase.h"
- #include "KernelEM1DSpec.h"
-
- namespace Lemma {
-
- class DipoleSource;
- class KernelEM1DReflBase;
-
-
-
-
-
-
- class KernelEM1DManager : public LemmaObject {
-
-
- friend std::ostream &operator<<(std::ostream &stream, const KernelEM1DManager &ob);
-
- public:
-
-
-
-
- KernelEM1DManager ( const ctor_key& );
-
-
- ~KernelEM1DManager ();
-
-
-
- static std::shared_ptr<KernelEM1DManager> NewSP();
-
-
-
-
-
- template<EMMODE Mode, int Ikernel, DIPOLE_LOCATION Isource, DIPOLE_LOCATION Irecv>
- int AddKernel( );
-
-
-
- void ResetSource(const int& ifreq);
-
-
-
- void ComputeReflectionCoeffs(const Real& lambda, const int& idx, const Real& rho0);
-
-
- void ClearVec() {
- KernelVec.clear();
- }
-
-
-
-
-
- void SetEarth( std::shared_ptr<LayeredEarthEM> Earth);
-
-
- void SetDipoleSource( DipoleSource* Dipole, const int& ifreq, const Real& rx_zin);
-
-
-
- std::shared_ptr<KernelEM1DBase> GetKernel(const unsigned int& ik);
-
-
-
- KernelEM1DBase* GetRAWKernel(const unsigned int& ik);
-
-
-
- DipoleSource* GetDipole( );
-
- inline std::vector< std::shared_ptr<KernelEM1DBase> > GetSTLVector() {
- return KernelVec;
- }
-
-
-
-
- virtual inline std::string GetName() const ;
-
- protected:
-
-
-
-
-
-
- std::vector< std::shared_ptr<KernelEM1DBase> > KernelVec;
-
-
- std::shared_ptr<KernelEM1DReflBase> TEReflBase = nullptr;
-
-
- std::shared_ptr<KernelEM1DReflBase> TMReflBase = nullptr;
-
-
- std::shared_ptr<LayeredEarthEM> Earth;
-
-
- DipoleSource* Dipole;
-
-
- int ifreq;
-
-
- Real rx_z;
-
- private:
-
- static constexpr auto CName = "KernelEM1DManager";
-
- };
-
-
- template<EMMODE Mode, int Ikernel, DIPOLE_LOCATION Isource, DIPOLE_LOCATION Irecv>
- int KernelEM1DManager::AddKernel( ) {
-
- auto NewKern = KernelEM1DSpec<Mode, Ikernel, Isource, Irecv>::NewSP();
- NewKern->managerIdx = KernelVec.size();
- switch (Mode) {
- case TE:
- if (TEReflBase == nullptr) {
- TEReflBase = KernelEM1DReflSpec<TE, Isource, Irecv>::NewSP();
- TEReflBase->Initialise(Earth);
- TEReflBase->SetUpSource(Dipole, ifreq);
- TEReflBase->SetUpReceiver( rx_z );
- }
- NewKern->SetReflBase(TEReflBase);
- break;
- case TM:
- if (TMReflBase == nullptr) {
- TMReflBase = KernelEM1DReflSpec<TM, Isource, Irecv>::NewSP();
- TMReflBase->Initialise(Earth);
- TMReflBase->SetUpSource(Dipole, ifreq);
- TMReflBase->SetUpReceiver( rx_z );
- }
- NewKern->SetReflBase(TMReflBase);
- break;
- }
- KernelVec.push_back( std::move(NewKern) );
- return static_cast<int>(KernelVec.size()-1);
- }
-
-
-
-
-
-
-
-
-
-
- }
-
- #endif
|