Skip to content
Snippets Groups Projects
Select Git revision
  • aa59701fffeba831428d115a9049b19a7cce9630
  • master default protected
2 results

eistoeigen.h

Blame
  • eistoeigen.h 1.29 KiB
    /* * libeisdrt - A library to calculate EIS Drts
     * Copyright (C) 2023 Carl Klemm <carl@uvos.xyz>
     *
     * This file is part of libeisdrt.
     *
     * libeisdrt is free software: you can redistribute it and/or modify
     * it under the terms of the GNU Lesser General Public License as published by
     * the Free Software Foundation, either version 3 of the License, or
     * (at your option) any later version.
     *
     * libeisdrt is distributed in the hope that it will be useful,
     * but WITHOUT ANY WARRANTY; without even the implied warranty of
     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     * GNU Lesser General Public License for more details.
     *
     * You should have received a copy of the GNU Lesser General Public License
     * along with libeisdrt.  If not, see <http://www.gnu.org/licenses/>.
     */
    
    // SPDX-License-Identifier: lgpl3
    
    #pragma once
    
    #include <Eigen/Core>
    #include <eisgenerator/eistype.h>
    #include <vector>
    
    Eigen::VectorX<std::complex<fvalue>> eistoeigen(const std::vector<eis::DataPoint>& data, Eigen::Vector<fvalue, Eigen::Dynamic>* omega = nullptr)
    {
    	Eigen::VectorX<std::complex<fvalue>> out(data.size());
    
    	if(omega)
    		*omega = Eigen::VectorX<fvalue>(data.size());
    
    	for(size_t i = 0; i < data.size(); ++i)
    	{
    		out[i] = data[i].im;
    		if(omega)
    			(*omega)[i] = data[i].omega;
    	}
    	return out;
    }