diff --git a/Benchmarks/GradientBenchmark/Makefile b/Benchmarks/GradientBenchmark/Makefile
index 349e16a..cc34320 100644
--- a/Benchmarks/GradientBenchmark/Makefile
+++ b/Benchmarks/GradientBenchmark/Makefile
@@ -1,107 +1,107 @@
 PROGRAM_NAME := GradientBenchmark
 #CXX=g++ -lm -ffast-math -ftree-loop-vectorize 
 CXX=icpc
 
 program_CXX_SRCS := $(wildcard *.cpp)
 #program_CXX_SRCS += $(wildcard ../../*.cpp) #Find C++ source files from additonal directories
 program_CXX_OBJS := ${program_CXX_SRCS:.cpp=.o}
 
 program_C_SRCS := $(wildcard *.c)
 #program_CXX_SRCS += $(wildcard ../../*.c) #Find C source files from additonal directories
 program_C_OBJS := ${program_C_SRCS:.c=.o}
 #
 program_CU_SRCS := $(wildcard *.cu)
 #program_CU_SRCS += $(wildcard ../../*.cu) #Find CUDA source files from additional directories
 #program_CU_HEADERS := $(wildcard *.cuh) #Optional: Include .cuh files as dependencies
 #program_CU_HEADERS += $(wildcard ../../*.cuh) #Find .cuh files from additional directories
 program_CU_OBJS := ${program_CU_SRCS:.cu=.cuo}
 #
 program_INCLUDE_DIRS := . /usr/local/cuda/include/ #C++ Include directories
 program_INCLUDE_DIRS += $(CFITSIO_ROOT)/include
 #program_INCLUDE_DIRS += /users/fgilles/bin/iaca-lin32/include
 program_INCLUDE_DIRS += $(LENSTOOL_ROOT)/include
 program_INCLUDE_DIRS += $(GSL_ROOT)/include
 program_INCLUDE_DIRS += $(LENSTOOLHPC_ROOT)/src
 # 
 program_CU_INCLUDE_DIRS := /home/users/amclaugh/CUB/cub-1.3.2/ #CUDA Include directories
 #
 program_INCLUDE_LIBS := ./ #Include libraries
 program_INCLUDE_LIBS += $(CFITSIO_ROOT)/lib #Include libraries
 program_INCLUDE_LIBS += $(LENSTOOL_ROOT)/src
 program_INCLUDE_LIBS += $(LENSTOOL_ROOT)/liblt 
 program_INCLUDE_LIBS += $(LENSTOOLHPC_ROOT)/src
 program_INCLUDE_LIBS += $(GSL_ROOT)/lib 
 program_INCLUDE_LIBS += $(WCSTOOL_ROOT) 
 #
 # Compiler flags
 # 
 CPPFLAGS += $(foreach includedir,$(program_INCLUDE_DIRS),-I$(includedir))
 CPPFLAGS += $(foreach includelib,$(program_INCLUDE_LIBS),-L$(includelib))
 #CPPFLAGS += -qopt-prefetch-distance=64,8 -qopt-streaming-cache-evict=0 -qopenmp -xMIC-AVX512 -pedantic -llenstoolhpc
 #CPPFLAGS += -qopt-streaming-stores=always -qopenmp -xMIC-AVX512 -pedantic -llenstoolhpc
 #CPPFLAGS += -ftz -qopenmp -xHost -llenstool -fma -pedantic -llenstoolhpc  -llt -lcfitsio -lwcs -lgsl -lgslcblas 
 CPPFLAGS += -ftz -qopenmp -xHost -fma -pedantic -llenstoolhpc  -llt -lcfitsio -lwcs -lgsl -lgslcblas 
 CPPFLAGS += -g -O3 -std=c++0x -Wall 
-#CPPFLAGS += -D_double
+CPPFLAGS += -D_double
 #CPPFLAGS += -D__WITH_LENSTOOL
 #CPPFLAGS += -D__USE_GPU
 #
 GEN_SM35 := -gencode=arch=compute_35,code=\"sm_35,compute_35\" #Target CC 3.5, for example
 NVFLAGS := -O3 -g -G -rdc=true #rdc=true needed for separable compilation
 #NVFLAGS += $(GEN_SM35)
 NVFLAGS += $(foreach includedir,$(program_CU_INCLUDE_DIRS),-I$(includedir))
 #
 CUO_O_OBJECTS := ${program_CU_OBJS:.cuo=.cuo.o}
 #
 OBJECTS = $(program_CU_OBJS) $(program_CXX_OBJS) $(program_C_OBJS)
 #
 .PHONY: all clean distclean
 #
 all: $(PROGRAM_NAME) 
 #
 debug: CXXFLAGS = -g -O0 -std=c++0x -Wall -pedantic -DDEBUG -llenstoolhpc -llenstool $(EXTRA_FLAGS)
 debug: NVFLAGS = -O0 $(GEN_SM35) -g -G 
 debug: NVFLAGS += $(foreach includedir,$(program_CU_INCLUDE_DIRS),-I$(includedir))
 debug: $(PROGRAM_NAME)
 
 # Rule for compilation of CUDA source (C++ source can be handled automatically)
 %.cuo: %.cu %.cuh
 	nvcc $(NVFLAGS) $(CPPFLAGS) -o $@ -dc $<
 
 %.cpp: %.cpp %.h
 	$(CXX) $(CXXFLAGS)  -o $@ $< $(CPPFLAGS) 
 
 # This is pretty ugly...details below
 # The program depends on both C++ and CUDA Objects, but storing CUDA objects as .o files results in circular dependency
 # warnings from Make. However, nvcc requires that object files for linking end in the .o extension, else it will throw
 # an error saying that it doesn't know how to handle the file. Using a non .o rule for Make and then renaming the file 
 # to have the .o extension for nvcc won't suffice because the program will depend on the non .o file but the files in
 # the directory after compilation will have a .o suffix. Thus, when one goes to recompile the code all files will be
 # recompiled instead of just the ones that have been updated. 
 #
 # The solution below solves these issues by silently converting the non .o suffix needed by make to the .o suffix 
 # required by nvcc, calling nvcc, and then converting back to the non .o suffix for future, dependency-based 
 # compilation.
 $(PROGRAM_NAME): $(OBJECTS) 
 	$(CXX) -o $@ $(program_CXX_OBJS) $(CUO_O_OBJECTS) $(program_C_OBJS) $(CPPFLAGS) 
 
 
 
 
 
 #$(PROGRAM_NAME): $(OBJECTS) 
 #	@ for cu_obj in $(program_CU_OBJS); \
 #	do				\
 #		mv $$cu_obj $$cu_obj.o; \
 #	done				#append a .o suffix for nvcc
 #	nvcc $(NVFLAGS) $(CPPFLAGS) -o $@ $(program_CXX_OBJS) $(program_C_OBJS) $(CUO_O_OBJECTS)
 #	@ for cu_obj in $(CUO_O_OBJECTS); 	\
 #	do					\
 #		mv $$cu_obj $${cu_obj%.*};	\
 #	done				#remove the .o for make
 
 clean:
 	@- $(RM) $(PROGRAM_NAME) $(OBJECTS) *~ *.o *.optrpt 
 
 distclean: clean
 
diff --git a/Benchmarks/GradientBenchmark/setup.cpp b/Benchmarks/GradientBenchmark/setup.cpp
index 0c1c37a..4bb545a 100644
--- a/Benchmarks/GradientBenchmark/setup.cpp
+++ b/Benchmarks/GradientBenchmark/setup.cpp
@@ -1,295 +1,296 @@
 #include <iostream>
 #include <string.h>
 //#include <cuda_runtime.h>
 #include <math.h>
 #include <sys/time.h>
 #include <fstream>
 #include <immintrin.h>
 
 //#include "simd_math.h"
 
 //#define __WITH_LENSTOOL
 //#include "structure.h"
 #include "structure_hpc.hpp"
 #include <type.h>
 //#ifdef __WITH_LENSTOOL
 //#endif
 //#include "setup.hpp"
 
 extern int num_lenses = 95;
 //
 extern type_t x_c = -44.094528948812552;
 extern type_t y_c = -36.928385887965803;
 //
 //extern int lense_type[]  = {81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81,81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, 81};
 extern int lense_type[]  = {8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8};
 //extern int lense_type[]  = {5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5};
 
 //
 extern type_t pos_x[] = {0.000000000000000, 35.000000000000000, 65.000000000000000, 130.000000000000000, -19.399999999999999, 11.025931099982012, -2.671581400009952, 8.706480300003618, -46.071898399997828, -10.335049000010734, -25.638072299983587, -21.186195800000924, 47.770210000017265, 20.889859399994865, -9.947619900012000, 28.559020299985104, -11.757235600015839, 44.290179900007189, 49.190403899989448, 36.260348400000979, -47.958373599980469, 42.325706400014852, 37.455656899984845, 35.637785899984095, 48.099282799982589, 35.578290900001157, -3.050470599984273, 3.330580999983544, 43.051886999993762, 12.070367100002324, -0.012525300009348, 0.389991100006194, 18.864752299989611, 3.278487299995037, 10.076003800004774, 11.586436500008050, 37.425482399992134, 0.486777199988778, 25.632663699981624, 64.980204499991984, 18.813228000016544, 3.462950200001255, 28.896917700002792, -21.734176000018063, -0.928577399996435, -0.731873800008366, 78.370563400014419, 39.869047099991327, 10.636794000018757, 81.825827699993738, 11.692331899990036, 65.849002200017992, 12.142102700007115, 7.184091700006435, 92.001179599988561, 9.130061900012469, 1.379771499990539, 1.090836400019363, 63.261966300009220, -26.291947899982713, 64.747063800006757, 65.182885999997012, 69.098453600009847, 63.422517399987171, 83.228941699997549, 62.814757499999601, 58.726967500001948, 109.445168699990987, 65.110011700002232, 17.873548699988238, 108.654938499989214, 4.474934500009342, 3.973924000006243, 88.196061999997639, 61.916070000008830, 87.056832499986754, 108.613092799990099, 61.803057900019461, 79.079379299996546, 75.673077399983285, 129.107267799989302, 132.913239399982729, 124.503095399984701, 143.243164500019446, 128.260958600014533, 138.446558499998758, 130.452594800015163, 134.181991500016807, 131.942247000012628, 130.527746399989439, 132.704864599988241, 118.334119300008808, 147.068493300001194, 150.936237199997493, 142.130408800003835};
 
 extern type_t pos_y[] = {0.000000000000000, -10.000000000000000, 40.000000000000000, 80.000000000000000, -21.699999999999999, -59.119920000003390, -58.477319999988708, -50.961599999999407, -45.297360000006393, -42.065999999999804, -46.933559999993690, -46.580759999989141, -37.085399999989477, -38.415960000011751, -38.951640000004772, -33.509519999998361, -35.354879999999866, -22.304880000001504, -22.674599999999145, -9.754919999988942, -22.953600000010965, -21.260159999994244, -20.612880000001610, -18.947520000006079, -7.068240000003811, -1.161000000010404, -1.597679999997581, -1.477079999995112, 5.219999999994229, -3.917879999997353, 0.001799999995455, -2.880720000001702, -0.453960000010056, 2.791800000011335, 1.789919999993117, 0.972720000009986, 2.251080000010575, 20.615760000009686, 20.495160000007218, 19.365120000000502, 16.301160000006121, 17.766359999990300, 18.265679999993267, 21.366720000011696, 32.603399999999283, 21.648600000006013, 23.630759999994666, 22.818239999989487, 21.551399999995624, 22.820040000010522, 25.769519999997215, 33.740639999987820, 25.422120000004611, 23.979960000008305, 33.112080000009314, 33.039720000007833, 32.423399999993308, 33.522119999992128, 33.943680000007248, 39.039480000008098, 33.088679999991655, 36.841680000006249, 40.110120000011307, 36.187200000006214, 43.166519999994080, 37.808640000000082, 41.374079999997093, 42.308279999991782, 39.722400000007951, 43.650719999999410, 45.423719999999435, 47.048760000009793, 48.891600000007429, 45.961559999992119, 53.340119999990065, 47.024999999987926, 46.107720000011909, 52.768080000006989, 58.089600000010932, 62.472239999991075, 77.337719999999877, 72.065520000009542, 74.942999999998960, 76.529879999998229, 77.375160000002552, 85.891679999997450, 83.807999999999083, 87.973920000004568, 87.793919999998593, 95.139359999993189, 95.914439999995693, 101.069640000000049, 101.447279999987927, 107.222760000001927, 106.741440000004673};
 
 extern type_t theta[] = {1.047197551196598, 1.047197551196598, 1.047197551196598, 1.047197551196598, -0.698131700797732, -1.408480706359424, 0.359537825910832, 0.027925268031909, -0.991347015132779, -0.055850536063819, -0.991347015132779, 0.036651914291881, 0.687659725285766, 0.561996019142174, 0.907571211037051, 0.054105206811824, 0.202458193231342, -1.343903524035634, 0.420624349730633, 0.246091424531200, 0.150098315671512, -0.521853446346304, -0.040142572795870, 0.980875039620813, -0.884881930761125, -1.509709802975095, 0.666715774261834, -0.514872129338327, 1.174606586592184, -0.282743338823081, 1.457349925415265, 0.260054058547155, -1.164134611080218, -0.654498469497874, 1.038470904936626, -0.453785605518526, -0.886627260013119, -0.003490658503989, 1.549852375770965, 0.134390352403563, 0.293215314335047, -1.453859266911276, 0.109955742875643, 0.823795406941324, -0.349065850398866, 1.096066770252439, -0.527089434102287, -0.766199541625511, -1.186823891356144, 1.368338133563554, 0.748746249105567, 0.066322511575785, -0.651007810993885, -1.052433538952581, 0.256563400043166, 1.321214243759707, 1.110029404268394, 0.794124809657420, 0.134390352403563, -1.132718684544320, -0.961676417848876, -1.078613477732496, -1.530653753999027, -0.191986217719376, -0.127409035395586, -0.366519142918809, -0.815068760681352, -1.469567230179226, 0.026179938779915, 1.448623279155294, -0.146607657167524, 1.118756050528365, 0.837758040957278, -0.422369678982628, 1.024508270920671, -0.464257581030492, 0.226892802759263, 1.364847475059566, 0.249582083035189, -1.115265392024376, 1.418952681871390, -0.031415926535898, -1.127482696788337, 1.083849465488479, -0.047123889803847, -0.855211333477221, -0.867428638241182, 0.841248699461267, 0.289724655831059, 1.075122819228507, 0.099483767363677, -1.197295866868110, -0.534070751110265, 0.481710873550435, -0.174532925199433};
 //
 extern type_t  epot[] =  {0.075426688904937, 0.075426688904937, 0.075426688904937, 0.075426688904937, 0.116562483442831, 0.344322344322344,0.075409836065574, 0.034285714285715, 0.158045977011495, 0.064297800338409, 0.180914512922465, 0.085616438356165, 0.449781659388646, 0.198529411764706, 0.179611650485437, 0.160975609756097, 0.492772667542707, 0.216589861751152, 0.031496062992126, 0.043407043407043, 0.376311844077961, 0.157622739018088, 0.396428571428571, 0.373650107991361, 0.241081081081081, 0.364293085655315, 0.528824833702883, 0.317901234567901, 0.338345864661654, 0.129963898916967, 0.175792507204611, 0.151898734177215, 0.059829059829059, 0.208333333333333, 0.340163934426229, 0.590493601462523, 0.039062500000001, 0.015317286652079, 0.126005361930295, 0.123473541383989, 0.308584686774942, 0.200913242009132, 0.035587188612100, 0.096280087527352, 0.167197452229299, 0.109909909909910, 0.104109589041096, 0.051409618573797, 0.087431693989071, 0.176470588235294, 0.097178683385580, 0.045769764216366, 0.074235807860262, 0.131944444444444, 0.101449275362319, 0.285714285714286, 0.367619047619048, 0.239263803680982, 0.132132132132132, 0.318295739348371, 0.078817733990148, 0.108695652173913, 0.045143638850889, 0.381165919282511, 0.099236641221374,0.240437158469945, 0.334513274336283, 0.103594080338266, 0.186246418338109, 0.328918322295806, 0.098844672657253, 0.024911032028470, 0.102719033232628, 0.462857142857143, 0.039920159680638, 0.403565640194490, 0.023391812865496, 0.315315315315315, 0.274418604651163, 0.161987041036717, 0.137254901960784, 0.044673539518900, 0.057902973395931, 0.160283687943262, 0.122340425531915, 0.520395550061805, 0.021645021645023, 0.094555873925501, 0.142045454545455, 0.145907473309608, 0.194915254237288, 0.282904689863843, 0.450331125827815, 0.135245901639344, 0.340425531914894};
 //
 extern type_t rcore[] = {10.000000000000000, 5.000000000000000, 10.000000000000000, 10.000000000000000, 1.000000000000000, 0.034052339117993, 0.030349179184560, 0.046574365790645, 0.038383710030628, 0.068256961228370, 0.020804005013518, 0.028193367328818, 0.055481341027049, 0.039097316478764, 0.031633478431847, 0.039641214329569, 0.048322227956496, 0.041128886304460, 0.028585576136945, 0.080565099864725, 0.039097316478764, 0.027425019798032, 0.034367421532497, 0.025594517675956, 0.049905332073874, 0.073815395284787, 0.052984269343359, 0.048322227956496,0.067320440611066, 0.044683475951999, 0.067320440611066, 0.022811137889776, 0.036320092822069, 0.039277781492078, 0.037857065785625, 0.021288592541707, 0.024668738981743, 0.069206510145232, 0.053474526751449, 0.048322227956496, 0.025359865727459, 0.029117021675657, 0.031199450836488, 0.051067776588639, 0.099116726380952, 0.029386438160114, 0.050833141468429, 0.034367421532497, 0.021784467563449, 0.027934888983489, 0.044273815382088, 0.052498506642202, 0.035821762466628, 0.013432193817836, 0.052257297914513, 0.037337647370553, 0.023342477548558, 0.043266020305102, 0.039641214329569, 0.061965070730691, 0.021093417552129, 0.028717521161380, 0.051067776588639, 0.032669835654398, 0.052498506642202, 0.017707080013958, 0.037509990120305, 0.030349179184560, 0.013936282772780, 0.028454237344829, 0.057829168758607, 0.036825355643309, 0.040192678553178, 0.029522079795690, 0.056512816167846, 0.034685419368686, 0.023886193697910, 0.035821762466628, 0.038738870126742, 0.034685419368686, 0.083588580432868, 0.032221588704875, 0.042672388251826, 0.052017197440259, 0.033124318340140, 0.048100207486392, 0.026677611870563, 0.023996447358569, 0.016000993535772, 0.057563467863253, 0.034526054342700, 0.045935341535597, 0.039459079494046, 0.031488135800734, 0.039277781492078};
 //
 extern type_t rcut[] = {500.000000000000000, 500.000000000000000, 500.000000000000000, 500.000000000000000, 150.000000000000000, 5.107850867699009, 4.552376877684008, 6.986154868596703, 5.757556504594200, 10.238544184255536, 3.120600752027715, 4.229005099322641, 8.322201154057367, 5.864597471814614, 4.745021764777110, 5.946182149435385, 7.248334193474441, 6.169332945669035, 4.287836420541705, 12.084764979708812, 5.864597471814614, 4.113752969704730, 5.155113229874521, 3.839177651393335, 7.485799811081068, 11.072309292717980, 7.947640401503818, 7.248334193474441, 10.098066091659968, 6.702521392799788, 10.098066091659968, 3.421670683466420, 5.448013923310371, 5.891667223811720, 5.678559867843796, 3.193288881256013, 3.700310847261404, 10.380976521784758, 8.021179012717386, 7.248334193474441, 3.803979859118900, 4.367553251348570, 4.679917625473273, 7.660166488295854, 14.867508957142872, 4.407965724017149, 7.624971220264309, 5.155113229874521, 3.267670134517328, 4.190233347523285, 6.641072307313197, 7.874775996330366, 5.373264369994223, 2.014829072675421, 7.838594687177010, 5.600647105583010, 3.501371632283681, 6.489903045765340, 5.946182149435385, 9.294760609603639, 3.164012632819346, 4.307628174206992, 7.660166488295854, 4.900475348159637, 7.874775996330366, 2.656062002093733, 5.626498518045686, 4.552376877684008, 2.090442415917007, 4.268135601724389, 8.674375313791064, 5.523803346496345, 6.028901782976731, 4.428311969353570, 8.476922425176864, 5.202812905302965, 3.582929054686518, 5.373264369994223, 5.810830519011283, 5.202812905302965, 12.538287064930271, 4.833238305731319, 6.400858237773873, 7.802579616038900, 4.968647751020976, 7.215031122958762, 4.001641780584524, 3.599467103785322, 2.400149030365801, 8.634520179487971, 5.178908151405005, 6.890301230339541, 5.918861924106924, 4.723220370110043, 5.891667223811720};
 //
 type_t b0[] = {27.686284800000006, 15.573535200000000, 21.197311800000001, 43.259820000000005, 1.401618168000000, 0.701887044377384, 0.625557486765266, 0.959991142907221, 0.791165290944736, 1.406912946824478, 0.428812292146906, 0.581121878203467, 1.143581776765294, 0.805874151883638, 0.652029471542907, 0.817084978065710, 0.996018089699853, 0.847748882881212, 0.589206088811179, 1.660608383702515, 0.805874151883638, 0.565284693698478, 0.708381525237709, 0.527554371568815, 1.028649042482203, 1.521483427216619, 1.092112118320076, 0.996018089699853, 1.387609377521935, 0.921016108754891, 1.387609377521935, 0.470183328577265, 0.748629999074688, 0.809593897959512, 0.780310096202241, 0.438800613557777, 0.508472214857728, 1.426485055525682, 1.102217307333858, 0.996018089699853, 0.522717724018210, 0.600160247852116, 0.643083291809730, 1.052609356688346, 2.042994635018428, 0.605713462253246, 1.047773056002485, 0.708381525237709, 0.449021592862168, 0.575794120800079, 0.912572182315177, 1.082099574236042, 0.738358410415477, 0.276864469886694, 1.077127778308336, 0.769603840315186, 0.481135305220354, 0.891799503367263, 0.817084978065710, 1.277224457300750, 0.434777665351592, 0.591925740547885, 1.052609356688346, 0.673390873628514, 1.082099574236042, 0.364978453094982, 0.773156170239529, 0.625557486765266, 0.287254754837836, 0.586498932739152, 1.191975217859029, 0.759044479765867, 0.828451762375228, 0.608509308563808, 1.164842549348754, 0.714936098789562, 0.492342386170850, 0.738358410415477, 0.798485853249674, 0.714936098789562, 1.722928385636979, 0.664151604471083, 0.879563555467234, 1.072178825707933, 0.682758673823120, 0.991441802267353, 0.549879116438807, 0.494614935370580, 0.329812587059260, 1.186498589205643, 0.711651265795296, 0.946819570637053, 0.813330813603161, 0.649033668246664, 0.80959389795951};
 //
 extern type_t   grad_x = -77.124413458712169;
 extern type_t   grad_y = -46.092652444451353;
 
 //
 //
 //
 
 /**** usefull functions for PIEMD profile : see old lenstool ****/
 
 /**  I*w,v=0.5 Kassiola & Kovner, 1993 PIEMD, paragraph 4.1
  *
  * Global variables used :
  * - none
  */
 
 /** @brief This module function calculates profile depended information like the impactparameter b0 and the potential ellipticity epot
  * 
  * @param lens: mass distribution for which to calculate parameters
  */
 void module_readParameters_calculatePotentialparameter(Potential *lens)
 {
         //std::cout << "module_readParameters_calculatePotentialparameter..." << std::endl;
         switch (lens->type)
         {
 
                 case(5): /*Elliptical Isothermal Sphere*/
                         //impact parameter b0
                         lens->b0 = 4* pi_c2 * lens->vdisp * lens->vdisp ;
                         //ellipticity_potential 
                         lens->ellipticity_potential = lens->ellipticity/3 ;
                         break;
 
                 case(8): /* PIEMD */
                         //impact parameter b0
                         lens->b0 = 6.*pi_c2 * lens->vdisp * lens->vdisp;
                         //ellipticity_parameter
                         if ( lens->ellipticity == 0. && lens->ellipticity_potential != 0. ){
                                 // emass is (a2-b2)/(a2+b2)
                                 lens->ellipticity = 2.*lens->ellipticity_potential / (1. + lens->ellipticity_potential * lens->ellipticity_potential);
                                 //printf("1 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
                         }
                         else if ( lens->ellipticity == 0. && lens->ellipticity_potential == 0. ){
                                 lens->ellipticity_potential = 0.00001;
                                 //printf("2 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
                         }
                         else{
                                 // epot is (a-b)/(a+b)
                                 lens->ellipticity_potential = (1. - sqrt(1 - lens->ellipticity * lens->ellipticity)) / lens->ellipticity;
                                 //printf("3 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
                         }
                         break;
 
                 default:
                         std::cout << "ERROR: LENSPARA profil type of clump "<< lens->name << " unknown : "<< lens->type << std::endl;
                         //printf( "ERROR: LENSPARA profil type of clump %s unknown : %d\n",lens->name, lens->type);
                         break;
         };
 }
 //
 //
 //
 void module_readParameters_calculatePotentialparameter_SOA(Potential_SOA *lens, int ii)
 {
         //std::cout << "module_readParameters_calculatePotentialparameter..." << std::endl;
         switch (lens->type[ii])
         {
 
                 case(5): /*Elliptical Isothermal Sphere*/
                         //impact parameter b0
                         lens->b0[ii] = 4* pi_c2 * lens->vdisp[ii] * lens->vdisp[ii] ;
                         //ellipticity_potential 
                         lens->ellipticity_potential[ii] = lens->ellipticity[ii]/3 ;
                         break;
 
                 case(8): /* PIEMD */
                         //impact parameter b0
                         lens->b0[ii] = 6.*pi_c2 * lens->vdisp[ii] * lens->vdisp[ii];
                         //ellipticity_parameter
                         if ( lens->ellipticity[ii] == 0. && lens->ellipticity_potential[ii] != 0. ){
                                 // emass is (a2-b2)/(a2+b2)
                                 lens->ellipticity[ii] = 2.*lens->ellipticity_potential[ii] / (1. + lens->ellipticity_potential[ii] * lens->ellipticity_potential[ii]);
                                 //printf("1 : %f %f \n",lens->ellipticity[ii],lens->ellipticity_potential[ii]);
                         }
                         else if ( lens->ellipticity[ii] == 0. && lens->ellipticity_potential[ii] == 0. ){
                                 lens->ellipticity_potential[ii] = 0.00001;
                                 //printf("2 : %f %f \n",lens->ellipticity[ii],lens->ellipticity_potential[ii]);
                         }
                         else{
                                 // epot is (a-b)/(a+b)
                                 lens->ellipticity_potential[ii] = (1. - sqrt(1 - lens->ellipticity[ii] * lens->ellipticity[ii])) / lens->ellipticity[ii];
                                 //printf("3 : %f %f \n",lens->ellipticity[ii],lens->ellipticity_potential[ii]);
                         }
                         break;
 
                 default:
                         std::cout << "ERROR: LENSPARA profil type of clump "<< lens->name << " unknown : "<< lens->type << std::endl;
                         //printf( "ERROR: LENSPARA profil type of clump %s unknown : %d\n",lens->name, lens->type);
                         break;
         };
 
 }
 //
 //
 //
 void 
 setup_jauzac_SOA(Potential_SOA *lens_soa, int* nlenses, type_t* x, type_t* y, type_t* sol_grad_x, type_t* sol_grad_y)
 {
 	*nlenses    = num_lenses;
 	*sol_grad_x = grad_x; 
 	*sol_grad_y = grad_y; 
 	*x	    = x_c;
 	*y	    = y_c;
 	//
         //Potential_SOA lens_soa
         //
         for (int i = 0; i < *nlenses; ++i)
         {
                 lens_soa->type       = (int*) malloc(*nlenses*sizeof(int));
                 lens_soa->vdisp      = (type_t*) malloc(*nlenses*sizeof(type_t));
                 //
                 lens_soa->position_x = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->position_y = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->weight = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->b0 = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->vdisp = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->ellipticity_angle = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->anglecos = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->anglesin = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->ellipticity = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->ellipticity_potential = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->rcore = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->rcut = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->rscale = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->exponent = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->alpha = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->einasto_kappacritic = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->z = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->mag = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->lum = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->theta = (type_t*) malloc(*nlenses*sizeof(type_t));
                 lens_soa->sigma = (type_t*) malloc(*nlenses*sizeof(type_t));
         }
         //
         for (int i = 0; i < *nlenses; ++i)
         {
                 //ilens = &lens[i];
                 //
                 lens_soa->vdisp[i]                 = 1.;
                 lens_soa->position_x[i]            = pos_x[i];
                 lens_soa->position_y[i]            = pos_y[i];
                 lens_soa->type[i]                  = lense_type[i];
                 lens_soa->ellipticity[i]           = 0.11;
                 lens_soa->ellipticity_potential[i] = epot[i];
                 lens_soa->ellipticity_angle[i]     = theta[i];
 		lens_soa->anglecos[i]		   = cos(theta[i]);
 		lens_soa->anglesin[i]		   = sin(theta[i]);
                 lens_soa->rcut[i]                  = rcut[i];
                 lens_soa->rcore[i]                 = rcore[i];
                 lens_soa->b0[i]                    = b0[i];
                 lens_soa->weight[i]                = 0;
                 lens_soa->rscale[i]                = 0;
                 lens_soa->exponent[i]              = 0;
                 lens_soa->alpha[i]                 = 0.;
                 lens_soa->einasto_kappacritic[i]   = 0;
                 lens_soa->z[i]                     = 0.4;
         }
 }
 
 void
 setup_jauzac(Potential** lens, int* nlenses, type_t* x, type_t* y, type_t* sol_grad_x, type_t* sol_grad_y)
 {
         *nlenses    = num_lenses;
         *sol_grad_x = grad_x;
         *sol_grad_y = grad_y;
         *x          = x_c;
         *y          = y_c;
         //
        	*lens = (Potential*) malloc(sizeof(Potential)*(*nlenses)); 
         //
         for (int i = 0; i < *nlenses; ++i)
         {
                 //ilens = &lens[i];
                 //
 		(*lens)[i].position.x            = pos_x[i];
                 (*lens)[i].position.y            = pos_y[i];
-		//
+
                 (*lens)[i].vdisp                 = 1.;
                 (*lens)[i].type                  = lense_type[i];
+                //std::cerr << (*lens)[i].type  << " "<< lense_type[i] <<std::endl;
                 (*lens)[i].ellipticity           = 0.11;
                 (*lens)[i].ellipticity_potential = epot[i];
                 (*lens)[i].ellipticity_angle     = theta[i];
                 (*lens)[i].rcut                  = rcut[i];
                 (*lens)[i].rcore                 = rcore[i];
                 (*lens)[i].b0                    = b0[i];
                 (*lens)[i].weight                = 0;
                 (*lens)[i].rscale                = 0;
                 (*lens)[i].exponent              = 0;
                 (*lens)[i].alpha                 = 0.;
                 (*lens)[i].einasto_kappacritic   = 0;
                 (*lens)[i].z                     = 0.4;
         }
 	std::cout << "Setup done..." << std::endl;
 }
 
 #ifdef __WITH_LENSTOOL
 extern struct pot lens[NLMAX];
 void
 //setup_jauzac_LT(struct pot** lens, int* nlenses, type_t* x, type_t* y, type_t* sol_grad_x, type_t* sol_grad_y)
 setup_jauzac_LT( int* nlenses, type_t* x, type_t* y, type_t* sol_grad_x, type_t* sol_grad_y)
 {
         *nlenses    = num_lenses;
         *sol_grad_x = grad_x;
         *sol_grad_y = grad_y;
         *x          = x_c;
         *y          = y_c;
         //
         //*lens = (struct pot*) malloc(sizeof(struct pot)*(*nlenses));
         //
         for (int i = 0; i < *nlenses; ++i)
         {
                 //
                 lens[i].C.x            = pos_x[i];
                 lens[i].C.y            = pos_y[i];
                 //
                 lens[i].sigma                 = 1.; 			// disp
 		if (lense_type[i] == 5)
 			lens[i].type                  = 1;
 		else
 			lens[i].type                  = lense_type[i];
                 lens[i].emass                 = 0.11;
                 lens[i].epot                  = epot[i];
                 lens[i].theta                 = theta[i];
                 lens[i].rcut                  = rcut[i];
                 lens[i].rc                    = rcore[i];
                 lens[i].b0                    = b0[i];
                 lens[i].masse                 = 0;			// weight
                 //lens[i].rc  	                 = 0;			// rscale
 //               (&lens)[i].exponent              = 0;
                 lens[i].alpha                 = 0.;
 //                (&lens)[i].einasto_kappacritic   = 0;
                 lens[i].z                     = 0.4;
         }
         std::cout << "Setup done..." << std::endl;
 }
 #endif
 
 
 
 
 
 
 
 
diff --git a/src/module_readParameters.cpp b/src/module_readParameters.cpp
index 1109d0c..b40f609 100644
--- a/src/module_readParameters.cpp
+++ b/src/module_readParameters.cpp
@@ -1,2743 +1,2744 @@
 /**
 * @file   module_readParameters.cpp
 * @Author Christoph Schaefer, EPFL (christophernstrerne.schaefer@epfl.ch)
 * @date   July 2015
 * @version 0,1
 * @brief  read parameters, images, sources and any other relevant information
 *
 * read parameter file
 * 
 */
 
 
 
 // Include
 //===========================================================================================================
 #include <iostream>
 #include <cstring>
 #include <string.h>
 #include <sstream>
 #include <stdlib.h>
 #include <stdio.h>
 #include <fstream>
 #include <cmath>
 #include "module_readParameters.hpp"
 #include <iomanip>
 
 
 
 
 
 //===========================================================================================================
 // Function definitions
 
 /**
  *
  * bayes.dat each # corresponds to one param available, it has to be in the same folder (can be changed)
  *
  * bayespot = array with bayes values
  * nparam = number of param available
  * nvalues = number of bayes potentials
  *
  */
 
 void module_readParameters_preparebayes(int &nparam, int &nvalues){
 
 	nparam = 0;
 	nvalues = 0;
 	//Counting lines
     std::string line;
     std::ifstream IM("bayes.dat",std::ios::in);
 	if ( IM )
 	{
 		while( std::getline(IM,line) )  // Read every line
 		{
 		if ( strncmp(line.c_str(), "#", 1) == 0){	//Skipping commented lines
 			nparam += 1;
 			continue;
 		}
 		nvalues +=1;
 		}
 	}
 	nvalues -= 1; //exclude last empty line
 	//nparam -=1; // Nparam is excluded
 	std::cerr << "nvalues :" << nvalues << "nparam :" << nparam << std::endl;
 	IM.close();
 
 }
 
 void module_readParameters_bayesmodels(double * bayespot, int nparam, int nvalues){
 
     std::string line;
     std::ifstream IM("bayes.dat",std::ios::in);
     std::stringstream streamline;
     int j = 0;
 	if ( IM )
 	{
 		while( std::getline(IM,line) )  // Read every line
 		{
 		if ( strncmp(line.c_str(), "#", 1) == 0){	//Skipping commented lines
 			continue;
 		}
 		streamline << line;
 		for(int i = 0; i < nparam; i++){
 			streamline >> bayespot[j * nparam + i];
 			//IM >> bayespot[j * nparam + i];
 			std::cerr << bayespot[j * nparam + i] << " " ;
 		}
 		streamline.clear();
 		std::cerr << std::endl;
 		j += 1;
 		}
 
 	}
 
 	IM.close();
 
 
 }
 
 /**setting potential using bayes[index] values. Does not support changing the bayes files config output defined by
 // Parameter constants in structure.h
 #define CX       0
 #define CY       1
 #define EPOT     2
 #define EMASS    3
 #define THETA    4
 #define PHI      5
 #define RC       6
 #define B0       7
 #define ALPHA    8
 #define BETA     9
 #define RCUT    10
 #define MASSE   11
 #define ZLENS   12
 #define RCSLOPE 13
 #define PMASS   14
 */
 
 void module_readParameters_setbayesmapmodels(const runmode_param* runmode, const cosmo_param* cosmology, const potentialoptimization* limit, potfile_param* potfile, Potential_SOA* lenses, double * bayespot, int nparam, int index){
 
 	int param_index = 2;
 	double DTR=acos(-1.)/180.;	/* 1 deg in rad  = pi/180 */
 	for(int i = 0; i < runmode->nhalos; i++){
 		if(limit[i].position.x.block == 1){
 			lenses->position_x[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].position.y.block == 1){
 			lenses->position_y[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].ellipticity_potential.block == 1){
 			lenses->ellipticity_potential[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].ellipticity.block == 1){
 			lenses->ellipticity[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].ellipticity_angle.block == 1){
 			lenses->ellipticity_angle[i] = bayespot[index*nparam+param_index]* DTR;
 			lenses->anglecos[i] = cos(lenses->ellipticity_angle[i]);
 			lenses->anglesin[i] = sin(lenses->ellipticity_angle[i]);
 			param_index++;
 		}
 		if(limit[i].rcore.block == 1){
 			lenses->rcore[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].vdisp.block == 1){
 			lenses->vdisp[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].rcut.block == 1){
 			lenses->rcut[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		if(limit[i].z.block == 1){
 			lenses->z[i] = bayespot[index*nparam+param_index];
 			param_index++;
 		}
 		module_readParameters_calculatePotentialparameter_SOA(lenses, i);
 	}
 	//Skip redshift image optimisation
 	if(runmode->potfile != 0){
 	param_index += runmode->N_z_param;
 	std::cerr << "N_z_param " << runmode->N_z_param << std::endl;
 	printf("DNDBSFB ircut %d\n",potfile->ircut);
 	//Start potfile updating
 	if(potfile->ircut > 0){
 		potfile->cut1 = bayespot[index*nparam+param_index];
 		//printf("cur %f ircut %d\n",potfile->cut,potfile->ircut);
 		//std::cerr << index*nparam+param_index_pot << " "<< bayespot[index*nparam+param_index_pot] << std::endl;
 		param_index++;
 	}
 	//std::cerr << "param " << param_index_pot << std::endl;
 	if(potfile->isigma > 0){
 		potfile->sigma1 = bayespot[index*nparam+param_index];
 		//std::cerr << index*nparam+param_index_pot << " "<< bayespot[index*nparam+param_index_pot] << std::endl;
 		param_index++;
 	}
 
 	setScalingRelations(runmode,cosmology,potfile,lenses);
 	}
 	/*
 	for(int i = runmode->nhalos; i < runmode->nhalos + runmode->npotfile; i++){
 		param_index_pot = param_index;
 		//std::cerr << "param " << param_index_pot << std::endl;
 
 		//std::cerr << "param " << param_index_pot << std::endl;
 		module_readParameters_calculatePotentialparameter_SOA(lenses, i);
 	}*/
 
 		//update potential parameters
 
 }
 
 /** @brief This module function reads the cosmology parameters from the parameter file
 * 
 * This module function reads the cosmology parameters from the parameter file. The given pointer is 
 * updated with the results.
 * Read an infile: The structure of the file is as follows:
 	|    .
 	|    .
 	|    .
 	|cosmology
 	|		model	x <---- this is a value
 	|		 H0	x
 	|		  .	.
 	|		  .	.
 	|		 end
 	|    .
 	|    .
 	|  finish
 * 	
 * @param Cosmology cosmology
 * @param infile path to file	 
 */
 
 void module_readParameters_readCosmology(std::string infile, cosmo_param &Cosmology)
 {
 
     std::string first, second, third, line1, line2;
 
     Cosmology.model = 1;
     Cosmology.H0 = 50;
     Cosmology.h = 1.;
     Cosmology.omegaM = 1.;
     Cosmology.omegaX = 0;
     Cosmology.wX = -1.;
     Cosmology.wa = 0.;
     Cosmology.curvature = 0.;
 
 
     std::ifstream IN(infile.c_str(),std::ios::in); // open file
     if ( IN )
     {
 	std::getline(IN,line1);
 	std::istringstream read1(line1); // create a stream for the line
 	read1 >> first;
 	while(strncmp(first.c_str(), "fini",4) != 0 ) // read line by line until finish is reached
         {
             if ( strncmp(first.c_str(), "cosmolog", 8) == 0){ // if the line contains information about cosmology
 
 		    std::getline(IN,line2);    // read the line word by word
 		    std::istringstream read2(line2);
 		    read2 >> second >> third;
 
 		    while(strncmp(second.c_str(), "end",3) != 0)    // Go ahead until "end" is reached
         	    { 
 
         		if ( !strcmp(second.c_str(), "model") )  // set model of universe
         		{                                                          
             		Cosmology.model=atoi(third.c_str());
         		}
        			else if ( !strcmp(second.c_str(), "H0") ) // set Hubble constant
         		{
             		Cosmology.H0=atof(third.c_str());
             		Cosmology.h = Cosmology.H0 / 50.;
         		}
         		else if ( !strcmp(second.c_str(), "omegaM") || !strcmp(second.c_str(), "omega") ) // set density of matter
         		{
            		Cosmology.omegaM=atof(third.c_str());
         		}
         		else if ( !strcmp(second.c_str(), "omegaX") || !strcmp(second.c_str(), "lambda") ) // set cosmological constant
         		{
             		Cosmology.omegaX=atof(third.c_str());
         		}
         		else if ( !strcmp(second.c_str(), "wX") || !strcmp(second.c_str(), "q") || !strcmp(second.c_str(), "w0") )     // set  "q" for Model 2, "wX" for Model 3, "w0" for Model 4
         		{
             		Cosmology.wX=atof(third.c_str());
         		}
         		else if ( !strcmp(second.c_str(), "wa") || !strcmp(second.c_str(), "n") || !strcmp(second.c_str(), "delta") || !strcmp(second.c_str(), "w1") )     // set  "n" for Model 2, "delta" for model 3, "w1" for model 4  
         		{
             		Cosmology.wa=atof(third.c_str());
         		}
         		else if ( !strcmp(second.c_str(), "omegaK") ) // set universe curvature
         		{
             		Cosmology.curvature=atof(third.c_str());
         		}
 			// read next line
 			std::getline(IN,line2);
 		        std::istringstream read2(line2);
 		        read2 >> second >> third;
 
     		   }
 
     		// if a flat Universe
     		if ( Cosmology.curvature == 0. )
     		{
         	Cosmology.omegaX = 1 - Cosmology.omegaM;
     		}
     		else
         	Cosmology.curvature = Cosmology.omegaM + Cosmology.omegaX - 1;
 		
 	    }
 	    // read next line
 	    std::getline(IN,line1);
 	    std::istringstream read1(line1);
 	    read1 >> first;
 
         }
 
         IN.close();
 
     }
     else
     {
         fprintf(stderr, "ERROR: file %s not found\n", infile.c_str());  // Exit if file was not found
         exit(-1);
     }
 
 }
 
 /** @brief This module function reads the number of sources, arclets, etc. in the parameter file. We need to know this to allocate the memory
 * 
 * Function to read the number of multiple images and clumps
 * Check if there is 1 limit for each clump set
 * The program reads the number of potentials and limits defined, and checks whether there are the same number
 * Then it opens the imfile to read the numbers of images and set of images
 * Reads also the size of the multiple images area, the size of a pixel, and the runmode.
 * 	
 * @param infile path to file
 * @param runmode runmode parameter
 */
 
 void read_runmode(std::istream &IN, struct runmode_param *runmode){
 	std::string  first, second, third, fourth, fifth, line1, line2;
 	//sscanf variables
 	double in1, in2;	//%lf in1, then (type_t)in1 ;
 	std::getline(IN,line2);
 					std::istringstream read2(line2);
 					read2 >> second >> third >> fourth;    // Read in 4 words
 		    		while (strncmp(second.c_str(), "end", 3))    // Read until we reach end
 		    		{
 						if ( !strcmp(second.c_str(), "nbgridcells") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d ", &runmode->nbgridcells);
 		        		}
 
 		        		if ( !strcmp(second.c_str(), "source") )
 		        		{
 							char filename[FILENAME_SIZE];
 		            		sscanf(line2.c_str(), " %*s %d %s ", &runmode->source, &filename);
 		            		runmode->sourfile = filename;
 		        		}
 
 						if ( !strcmp(second.c_str(), "image") )
 		        		{
 							char filename[FILENAME_SIZE];
 		            		sscanf(line2.c_str(), " %*s %d %s ", &runmode->image, &filename);
 		            		runmode->imagefile = filename;
 		        		}
 		        		if ( !strcmp(second.c_str(), "inverse") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d ", &runmode->inverse);
 		        		}
 		        		if ( !strcmp(second.c_str(), "mass") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d %d %lf %lf", &runmode->mass, &runmode->mass_gridcells, &in1, &in2);
 							runmode->z_mass = (type_t)in1;
 							runmode->z_mass_s =(type_t)in2;
 		        		}
 		        		if ( !strcmp(second.c_str(), "poten") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d %d %lf", &runmode->potential, &runmode->pot_gridcells, &in1);
 							runmode->z_pot = (type_t)in1;
 		        		}
 		        		if ( !strcmp(second.c_str(), "dpl") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d %d %lf", &runmode->dpl, &runmode->dpl_gridcells, &in1);
 							runmode->z_dpl = (type_t)in1;
 		        		}
 		        		if ( !strcmp(second.c_str(), "grid") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d %d %lf", &runmode->grid, &runmode->gridcells, &in1);
 							runmode->zgrid = (type_t)in1;
 		        		}
 		        		if ( !strcmp(second.c_str(), "ampli") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d %d %lf", &runmode->amplif, &runmode->amplif_gridcells, &in1);
 							runmode->z_amplif = (type_t)in1;
+							//std::cerr<<runmode_>ampli << << <<std::endl;
 									        		}
 						if ( !strcmp(second.c_str(), "arclets") )
 		        		{
 		            		runmode->arclet = 1;  // Not supported yet
 		        		}
 				        if (!strcmp(second.c_str(), "reference"))
 				        {
 				        	sscanf(line2.c_str(), "%*s %*d %lf %lf", &in1, &in2);
 				                runmode->ref_ra = (type_t)in1;
 				                runmode->ref_dec =(type_t)in2;
 
 				            //std::cerr << line2 << std::endl;
 				            std::cout << "Reference: Ra " << runmode->ref_ra << " Dec:" << runmode->ref_dec <<std::endl;
 				        }
 
 						if ( !strcmp(second.c_str(), "time") )
 		        		{
 							sscanf(line2.c_str(), " %*s %d ", &runmode->time);
 
 		        		}
 						if( !strncmp(second.c_str(), "Debug",5) )    // Read in if we are in debug mode
 						{
 						runmode->debug = 1;
 						}
 
 						// Read the next line
 						std::getline(IN,line2);
 						std::istringstream read2(line2);
 						read2 >> second >> third;
 		    		}
 
 }
 
 void read_runmode_potential(std::istream &IN, int &numberPotentials){
 	std::string  first, second, third, fourth, fifth, line1, line2;
 
 	numberPotentials += 1;
 	std::getline(IN,line2);
 	std::istringstream read2(line2);
 	double z(0);
 	read2 >> second >> third;
 	//std::cout << second  << third << std::endl;
 	while (strncmp(second.c_str(), "end", 3))    // Read until we reach end
 	{
 		if (!strcmp(second.c_str(), "z_lens"))  // Get redshift
 		{
 			z=atof(third.c_str());
 		}
 		// Read the next line
 		std::getline(IN,line2);
 		std::istringstream read2(line2);
 		read2 >> second >> third;
 	}
 	// Check if redshift from current halo was initialized
 	if ( z == 0. )
 		{
 			fprintf(stderr, "ERROR: A redshift is not defined for a potential \n");
 			exit(-1);
 		}
 }
 
 void read_runmode_image(std::istream &IN, struct runmode_param *runmode){
 	std::string  first, second, third, fourth, fifth, line1, line2;
 
     std::getline(IN,line2);
  	std::istringstream read2(line2);
  	double z(0);
  	read2 >> second >> third;
  	while (strncmp(second.c_str(), "end", 3))    // Read until we reach end
 		{
 			if ( !strcmp(second.c_str(), "multfile") )
 			{
 				char filename[FILENAME_SIZE];
 				sscanf(line2.c_str(), " %*s %d %s ", &runmode->multi, &filename);
 				runmode->imagefile = filename;
 			}
 			if ( !strcmp(second.c_str(), "z_m_limit") )
 			{
 				runmode->N_z_param += 1 ;
 			}
 			//std::cout << runmode->multi << runmode->imagefile << std::endl;
 			// Read the next line
 			std::getline(IN,line2);
 			std::istringstream read2(line2);
 			read2 >> second >> third;
 		}
 }
 
 void read_runmode_potfile(std::istream &IN, struct runmode_param *runmode){
 	std::string  first, second, third, fourth, fifth, line1, line2;
 
     runmode->potfile = 1;
 
     std::getline(IN,line2);
 	std::istringstream read2(line2);
 	read2 >> second >> third >> fourth;    // Read in 4 words
 	while (strncmp(second.c_str(), "end", 3))    // Read until we reach end
 	{
 
 	if ( !strcmp(second.c_str(), "filein") )
 	{
 		//std::cerr<< third << " " << fourth << " " << runmode->potfilename << std::endl;
 		runmode->potfilename = fourth;
 		//std::cerr<< line2 << runmode->potfilename;
 		break;
 
 	}
 	// Read the next line
 	std::getline(IN,line2);
 	std::istringstream read2(line2);
 	read2 >> second >> third;
 	}
 }
 
 void read_runmode_countimages(struct runmode_param *runmode){
 	std::string line2;
 	int old_j = 0;
 	int j = 0;
 	int imageIndex = 0;
 
 	if (runmode->image == 1 or runmode->inverse == 1 or runmode->time >= 1 or runmode->multi >= 1){
 
 		std::string imageFile_name = runmode->imagefile;
 		std::ifstream IM(imageFile_name.c_str(), std::ios::in);
 
 		if ( IM )
 		{
 			while( std::getline(IM,line2) )  // Read every line
 			{
 			if ( strncmp(line2.c_str(), "#", 1) == 0){	//Skipping commented lines
 				continue;
 			}
 			else{
 				int j=atoi(line2.c_str());
 				if(j != old_j){				//If a new set has been reached, increase the nset iterator and update old j
 					runmode->nsets +=1;
 					old_j = j;
 				}
 				imageIndex++;
 				}
 			}
 		}
 		else{
 
 			fprintf(stderr, "ERROR: file %s not found\n", imageFile_name.c_str());
 			exit(-1);
 		}
 
 	runmode->nimagestot=imageIndex;
 	IM.close();
 	}
 }
 
 void read_runmode_countsources(struct runmode_param *runmode){
 	std::string  imageFile_name,line1, line2;
 
 	if (runmode->source == 1 and runmode->image == 0 and runmode->multi == 0 ){
 		imageFile_name = runmode->sourfile;
 		//printf("Source to image mode activated\n");
 
 	std::ifstream IM(imageFile_name.c_str(), std::ios::in);
 	//printf(" Booo says hello again \n");
     	if ( IM ){
 			int i = 0;
 	        while( std::getline(IM,line1) ){    // Read until we reach the end
 	            i++;
 			}
 			runmode->nsets = i ;
 	    	}
 		else{
 
 			fprintf(stderr, "ERROR: file %s not found\n", imageFile_name.c_str());
 			exit(-1);
 		}
 
 	runmode->nimagestot= 0;	// Important
 	IM.close();
 
 	}
 }
 
 void read_runmode_countpotfile(struct runmode_param *runmode){
 	std::string  imageFile_name,line1, line2;
 
 	if (runmode->potfile == 1){
 			imageFile_name = runmode->potfilename;
 
 			std::ifstream IM(imageFile_name.c_str(), std::ios::in);
 
 	    	if ( IM ){
 				int i = 0;
 		        while( std::getline(IM,line1) ){    // Read until we reach the end
 	                if ( line1[0] == '#' ){
 	                    continue;
 	                }
 		            i++;
 				}
 				runmode->npotfile = i ;
 		    	}
 			else{
 
 				fprintf(stderr, "ERROR: file %s not found\n", imageFile_name.c_str());
 				exit(-1);
 			}
 
 		IM.close();
 
 		}
 }
 
 
 void module_readParameters_readRunmode(std::string infile, struct runmode_param *runmode)
 {
 
 	std::string  first, second, third, fourth, fifth, line1, line2;
 	int Nsis(0), Npiemd(0);
 	/// Set default values
 
 	runmode->nbgridcells = 1000;
 	runmode->source = 0;
 	runmode->image = 0;
 	runmode->N_z_param = 0;
 	runmode->nsets = 0;
 	runmode->nhalos = 0;
 	runmode->multi = 0;
 	runmode->mass = 0;
 	runmode->mass_gridcells = 1000;
 	runmode->z_mass = 0.4;
 	runmode->z_mass_s = 0.8;
 	runmode->potential = 0;
 	runmode->pot_gridcells = 1000;
 	runmode->potfile = 0; //weird seg fault due to this line, haven't figured out why
 	runmode->npotfile = 0;
 	runmode->z_pot = 0.8;
 	runmode->dpl = 0;
 	runmode->dpl_gridcells = 1000;
 	runmode->z_dpl = 0.8;
 	runmode->inverse = 0;
 	runmode->arclet = 0;
 	runmode->debug = 0;
 	runmode->nimagestot = 0;
 	runmode->nsets = 0;
 	runmode->gridcells = 1000;
 	//std::cerr << sizeof(*runmode) << std::endl;
 	runmode->cline = 0;
 	runmode->time = 0;
 	runmode->inverse = 0;
 	runmode->arclet = 0;
 	runmode->ref_ra = 0;
 	runmode->ref_dec = 0;
 
 
 	int j=0;
 	std::string imageFile_name;
 	int imageIndex=0;
 	int numberPotentials=0, numberLimits=0;
 
 /*************************** read nhalos, imfile_name, pixel_size, multipleimagesarea_size and runmode from configuration file *********************/
 
 std::ifstream IN(infile.c_str(), std::ios::in);
     if ( IN )
     {
 
 	std::getline(IN,line1);
 	std::istringstream read1(line1); // create a stream for the line
 	read1 >> first;  // Read the first word
 	//std::cout<<first;
         while(  strncmp(first.c_str(), "fini",4) != 0  )    // Continue until we reach finish
         {
 			if ( strncmp(first.c_str(), "runmode", 7) == 0){    // Read in runmode information
 				read_runmode(IN,runmode);
 		    }
 			else if (!strncmp(first.c_str(), "potent", 6)) // each time we find a "potential" string in the configuration file, we add an halo
             {
 				read_runmode_potential(IN,numberPotentials);
 				//std::cerr<<numberPotentials << std::endl;
             }
             else if (!strncmp(first.c_str(), "image", 5)) // same for the limit of the potential
             {
             	read_runmode_image(IN,runmode);
             }
             else if (!strncmp(first.c_str(), "limit", 5)) // same for the limit of the potential
             {
                 numberLimits++;
             }
             else if (!strncmp(first.c_str(), "cline", 5))
             {
                 runmode->cline = 1;
             }
 
             else if (!strncmp(first.c_str(), "potfile", 7))
             {
             	read_runmode_potfile(IN,runmode);
             }
 	    // read the next line
 	    std::getline(IN,line1);
 	    std::istringstream read1(line1);
 	    read1 >> first;
 	    //std::cout<<first;
         }
 
         IN.close();
 	
         //if(numberLimits!=numberPotentials) printf("Warning : Number of clumps different than number of limits in %s\n", infile.c_str()); // must be limits for each halo
 	runmode->nhalos=numberPotentials;
 
     }
     else
     {
         fprintf(stderr, "ERROR: file %s not found\n", infile.c_str());
         exit(-1);
     }
     //
     //getting nimage value (number of images), nset value (number of sources) and npotfile
     //if image or multi mode is activated get nimage and nset
     read_runmode_countimages(runmode);
 	//if source mode is activated, get nset
     read_runmode_countsources(runmode);
     //if potfile mode, count number of potential in potfile
     read_runmode_countpotfile(runmode);
 
 
 std::cerr <<"nsets: " <<runmode->nsets <<" nhalos: " << runmode->nhalos << " nimagestot: " << runmode->nimagestot << " npotfile: " << runmode->npotfile << " multi: " << runmode->multi<< std::endl;
 
 }
 
 
 
 
 /** @brief read the positions, redshifts and numbers of multiple images from the images file
 * 
 * This module function reads in the strong lensing images
 * Output: image coordinates, image shapes (semi-minor, semi-major of ellipse and orientation angle), source redshifts, number of images per set
 * 	
 ** the images file must contain
 	1 	x_center	y_center	major axis	minor axis	ellipticity angle	redshift
 	1	   .		   .		   .		    .			.		    .
 	1	   .		   .		   .		    .			.		    .
 	2	   .		   .		   .		    .			.		    .
 	2	   .		   .		   .		    .			.		    .
 	2	   .		   .		   .		    .			.		    .
 	2	   .		   .		   .		    .			.		    .
 	2	   .		   .		   .		    .			.		    .
 	.	   .		   .		   .		    .			.		    .
 	.	   .		   .		   .		    .			.		    .
 	.	   .		   .		   .		    .			.		    .
    nsetofimages	   .		   .		   .		    .			.		    .
 
    At each line we store in j the index of the set of images to store the redshifts and the number of images of each set
    At each line we add an images in the position of images' array
 * 
 * @param runmode runmode parameter
 * @param image	array where images will be stored
 * @param nImagesSet array where the number of images per Set will be stored
 */
 
 
 /// read the positions, redshifts and numbers of multiple images from the images file
 void module_readParameters_readImages(const struct runmode_param *runmode, struct galaxy image[], int nImagesSet[])
 {
 
 	std::string second, line1;
 	int imageIndex=0;
 	int j=0;
 	//cast variables
 	double cast_x,cast_y,cast_a,cast_b,cast_theta,cast_z,cast_mag;
 	
 
 
 
 for(int i=0; i<runmode->nsets; i++){
 	nImagesSet[i]=0;
 }
 
 /*********initialisation of nimages array*********/
 for(int i=0; i<runmode->nimagestot; i++){
 	
 	/* Initialise here the variables of the images*/
 	image[i].center.x = image[i].center.y = 0;
 	image[i].shape.a = image[i].shape.b = image[i].shape.theta = 0;
 	image[i].redshift = 0; 
 
     }
 
 //printf("imagefile :%d \n", runmode->imagefile.c_str
 
 // Read in images
     std::ifstream IM(runmode->imagefile.c_str(),std::ios::in);  
 	if ( IM )
     	{
 			int i = 0;
         	while( std::getline(IM,line1) )    // Read until we reach the end
         	{
                         // Read in the parameters, * means we read in a parameter but do not store it
             
 			sscanf(line1.c_str(), "%d %lf %lf %lf %lf %lf %lf %lf", &j, &cast_x, &cast_y, &cast_a, &cast_b, &cast_theta, &cast_z, &cast_mag);
 			//Casting
 			image[i].center.x =(type_t)cast_x;
 			image[i].center.y =(type_t)cast_y;
 			image[i].shape.a =(type_t)cast_a;
 			image[i].shape.b =(type_t)cast_b;
 			image[i].shape.theta =(type_t)cast_theta;
 			image[i].redshift =(type_t)cast_z;
 			image[i].mag =(type_t)cast_mag;
 			//Variables
 			nImagesSet[j-1]++;  // Increase the counter of the number of system for system with number j-1 by 1
             imageIndex++;
             i++;
 		}
 	}
 	else{
 			std::cout << "Error : file "  << runmode->imagefile <<  " not found" << std::endl;
 			exit(-1);
 		}
 	
 	IM.close();
 }
 
 /** @brief read the positions, redshifts and numbers of multiple sources from the sources file
 * 
 * This module function reads in the strong lensing sources
 * Output: sources coordinates, sources shapes (semi-minor, semi-major of ellipse and orientation angle), source redshifts
 * 	
 *  the images file must contain
 	 	x_center	y_center	major axis	minor axis	ellipticity angle	redshift
 	1	   .		   .		   .		    .			.		    .
 	2	   .		   .		   .		    .			.		    .
 	3	   .		   .		   .		    .			.		    .
    
 * 
 * @param runmode runmode parameter
 * @param source	array where sources will be stored
 */
 
 
 /// read the positions, redshifts and numbers of multiple images from the images file
 void module_readParameters_readSources(struct runmode_param *runmode, struct galaxy source[])
 {
 
 	std::string second, line1;
 	int j=0;
 	//cast variables
 	double cast_x,cast_y,cast_a,cast_b,cast_theta,cast_z,cast_mag;
 	
 	//Calculating nset
 	std::ifstream IM(runmode->sourfile.c_str(),std::ios::in);
 	if ( IM ){
 		int i = 0;
         while( std::getline(IM,line1) ){    // Read until we reach the end
             i++;
 		}
 		runmode->nsets = i ;
 	}
 	else{
 			std::cout << "Error : file "  << runmode->sourfile <<  " not found" << std::endl;
 			exit(-1);
 		}
 		
 	IM.close();
 
 /*********initialisation of nimages array*********/
 for(int i=0; i<runmode->nsets; i++){
 	
 	/* Initialise here the variables of the images*/
 	source[i].center.x = source[i].center.y = 0;
 	source[i].shape.a = source[i].shape.b = source[i].shape.theta = 0;
 	source[i].redshift = 0; 
 	source[i].mag = 0; 
 
     }
 
 	std::ifstream IM2(runmode->sourfile.c_str(),std::ios::in);
 // Read in images
 	if ( IM2 )
     	{
 			int i = 0;
         	while( std::getline(IM2,line1) )    // Read until we reach the end
         	{
                         // Read in the parameters, * means we read in a parameter but do not store it
             
 			sscanf(line1.c_str(), "%d %lf %lf %lf %lf %lf %lf %lf", &j, &cast_x, &cast_y, &cast_a, &cast_b, &cast_theta, &cast_z, &cast_mag);
 			//Casting
 			source[i].center.x =(type_t)cast_x;
 			source[i].center.y =(type_t)cast_y;
 			source[i].shape.a =(type_t)cast_a;
 			source[i].shape.b =(type_t)cast_b;
 			source[i].shape.theta =(type_t)cast_theta;
 			source[i].redshift =(type_t)cast_z;
 			source[i].mag =(type_t)cast_mag;
 			
             i++;
 		}
 	}
 	else{
 			std::cout << "Error : file "  << runmode->sourfile <<  " not found" << std::endl;
 			exit(-1);
 		}
 	
 	IM2.close();
 }
 
 /** @brief This module function reads the critical and caustic line information
  *@param infile path to file
 * @param cline cline parameter variable
 */
 
 
 
 #if 0
 void module_readParameters_CriticCaustic(std::string infile, cline_param *cline){
 	
     std::string first, second, third, line1, line2;
     //cast variables
     double cast_1;
     //Default value initialiasation
     cline->nplan = 0;
     for(int i =0; i < NPZMAX; ++i){
 		cline->cz[i] = 0;
 	    cline->dos[i] = 0;
 	    cline->dls[i] = 0;
 	    cline->dlsds[i] = 0;
 	}
 
     cline->limitLow = 1;
     cline->dmax = 1;
     cline->limitHigh = 10;
     cline->nbgridcells = 1000;
 
 	std::ifstream IN(infile.c_str(), std::ios::in);
     if ( IN ){
 		while(std::getline(IN,line1)){
 			std::istringstream read1(line1); // create a stream for the line
 			read1 >> first;
 			if ( strncmp(first.c_str(), "cline", 5) == 0){    // Read in runmode information
 	            std::getline(IN,line2);
 				std::istringstream read2(line2);
 				read2 >> second >> third;    // Read in 4 words
 	    		while (strncmp(second.c_str(), "end", 3))    // Read until we reach end
 	    		{	
 	        		if ( !strcmp(second.c_str(), "nplan") ){
 						sscanf(third.c_str(), "%d", &cline->nplan);
 				            if ( cline->nplan > NPZMAX ){
 				                cline->nplan = NPZMAX;
 							}
 							int j = 0;
 				            while ( read2 >> third )
 				            {
 				                sscanf(third.c_str(), "%lf", &cast_1);
 				                cline->cz[j] =(type_t)cast_1;
 				                //printf(" zf %f \n",cline->cz[j]);
 				                j++;
 				            }
 						}
 	            		
 					if ( !strcmp(second.c_str(), "dmax") )
 	        		{
 	            		sscanf(third.c_str(), "%lf", &cast_1);
 	            		cline->dmax =(type_t)cast_1;
 	            		cline->xmax = cline->dmax;
 	            		cline->xmin = -cline->dmax;
 	            		cline->ymax = cline->dmax;
 	            		cline->ymin = -cline->dmax;	            		
 	        		}
 	        		if ( !strcmp(second.c_str(), "pas") || !strcmp(second.c_str(), "step") || !strcmp(second.c_str(), "limitLow") )
 	        		{
 						sscanf(third.c_str(), "%lf", &cast_1);
 						cline->limitLow =(type_t)cast_1;
 	        		}
 	        		if ( !strcmp(second.c_str(), "limitHigh") )
 	        		{
 						sscanf(third.c_str(), "%lf", &cast_1);
 						cline->limitHigh =(type_t)cast_1;
 	        		}
 	        		if ( !strcmp(second.c_str(), "nbgridcells") )
 	        		{
 						sscanf(third.c_str(), "%d", &cline->nbgridcells);
 	        		}
 					// Read the next line
 					std::getline(IN,line2);
 					std::istringstream read2(line2);
 					read2 >> second >> third;
 	    		}
 		    }  
 		} // closes while loop    
 
 }  // closes if(IN)
 
 
 
 IN.close();
 	
 }
 #endif
 
 /** @brief This module function reads the potfile information
  *@param infile path to file
 * @param potfile_param potfile parameter variable
 */
 
 
 
 void module_readParameters_readpotfiles_param(std::string infile, potfile_param *potfile, cosmo_param cosmology){
 
     std::string first, second, third, line1, line2;
     //cast variables
     double cast_1, cast_2;
     //Default value potfile initialiasation
 
     potfile->potid = 0;
     potfile->ftype = 0;
     potfile->type = 0;
     potfile->zlens = 0;
     potfile->mag0 = 0;
     potfile->isigma = 0;
     potfile->sigma = -1;
     potfile->core = -1.0;
     potfile->corekpc = -1;
     potfile->ircut = 0;
     potfile->cut1 = DBL_MAX;
     potfile->cut2 = 0;
     potfile->cutkpc1 = DBL_MAX;
     potfile->cutkpc2 = 0;
     potfile->islope = 0;
     potfile->slope1 = 0;
     potfile->slope2 = 0;
     potfile->npotfile = 0;
     potfile->ivdscat = 0;
 	potfile->vdscat1 =0;
 	potfile->vdscat2 = 0;
     potfile->ircutscat = 0;
 
 	std::ifstream IN(infile.c_str(), std::ios::in);
     if ( IN ){
 		while(std::getline(IN,line1)){
 			std::istringstream read1(line1); // create a stream for the line
 			read1 >> first;
 			if ( strncmp(first.c_str(), "potfile", 7) == 0){    // Read in potfile information
 	            std::getline(IN,line2);
 				std::istringstream read2(line2);
 				read2 >> second >> third;    // Read in 4 words
 	    		while (strncmp(second.c_str(), "end", 3))    // Read until we reach end
 	    		{
 
 					if ( !strcmp(second.c_str(), "filein") )
 	        		{
 						sscanf(line2.c_str(), " %*s %d %s ", &potfile->ftype, potfile->potfile);
 	        		}
 					else if ( !strcmp(second.c_str(), "type") )
 	        		{
 						sscanf(third.c_str(), "%d", &potfile->type);
 	        		}
 					else if ( !strcmp(second.c_str(), "zlens") || !strcmp(second.c_str(), "z_lens"))
 	        		{
 						sscanf(third.c_str(), "%lf", &cast_1);
 						potfile->zlens =(type_t)cast_1;
 	        		}
 
 	        		else if (!strcmp(second.c_str(), "mag0") || !strcmp(second.c_str(), "r200"))
 					{
 						sscanf(third.c_str(), "%lf", &cast_1);
 						potfile->mag0 =(type_t)cast_1;
 					}
 					else if (!strcmp(second.c_str(), "select"))
 					{
 						sscanf(third.c_str(), "%d", &potfile->select);
 					}
 					else if (!strcmp(second.c_str(), "core"))
 					{
 						sscanf(third.c_str(), "%lf", &cast_1);
 						potfile->core =(type_t)cast_1;
 					}
 					else if (!strcmp(second.c_str(), "corekpc"))
 					{
 						sscanf(third.c_str(), "%lf", &cast_1);
 						potfile->corekpc =(type_t)cast_1;
 					}
 					else if (!strcmp(second.c_str(), "cut"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ircut, &cast_1, &cast_2);
 						potfile->cut1 =(type_t)cast_1;
 						potfile->cut2 =(type_t)cast_2;
 					}
 					else if (!strcmp(second.c_str(), "cutkpc"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ircut, &cast_1, &cast_2);
 						potfile->cutkpc1 =(type_t)cast_1;
 						potfile->cutkpc2 =(type_t)cast_2;
 					}
 					else if (!strcmp(second.c_str(), "slope") || !strcmp(second.c_str(), "m200slope"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->islope, &cast_1, &cast_2);
 						potfile->slope1 =(type_t)cast_1;
 						potfile->slope2 =(type_t)cast_2;
 					}
 					else if (!strcmp(second.c_str(), "sigma"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->isigma, &cast_1, &cast_2);
 						potfile->sigma1 =(type_t)cast_1;
 						potfile->sigma2 =(type_t)cast_2;
 					}
 					else if (!strcmp(second.c_str(), "vdslope") || !strcmp(second.c_str(), "c200slope"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ivdslope, &cast_1, &cast_2);
 						potfile->vdslope1 =(type_t)cast_1;
 						potfile->vdslope2 =(type_t)cast_2;
 					}
 					else if (!strncmp(second.c_str(), "vdscat", 6))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ivdscat, &cast_1, &cast_2);
 						potfile->vdscat1 =(type_t)cast_1;
 						potfile->vdscat2 =(type_t)cast_2;
 					}
 					else if (!strncmp(second.c_str(), "rcutscat", 8))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ircutscat, &cast_1, &cast_2);
 						potfile->rcutscat1 =(type_t)cast_1;
 						potfile->rcutscat2 =(type_t)cast_2;
 					}
 					else if (!strcmp(second.c_str(), "a") || !strcmp(second.c_str(), "m200"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ia, &cast_1, &cast_2);
 						potfile->a1 =(type_t)cast_1;
 						potfile->a2 =(type_t)cast_2;
 					}
 					else if (!strcmp(second.c_str(), "b") || !strcmp(second.c_str(), "c200"))
 					{
 						sscanf(line2.c_str(), " %*s %d%lf%lf", &potfile->ib, &cast_1, &cast_2);
 						potfile->b1 =(type_t)cast_1;
 						potfile->b2 =(type_t)cast_2;
 					}
 
 					// Read the next line
 					std::getline(IN,line2);
 					std::istringstream read2(line2);
 					read2 >> second >> third;
 	    		}
 		    }
 		} // closes while loop
 
 }  // closes if(IN)
 
 IN.close();
 
 //Calculate vdisp, rcut and rcore
 
 //*********************************************************************
 // Set the Potfile current and limiting values
 //*********************************************************************
 if ( potfile->ftype <= 4 )
 {
     // Scale potfile SIGMA
 	potfile->sigma = potfile->sigma1;
 
     // ... and potfile RCUT
     if ( potfile->cut1 == DBL_MAX && potfile->cutkpc1 != DBL_MAX )
     {
     	potfile->cut1 = potfile->cutkpc1 / (d0 / cosmology.h * module_cosmodistances_observerObject(potfile->zlens,cosmology));
     	potfile->cut2 = potfile->cutkpc2 / (d0 / cosmology.h * module_cosmodistances_observerObject(potfile->zlens,cosmology));
     }
     potfile->cut = potfile->cut1;
 
     // ... and potfile RCORE
     if ( potfile->core == -1.0 && potfile->corekpc != -1 )
     	potfile->core = potfile->corekpc / (d0 / cosmology.h * module_cosmodistances_observerObject(potfile->zlens,cosmology));
 
     // ... and potfile RCUT SLOPE
     potfile->slope = potfile->slope1;
 
     // ... and potfile VDSLOPE
     potfile->vdslope = potfile->vdslope1;
 }
 
 
 
 
 }
 
 /** @brief This module function loads the potential from the potfile into a lens
  *@param infile path to file
 * @param cline cline parameter variable
 */
 
 
 /*
 void module_readParameters_readpotfiles(const runmode_param *runmode, potfile_param *potfile, Potential *lens){
 
 	std::string first, second, line1;
 	double cast_1, cast_2;
 	double aa,bb;
 	double DTR=acos(-1.)/180.;
 	//cast variables
 	double cast_x,cast_y,cast_theta,cast_lum,cast_mag;
 	potfile->reference_ra = potfile->reference_dec = 0;
 	std::cerr << "Ref pot: "<< potfile->reference_ra <<  " " << potfile->reference_dec << std::endl;
 
 // Read in potentials
     std::ifstream IM(potfile->potfile,std::ios::in);
 	if ( IM )
     	{
 			int i = runmode->nhalos;
         	while( std::getline(IM,line1) )    // Read until we reach the end
         	{
     			std::istringstream read1(line1); // create a stream for the line
     			read1 >> first;
                 // Skip commented lines with #
     			//std::cerr << first << std::endl;
                 if (!strncmp(first.c_str(), "#REFERENCE", 10) ){
                 	sscanf(line1.c_str(), " %*s %*d%lf%lf",  &cast_1, &cast_2);
                 	potfile->reference_ra = (type_t) cast_1;
                 	potfile->reference_dec = (type_t) cast_2;
                 	std::cerr << "Ref potfiles: "<< potfile->reference_ra <<  " " << potfile->reference_dec << std::endl;
                     continue;
 
                 }
                 else if ( line1[0] == '#' ){
                 	 continue;
                 }
 
 
                 // Default initialisation of clump
                 lens[i].type = potfile->type;
                 lens[i].z = potfile->zlens;
                 lens[i].ellipticity_potential = lens[i].ellipticity = 0.;
                 lens[i].alpha  = 0.;
                 lens[i].rcut = 0.;
                 lens[i].rcore = 0.;
                 lens[i].rscale = 0.;
                 lens[i].mag = 0.;
                 lens[i].lum = 0.;
                 lens[i].vdisp = 0.;
                 lens[i].position.x = lens[i].position.y = 0.;
                 lens[i].ellipticity_angle = 0.;
                 lens[i].weight = 0;
                 lens[i].exponent = 0;
                 lens[i].einasto_kappacritic = 0;
 
 
 				// Read a line of the catalog
 				if ( potfile->ftype == 1 || potfile->ftype == 3 )
 				{
 						sscanf( line1.c_str(), "%s%lf%lf%lf%lf%lf%lf%lf",
 							&lens[i].name, &cast_x, &cast_y,
 								 &aa, &bb, &cast_theta, &cast_mag, &cast_lum);
 						lens[i].ellipticity = (type_t) (aa*aa-bb*bb)/(aa*aa+bb*bb);
 						if ( lens[i].ellipticity < 0 )
 						{
 							fprintf( stderr, "ERROR: The potfile clump %s has a negative ellipticity.\n", lens[i].name );
 							exit(-1);
 						}
 						//goto NEXT;
 
 				}
 
 
 				//Casting
 				lens[i].position.x =(type_t)cast_x;
 				lens[i].position.y =(type_t)cast_y;
 				lens[i].theta =(type_t)cast_theta;
 				lens[i].lum =(type_t)cast_lum;
 				lens[i].mag =(type_t)cast_mag;
 				//general parameters
 				lens[i].vdisp = potfile->sigma;
 				lens[i].rcore = potfile->core;
 				lens[i].rcut = potfile->cut;
 				lens[i].ellipticity_angle = lens[i].theta* DTR;
 
 			    //Calculate parameters like b0, potential ellipticity and anyother parameter depending on the profile
 			    module_readParameters_calculatePotentialparameter(&lens[i]);
 
 				//Variables
 				potfile->npotfile++;
 				i++;
 		}
 	}
 	else{
 			std::cout << "Error : file "  << potfile->potfile <<  " not found" << std::endl;
 			exit(-1);
 		}
 
 	IM.close();
 
 }
 */
 void module_readParameters_readpotfiles_SOA(const runmode_param *runmode, const cosmo_param *cosmology, potfile_param *potfile, Potential_SOA *lens){
 
 	std::string first, second, line1;
 	double cast_1, cast_2;
 	double aa,bb;
 	double DTR=acos(-1.)/180.;	/* 1 deg in rad  = pi/180 */
 	//cast variables
 	double cast_x,cast_y,cast_theta,cast_lum,cast_mag, cast_name;
 
 
 // Read in potentials
     std::ifstream IM(potfile->potfile,std::ios::in);
 	if ( IM )
     	{
 			int i = runmode->nhalos;
         	while( std::getline(IM,line1) )    // Read until we reach the end
         	{
     			std::istringstream read1(line1); // create a stream for the line
     			read1 >> first;
                 // Skip commented lines with #
     			std::cerr << first << std::endl;
                  if (!strncmp(first.c_str(), "#REFERENCE", 10)){
                 	sscanf(line1.c_str(), " %*s %d%lf%lf", &potfile->reference_mode,  &cast_1, &cast_2);
                 	potfile->reference_ra = (type_t) cast_1;
                 	potfile->reference_dec = (type_t) cast_2;
                 	std::cerr << "Ref pot: "<< potfile->reference_ra << " " << potfile->reference_dec << std::endl;
                     continue;
 
 
                 }
                 // Skip commented lines with #
                 else if ( line1[0] == '#' )
                     continue;
 
                 //std::cerr << "Turn " << i << std::endl;
 
                 // Default initialisation of clump
                 lens->type[i] = potfile->type;
                 lens->z[i] = potfile->zlens;
                 lens->ellipticity_potential[i] = lens->ellipticity[i] = 0.;
                 lens->alpha[i]  = 0.;
                 lens->rcut[i] = 0.;
                 lens->rcore[i] = 0.;
                 lens->rscale[i] = 0.;
                 lens->mag[i] = 0.;
                 lens->lum[i] = 0.;
                 lens->vdisp[i] = 0.;
                 lens->position_x[i] = lens->position_y[i] = 0.;
                 lens->ellipticity_angle[i] = 0.;
                 lens->weight[i] = 0;
                 lens->exponent[i] = 0;
                 lens->einasto_kappacritic[i] = 0;
 
                 //std::cerr << "Init finished "<< std::endl;
 
 
 				// Read a line of the catalog
 				if ( potfile->ftype == 1 || potfile->ftype == 3 )
 				{
 						sscanf( line1.c_str(), "%lf%lf%lf%lf%lf%lf%lf%lf",
 							&cast_name, &cast_x, &cast_y,
 								 &aa, &bb, &cast_theta, &cast_mag, &cast_lum);
 						lens->ellipticity[i] = (type_t) (aa*aa-bb*bb)/(aa*aa+bb*bb);
 						if ( lens->ellipticity[i] < 0 )
 						{
 							fprintf( stderr, "ERROR: The potfile clump %d has a negative ellipticity.\n", i );
 							exit(-1);
 						}
 						//goto NEXT;
 
 				}
 
 
 				//Casting
 				lens->name[i] =(type_t)cast_name;
 				lens->position_x[i] =(type_t)cast_x;
 				lens->position_y[i] =(type_t)cast_y;
 				//module_cosmodistances_relativecoordinates_XY( &lens->position_x[i], &lens->position_y[i], potfile->reference_mode, potfile->reference_ra, potfile->reference_dec );
 				lens->theta[i] =(type_t)cast_theta;
 				lens->lum[i] =(type_t)cast_lum;
 				lens->mag[i] =(type_t)cast_mag;
 				//general parameters
 				//lens->vdisp[i] = potfile->sigma;
 				//lens->rcore[i] = potfile->core;
 				//lens->rcut[i] = potfile->cut;
 				lens->ellipticity_angle[i] = lens->theta[i]* DTR;
 				lens->anglecos[i]	     = cos(lens->ellipticity_angle[i]);
 				lens->anglesin[i] 	     = sin(lens->ellipticity_angle[i]);
 
 
 
 				//Variables
 				potfile->npotfile++;
 				i++;
 		}
 
         	setScalingRelations(runmode,cosmology,potfile,lens);
 
 
 
 
 
 
 
 	}
 	else{
 			std::cout << "Error : file "  << potfile->potfile <<  " not found" << std::endl;
 			exit(-1);
 		}
 
 	IM.close();
 
 }
 
 void setScalingRelations(const runmode_param *runmode, const cosmo_param *cosmology, potfile_param *pot, Potential_SOA* lenses){
 
     //*********************************************************************
     // Check if the scaling relations are defined
     //*********************************************************************
     if ( pot->ftype == 1 )
     {
         if ( pot->sigma1 == -1 )
         {
             fprintf(stderr, "ERROR: potfile: sigma not defined\n");
             exit(-1);
         }
 
         if ( pot->cutkpc1 == DBL_MAX && pot->cut1 == DBL_MAX )
         {
             fprintf(stderr, "ERROR: potfile: cut length not defined\n");
             exit(-1);
         }
 
         if ( pot->corekpc == -1 && pot->core == -1 )
         {
             fprintf(stderr, "ERROR: potfile: core length not defined\n");
             exit(-1);
         }
     }
     else{
     	fprintf(stderr, "ERROR: potfile: potfile type %d not supported\n", pot->ftype);
     	            exit(-1);
     }
 
     //*********************************************************************
     // Set the Potfile current and limiting values
     //*********************************************************************
     if ( pot->ftype <= 4 )
     {
         // Scale potfile SIGMA
         pot->sigma = pot->sigma1;
 
         // ... and potfile RCUT
         if ( pot->cut1 == DBL_MAX && pot->cutkpc1 != DBL_MAX )
         {
             pot->cut1 = pot->cutkpc1 / (d0 / cosmology->h * module_cosmodistances_observerObject(pot->zlens,*cosmology));
             pot->cut2 = pot->cutkpc2 / (d0 / cosmology->h * module_cosmodistances_observerObject(pot->zlens,*cosmology));
         }
         pot->cut = pot->cut1;
 
         // ... and potfile RCORE
         if ( pot->core == -1.0 && pot->corekpc != -1 )
             pot->core = pot->corekpc / (d0 / cosmology->h * module_cosmodistances_observerObject(pot->zlens,*cosmology));
 
         // ... and potfile RCUT SLOPE
         pot->slope = pot->slope1;
 
         // ... and potfile VDSLOPE
         pot->vdslope = pot->vdslope1;
     }
 
     // set potfile VDSCAT for all potfile scaling relations
      pot->vdscat = pot->vdscat1;
 
      // ... and potfile RCUTSCAT
      pot->rcutscat = pot->rcutscat1;
 
 
      for ( int i = runmode->nhalos ; i < runmode->npotfile+runmode->nhalos ; i++ ){
          if ( lenses->mag[i] != 0 ){
         	 lenses->rcore[i] = pot->core * pow(10., 0.4 * (pot->mag0 - lenses->mag[i]) / 2.);}
 		 /*
 		  * Scale the sigma and rcut of a potfile clump according to the potfile parameters
 		  */
          // loop over the potfile clumps to scale
          if ( pot->ftype <= 4 )
          {
 
 
                  if ( lenses->mag[i] != 0 )
                  {
                 	 lenses->vdisp[i] = pot->sigma *
                                     pow(10., 0.4 * (pot->mag0 - lenses->mag[i]) / pot->vdslope);
                      /* The factor of 2 so that with slope1 = 4, we have
                       * 2/slope1=1/2, then Brainerd, Blandford, Smail, 1996 */
                 	 lenses->rcut[i] = pot->cut *
                                    pow(10., 0.4 * (pot->mag0 - lenses->mag[i]) * 2. / pot->slope);
                  }
 
                  if ( pot->ivdscat != 0 ){
                 	 fprintf(stderr, "ERROR: potfile: ivdscat not supported yet\n");
                 	 exit(-1);
                  }
 
                  // Convert sigma to b0
                  //set_dynamics(i);
 
                  if ( pot->ircutscat != 0 ){
                 	 fprintf(stderr, "ERROR: potfile: ircutscat not supported yet\n");
                 	 exit(-1);
                  }
              }
          //Calculate parameters like b0, potential ellipticity and anyother parameter depending on the profile
 		 module_readParameters_calculatePotentialparameter_SOA(lenses,i);
          }
 
 
 
 }
 
 
 
 /** @brief read the information about arclets
 * !Not used! Will be reworked
 * This module function reads in the arclet images for weak lensing
 * @param Arclet file
 */
 
 
 void module_readParameters_arclets(std::string arclets_filename, point arclets_position[], ellipse arclets_shape[], double arclets_redshift[])
 {
 	std::string second, line1;
 	int j=0;
 	//cast variables
 	double cast_x,cast_y,cast_a,cast_b,cast_theta,cast_z;
 
 
 /******************** read the arclets file *******************/
 /* the arclets file must contain
 			id	x_center y_center   a   b   theta   redshift
 line :	1          	 .	   .        .       .   .     .        .        
 	2
 	3
 	.
 	.
 	narclets
 */
 
     std::ifstream IM(arclets_filename.c_str(),std::ios::in);
 	if ( IM )
     	{
         	while( std::getline(IM,line1))    // Read every line
         	{       // Read in parameters, * means we read the parameter but don't store it (*s)   
 			sscanf(line1.c_str(), "%*s %lf %lf %lf %lf %lf %lf", &cast_x, &cast_y, &cast_a, &cast_b, &cast_theta, &cast_z);
 			//Casting
 			arclets_position[j].x =(type_t)cast_x;
 			arclets_position[j].y =(type_t)cast_y;
 			arclets_shape[j].a =(type_t)cast_a;
 			arclets_shape[j].b =(type_t)cast_b;
 			arclets_shape[j].theta =(type_t)cast_theta;
 			arclets_redshift[j] =(type_t)cast_z;
 
 			j++;
 		}
 		IM.close();
 	}
 	else
 	{
 		printf("Error : file %s not found\n",arclets_filename.c_str());
 		exit(-1);
 	}
 }
 
 
 /** @brief This module function reads in if a parameter will be optimized by the MCMC or stay fixed. 
  * 
  * This module function reads in if a parameter will be optimized by the MCMC or stay fixed. 
  * If it will be optimized, it specifies its minimum and maximum allowed values. Unless declared otherwise by the user, input values are fixed and won't be optimized.
 * 
 * read an infile :
 	|  .
 	|  .
 	|limit
 	|	x_center x  x  x  x  <--- these values contains : block  min  max  accuracy
 	|	y_center x  x  x  x		if block=1 this is a free parameter, otherwise not
 	|	   .	 .  .  .  .		min and max define the extremal value of this parameter
 	|	   .	 .  .  .  .		accuracy is a criterium of convergence for the MCMC
 	|	  end
 	|  .
 	|  .
 	|limit
 	|	x_center x  x  x  x
 	|	y_center x  x  x  x
 	|	   .	 .  .  .  .
 	|	   .	 .  .  .  .
 	|	  end
 	|  .
 	|  .
 	|finish
 and fills the variables with these values
 * @param infile path to input file
 * @param host_potentialoptimization array where limits will be stored
 * @param nhalos number of mass distributions
 
 */
 
 void module_readParameters_limit(std::string infile, struct potentialoptimization host_potentialoptimization[], int nhalos )
 {
     std::string first, second, line1, line2;
     int i=0;
 	//cast variables
 	double cast_min,cast_max,cast_sigma;
 	//double d1 = d0 / cosmology.h * module_cosmodistances_observerObject(lens_temp.z,cosmology);
 
  type_t DTR=acos(-1.)/180.;	/* 1 deg in rad  = pi/180 */
 
 /*** initialize the block variables to zero (= not to be optimized) ***/
 for(int index=0; index<nhalos; index++)
 {
 	host_potentialoptimization[index].position.x.block=0;
 	host_potentialoptimization[index].position.y.block=0;
 	host_potentialoptimization[index].vdisp.block = 0;
 	host_potentialoptimization[index].weight.block=0;
 	host_potentialoptimization[index].ellipticity_angle.block=0;
 	host_potentialoptimization[index].ellipticity.block=0;
 	host_potentialoptimization[index].rcore.block=0;
 	host_potentialoptimization[index].rcut.block=0;
 	host_potentialoptimization[index].rscale.block=0;
 	host_potentialoptimization[index].exponent.block=0;
 	host_potentialoptimization[index].alpha.block=0;
 	host_potentialoptimization[index].einasto_kappacritic.block=0;
 	host_potentialoptimization[index].z.block=0;
 }
 
 
 
 
 // Read in 
 std::ifstream IN(infile.c_str(), std::ios::in);
     if ( IN )
     {
 	while(std::getline(IN,line1))
 	{   
 	    	std::istringstream read1(line1);
 	    	read1 >> first;
 
 
 		if (!strncmp(first.c_str(), "limit", 5))  // Read the limits
 		{
                 while(std::getline(IN,line2))
                 {
                     std::istringstream read2(line2);
                     read2 >> second;    // Read in 1 word
                     if (strcmp(second.c_str(), "end") == 0) break;  // stop reading at "end" and move to next potential limit section
                 
 
                     if (!strcmp(second.c_str(), "x_centre") ||    // Read in for x center
 	                !strcmp(second.c_str(), "x_center") )
                     {
                         sscanf(line2.c_str(), "%*s %d %lf %lf %lf", &host_potentialoptimization[i].position.x.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].position.x.min =(type_t)cast_min;
                         host_potentialoptimization[i].position.x.max =(type_t)cast_max;
                         host_potentialoptimization[i].position.x.sigma =(type_t)cast_sigma;
                     }
                     else if (!strcmp(second.c_str(), "y_centre") ||  // Read in for y center
             		 !strcmp(second.c_str(), "y_center") )
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].position.y.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].position.y.min =(type_t)cast_min;
                         host_potentialoptimization[i].position.y.max =(type_t)cast_max;
                         host_potentialoptimization[i].position.y.sigma =(type_t)cast_sigma;
                     }
                     else if ( !strcmp(second.c_str(), "v_disp") )  // Read in for ellipticity
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].vdisp.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].vdisp.min =(type_t)cast_min;
                         host_potentialoptimization[i].vdisp.max =(type_t)cast_max;
                         host_potentialoptimization[i].vdisp.sigma =(type_t)cast_sigma;
                     }
                     else if ( !strcmp(second.c_str(), "ellip_pot") )  // Read in for ellipticity
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].ellipticity_potential.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].ellipticity_potential.min =(type_t)cast_min;
                         host_potentialoptimization[i].ellipticity_potential.max =(type_t)cast_max;
                         host_potentialoptimization[i].ellipticity_potential.sigma =(type_t)cast_sigma;
                     }
                     else if ( !strcmp(second.c_str(), "ellipticitymass") || !strcmp(second.c_str(), "ellipticity") || !strcmp(second.c_str(), "ellipticite") )  // Read in for ellipticity
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].ellipticity.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].ellipticity.min =(type_t)cast_min;
                         host_potentialoptimization[i].ellipticity.max =(type_t)cast_max;
                         host_potentialoptimization[i].ellipticity.sigma =(type_t)cast_sigma;
                     }
                     else if (!strcmp(second.c_str(), "ellipticity_angle") || !strcmp(second.c_str(), "angle_pos"))  // Read in for ellipticity angle
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].ellipticity_angle.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].ellipticity_angle.min =(type_t)cast_min;
                         host_potentialoptimization[i].ellipticity_angle.max =(type_t)cast_max;
                         host_potentialoptimization[i].ellipticity_angle.sigma =(type_t)cast_sigma;
 
                         host_potentialoptimization[i].ellipticity_angle.min *= DTR;
                         host_potentialoptimization[i].ellipticity_angle.max *= DTR;
                         host_potentialoptimization[i].ellipticity_angle.sigma *= DTR;
                     }
                     else if ( !strcmp(second.c_str(), "rcut") || !strcmp(second.c_str(), "cut_radius"))    // Read in for r cut
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].rcut.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].rcut.min =(type_t)cast_min;
                         host_potentialoptimization[i].rcut.max =(type_t)cast_max;
                         host_potentialoptimization[i].rcut.sigma =(type_t)cast_sigma;
                     }
                     else if (  !strcmp(second.c_str(), "cut_radius_kpc"))    // Read in for r cut
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].rcut.block,
                         		&cast_min, &cast_max, &cast_sigma);
                     }
                     else if ( !strcmp(second.c_str(), "rcore") || !strcmp(second.c_str(), "core_radius"))  // Read in for core radius
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].rcore.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].rcore.min =(type_t)cast_min;
                         host_potentialoptimization[i].rcore.max =(type_t)cast_max;
                         host_potentialoptimization[i].rcore.sigma =(type_t)cast_sigma;
                     }
                     else if ( !strcmp(second.c_str(), "NFW_rs") ||    // Read in for NFW scale radius
                               !strcmp(second.c_str(), "rscale") )
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].rscale.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].rscale.min =(type_t)cast_min;
                         host_potentialoptimization[i].rscale.max =(type_t)cast_max;
                         host_potentialoptimization[i].rscale.sigma =(type_t)cast_sigma;
                     }
             	else if ( !strcmp(second.c_str(), "exponent") )    // Read in for exponent
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].exponent.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].exponent.min =(type_t)cast_min;
                         host_potentialoptimization[i].exponent.max =(type_t)cast_max;
                         host_potentialoptimization[i].exponent.sigma =(type_t)cast_sigma;
                     }
             	else if ( !strcmp(second.c_str(), "alpha") )    // Read in for alpha
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].alpha.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].alpha.min =(type_t)cast_min;
                         host_potentialoptimization[i].alpha.max =(type_t)cast_max;
                         host_potentialoptimization[i].alpha.sigma =(type_t)cast_sigma;
                     }
             	else if ( !strcmp(second.c_str(), "einasto_kappacritic") )  // Read in for critical kappa
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].einasto_kappacritic.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].einasto_kappacritic.min =(type_t)cast_min;
                         host_potentialoptimization[i].einasto_kappacritic.max =(type_t)cast_max;
                         host_potentialoptimization[i].einasto_kappacritic.sigma =(type_t)cast_sigma;
                     }
                     else if (!strcmp(second.c_str(), "virial_mass") ||  // Read in for virial mass
                              !strcmp(second.c_str(), "masse") ||
                              !strcmp(second.c_str(), "m200") ||
                              !strcmp(second.c_str(), "mass"))
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].weight.block,
                         		&cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].weight.min =(type_t)cast_min;
                         host_potentialoptimization[i].weight.max =(type_t)cast_max;
                         host_potentialoptimization[i].weight.sigma =(type_t)cast_sigma;
                     }
                     else if ( !strcmp(second.c_str(), "z_lens") )    // Read in for redshift
                     {
                         sscanf(line2.c_str(), "%*s%d%lf%lf%lf", &host_potentialoptimization[i].z.block,
                                &cast_min, &cast_max, &cast_sigma);
                         host_potentialoptimization[i].z.min =(type_t)cast_min;
                         host_potentialoptimization[i].z.max =(type_t)cast_max;
                         host_potentialoptimization[i].z.sigma =(type_t)cast_sigma;
                     }
                 }  // end of inner while loop
                 i++; // Move to next potential
     		}
 	}
     }
 IN.close();
 }
 
 
 /** @brief This module function reads in the potential form and its parameters (e.g. NFW).
 * 
 * @param infile path to input file
 * @param lens array where mass distributions will be stored
 * @param nhalos number of mass distributions
 */
 
 
 void module_readParameters_Potential(std::string infile, Potential lens[], int nhalos)
 {
 
 	double DTR=acos(-1.)/180.;	/* 1 deg in rad  = pi/180 */
     Potential  *ilens;
     std::string first, second, third, line1, line2;
     int i=0;
 
 std::ifstream IN(infile.c_str(), std::ios::in);
     if ( IN )
     {
 	while(std::getline(IN,line1))
         {
 	    std::istringstream read1(line1); // create a stream for the line
 	    read1 >> first;
             if (!strncmp(first.c_str(), "potent", 6))  // Read in potential
 		{
 /***********************************************/
 
     ilens = &lens[i];
 
     ilens->position.x  		 = ilens->position.y = 0.;
     ilens->ellipticity 		 = 0;
     ilens->ellipticity_potential = 0.;
     ilens->ellipticity_angle 	 = 0.;
     ilens->rcut 		 = 0.;
     ilens->rcore 		 = 0;
     ilens->weight 		 = 0;
     ilens->rscale 		 = 0;
     ilens->exponent 		 = 0;
     ilens->alpha 		 = 0.;
     ilens->einasto_kappacritic   = 0;
     ilens->z 			 = 0;
 
 
     while(std::getline(IN,line2))
     {
     	std::istringstream read2(line2);
     	read2 >> second >> third;
     	if (strcmp(second.c_str(), "end") == 0)  // Move to next potential and initialize it
         {
    	    if ( ilens->z == 0. )  // Check if redshift from current halo was initialized
             {
                 fprintf(stderr, "ERROR: No redshift defined for potential %d\n", i);
                 exit(-1);
             }
       
             break; // Break while loop and move to next potential
 
         }
     
  	// Read in values
  	
         if ( !strcmp(second.c_str(), "profil") ||  // Get profile
              !strcmp(second.c_str(), "profile") )
         {
 		if(!strcmp(third.c_str(), "PIEMD") ||
 		   !strcmp(third.c_str(), "1") )
 		{
 			ilens->type=1;
 			strcpy(ilens->type_name,"PIEMD");//ilens->type_name="PIEMD";
 		}
 		if(!strcmp(third.c_str(), "NFW") ||
 		   !strcmp(third.c_str(), "2") )
 		{
 			ilens->type=2;
 			strcpy(ilens->type_name,"NFW");//ilens->type_name="NFW";
 		}
 		if(!strcmp(third.c_str(), "SIES") ||
 		   !strcmp(third.c_str(), "3") )
 		{
 			ilens->type=3;
 			strcpy(ilens->type_name,"SIES");//ilens->type_name="SIES";
 		}
 		if(!strncmp(third.c_str(), "point", 5) ||
 		   !strcmp(third.c_str(), "4") )
 		{
 			ilens->type=4;
 			strcpy(ilens->type_name,"point");//ilens->type_name="point";
 		}
 		if(!strcmp(third.c_str(), "SIE") ||
 		   !strcmp(third.c_str(), "5") )
 		{
 			ilens->type=5;
 			strcpy(ilens->type_name,"SIE");//ilens->type_name="point";
 		}
 		if(!strcmp(third.c_str(), "8") )
 		{
 			ilens->type=8;
 			strcpy(ilens->type_name,"PIEMD1");//ilens->type_name="point";
 		}
 		if(!strcmp(third.c_str(), "81") )
 		{
 			ilens->type=81;
 			strcpy(ilens->type_name,"PIEMD81");//ilens->type_name="point";
 		}
 		
         }
         
         else if (!strcmp(second.c_str(), "name"))    // Get name of lens
         {
             sscanf(third.c_str(),"%s",ilens->name);
         }
         
         else if (!strcmp(second.c_str(), "x_centre") ||  // Get x center
 		 !strcmp(second.c_str(), "x_center") )
         {
             ilens->position.x=atof(third.c_str());
             //std::cout << "PositionX : " << std::setprecision(15) << ilens->position.x << std::endl;
         }
         else if (!strcmp(second.c_str(), "y_centre") ||  // Get y center
 		 !strcmp(second.c_str(), "y_center") )
         {
             ilens->position.y=atof(third.c_str());
         }
         else if ( !strcmp(second.c_str(), "ellipticitymass") || !strcmp(second.c_str(), "ellipticity") )  // Get ellipticity
         {
             ilens->ellipticity=atof(third.c_str());
             //ilens->ellipticity=ilens->ellipticity/3.;
         }
         else if (!strcmp(second.c_str(), "ellipticity_angle") || !strcmp(second.c_str(), "angle_pos"))  // Get ellipticity angle
         {
             ilens->ellipticity_angle=atof(third.c_str());
             ilens->ellipticity_angle *= DTR;
         }
         else if ( !strcmp(second.c_str(), "rcore") || !strcmp(second.c_str(), "core_radius"))  // Get core radius
         {
             ilens->rcore=atof(third.c_str());
         }
         else if (!strcmp(second.c_str(), "rcut") || !strcmp(second.c_str(), "cut_radius"))  // Get cut radius
         {
             ilens->rcut=atof(third.c_str());
         }
 		else if (!strcmp(second.c_str(), "NFW_rs") ||  // Get scale radius of NFW
 			 !strcmp(second.c_str(), "rscale"))
 	        {
 	            ilens->rscale=atof(third.c_str());
 	        }
 		else if (!strcmp(second.c_str(), "exponent") )  // Get exponent
 	        {
 	            ilens->exponent=atof(third.c_str());
 	        }
 		else if (!strcmp(second.c_str(), "alpha") )  // Get alpha
 	        {
 	            ilens->alpha=atof(third.c_str());
 	        }
 		else if (!strcmp(second.c_str(), "einasto_kappacritic") ||  // Get critical kappa 
 			 !strcmp(second.c_str(), "kappacritic"))
         {
             ilens->einasto_kappacritic=atof(third.c_str());
         }
         else if (!strcmp(second.c_str(), "z_lens"))  // Get redshift
         {
             ilens->z=atof(third.c_str());
         }
         else if (!strcmp(second.c_str(), "v_disp"))  // Get Dispersion velocity
         {
             ilens->vdisp=atof(third.c_str());
         }
         else if ( !strncmp(second.c_str(), "virial_mass", 6) ||  // Get virial mass
                   !strcmp(second.c_str(), "masse") ||
                   !strcmp(second.c_str(), "m200") ||
                   !strcmp(second.c_str(), "mass") )
         {
             ilens->weight=atof(third.c_str());
         }
 
 
     } // closes inner while loop
     
     //Calculate parameters like b0, potential ellipticity and anyother parameter depending on the profile
     module_readParameters_calculatePotentialparameter(ilens);
   
     i++; // Set counter to next potential
 
 
 
 
 }  // closes if loop
 
 }  // closes while loop
 
 if(i==0){
 	printf("Parameter potential not found in the file %s",infile.c_str());
 	exit(-1);
 	}
 if(i>1){
 	for(int j=1; j<i; j++)
 		{
 		if(lens[j].z!=lens[j-1].z) printf("Warning : Some halos have different redshifts ! They should be in the same plane (same redshift) !\n");
 		}
 	}
 
 }  // closes if(IN)
 
 IN.close();
 
 }
 
 /** @brief Finds the amount of potential of same types. Has to be updated when introducing a new type of potential.
 *
 */
 
 
 void read_potentialSOA_ntypes(std::string infile, int N_type[]){
 
 	int ind = 0;
 	std::string first, second, third, line1, line2;
 
     std::ifstream IN(infile.c_str(), std::ios::in);
     //First sweep throught the runmode file to find N_type (number of types)
     if ( IN )
     {
 	while(std::getline(IN,line1))
         {
 	    std::istringstream read1(line1); // create a stream for the line
 	    read1 >> first;
             if (!strncmp(first.c_str(), "potent", 6))  // Read in potential
 			{
                 while(std::getline(IN,line2))
                 {
                 	std::istringstream read2(line2);
                 	read2 >> second >> third;
             	if (strcmp(second.c_str(), "end") == 0)  // Move to next potential and initialize it
 					{
 						break; // Break while loop and move to next potential
 					}
 
             	if ( !strcmp(second.c_str(), "profil") ||  // Get profile
 						 !strcmp(second.c_str(), "profile") )
 					{
 					if(!strcmp(third.c_str(), "PIEMD") ||
 					   !strcmp(third.c_str(), "1") )
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 					}
 
 					if(!strcmp(third.c_str(), "NFW") ||
 					   !strcmp(third.c_str(), "2") )
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 					}
 					if(!strcmp(third.c_str(), "SIES") ||
 					   !strcmp(third.c_str(), "3") )
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 					}
 					if(!strncmp(third.c_str(), "point", 5) ||
 					   !strcmp(third.c_str(), "4") )
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 					}
 					if(!strcmp(third.c_str(), "SIE") ||
 					   !strcmp(third.c_str(), "5") )
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 					}
 					if(!strcmp(third.c_str(), "8") )	//PIEMD
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 					}
 					if(!strcmp(third.c_str(), "81") )	//PIEMD81
 					{
 						ind=atoi(third.c_str());
 						N_type[ind] += 1;
 						//std::cerr << "Type First: " << ind << std::endl;
 					}
 				}
                 }
 			}
 		}
     }
 
 	IN.close();
 	IN.clear();
 	IN.open(infile.c_str(), std::ios::in);
 
 }
 
 void module_readParameters_PotentialSOA_direct(std::string infile, Potential_SOA *lens_SOA, int nhalos, int npotfiles, cosmo_param cosmology){
 
 
 	double DTR=acos(-1.)/180.;	/* 1 deg in rad  = pi/180 */
 
 	double core_radius_kpc = 0.;
 	double cut_radius_kpc = 0.;
 
 	int N_type[100];
 	int Indice_type[100];
 	int ind;
 	Potential lens_temp;
 	//Init of lens_SOA
 	lens_SOA->name = 	new type_t[nhalos+npotfiles];
 	lens_SOA->type = 	new int[nhalos+npotfiles];
 	lens_SOA->position_x  = 	new type_t[nhalos+npotfiles];
 	lens_SOA->position_y = 		new type_t[nhalos+npotfiles];
 	lens_SOA->b0 = 	new type_t[nhalos+npotfiles];
 	lens_SOA->vdisp = 	new type_t[nhalos+npotfiles];
 	lens_SOA->ellipticity_angle = new type_t[nhalos+npotfiles];
 	lens_SOA->ellipticity = new type_t[nhalos+npotfiles];
 	lens_SOA->ellipticity_potential = new type_t[nhalos+npotfiles];
 	lens_SOA->rcore = 	new type_t[nhalos+npotfiles];
 	lens_SOA->rcut = 	new type_t[nhalos+npotfiles];
 	lens_SOA->z = 		new type_t[nhalos+npotfiles];
 	lens_SOA->anglecos = 	new type_t[nhalos+npotfiles];
 	lens_SOA->anglesin = 		new type_t[nhalos+npotfiles];
 
 	lens_SOA->mag = 	new type_t[nhalos+npotfiles];
 	lens_SOA->lum = 		new type_t[nhalos+npotfiles];
 	lens_SOA->weight = 	new type_t[nhalos+npotfiles];
 	lens_SOA->exponent = 		new type_t[nhalos+npotfiles];
 	lens_SOA->einasto_kappacritic = 		new type_t[nhalos+npotfiles];
 	lens_SOA->rscale = 		new type_t[nhalos+npotfiles];
 	lens_SOA->alpha = 		new type_t[nhalos+npotfiles];
 	lens_SOA->theta = 		new type_t[nhalos+npotfiles];
 
 
 
 
 	//Init of N_types and Indice_type (Number of lenses of a certain type)
 	for(int i=0;i < 100; ++i){
 		N_type[i] = 0;
 		Indice_type[i] = 0;
 	}
 
 
 
     //First sweep through the runmode file to find N_type (number of types)
     read_potentialSOA_ntypes(infile,N_type);
 
     //Calcuting starting points for each type in lens array
 	for(int i=1;i < 100; ++i){
 		Indice_type[i] = N_type[i]+Indice_type[i-1];
 		//printf("%d %d \n ",N_type[i], Indice_type[i]);
 	}
 
     std::string first, second, third, line1, line2;
     std::ifstream IN(infile.c_str(), std::ios::in);
 	if(IN){
 	while(std::getline(IN,line1))
         {
 	    std::istringstream read1(line1); // create a stream for the line
 	    read1 >> first;
             if (!strncmp(first.c_str(), "potent", 6))  // Read in potential
 		{
 			lens_temp.position.x = lens_temp.position.y = 0.;
 			lens_temp.ellipticity = 0;
 			lens_temp.ellipticity_potential = 0.;
 			lens_temp.ellipticity_angle = 0.;
 			lens_temp.vdisp = 0.;
 			lens_temp.rcut = 0.;
 			lens_temp.rcore = 0;
 			core_radius_kpc = 0.;
 			cut_radius_kpc = 0;
 			lens_temp.weight = 0;
 			lens_temp.rscale = 0;
 			lens_temp.exponent = 0;
 			lens_temp.alpha = 0.;
 			lens_temp.einasto_kappacritic = 0;
 			lens_temp.z = 0;
 			while(std::getline(IN,line2))
 			{
 				//Init temp potential
 
 
 
 				std::istringstream read2(line2);
 				read2 >> second >> third;
 				//std::cerr << line2 << std::endl;
 				if (strcmp(second.c_str(), "end") == 0)  // Move to next potential and initialize it
 				{
 					if ( lens_temp.z == 0. )  // Check if redshift from current halo was initialized
 						{
 							fprintf(stderr, "ERROR: No redshift defined for potential at position x: %f and y: %f \n", lens_temp.position.x , lens_temp.position.y);
 							exit(-1);
 						}
 					break; // Break while loop and move to next potential
 				}
 
 				//Find profile
 				if ( !strcmp(second.c_str(), "profil") ||  // Get profile
 					 !strcmp(second.c_str(), "profile") )
 				{
 					lens_temp.type=atoi(third.c_str());
 					//std::cerr << lens_temp.type << std::endl;
 				}
 
 				else if (!strcmp(second.c_str(), "name"))    // Get name of lens
 				{
 					sscanf(third.c_str(),"%s",lens_temp.name);
 				}
 
 				else if (!strcmp(second.c_str(), "x_centre") ||  // Get x center
 				 !strcmp(second.c_str(), "x_center") )
 				{
 					lens_temp.position.x=atof(third.c_str());
 					//std::cout << "PositionX : " << std::setprecision(15) << lens_temp.position.x << std::endl;
 				}
 				else if (!strcmp(second.c_str(), "y_centre") ||  // Get y center
 				 !strcmp(second.c_str(), "y_center") )
 				{
 					lens_temp.position.y=atof(third.c_str());
 				}
 				else if ( !strcmp(second.c_str(), "ellipticitymass") || !strcmp(second.c_str(), "ellipticity") || !strcmp(second.c_str(), "ellipticite") )  // Get ellipticity
 				{
 					lens_temp.ellipticity=atof(third.c_str());
 					//lens_temp.ellipticity=lens_temp.ellipticity/3.;
 				}
 				else if (!strcmp(second.c_str(), "ellipticity_angle") || !strcmp(second.c_str(), "angle_pos"))  // Get ellipticity angle
 				{
 					lens_temp.ellipticity_angle=atof(third.c_str());
 					lens_temp.ellipticity_angle *= DTR;
 				}
 				else if ( !strcmp(second.c_str(), "rcore") || !strcmp(second.c_str(), "core_radius"))  // Get core radius
 				{
 					lens_temp.rcore=atof(third.c_str());
 				}
 				else if (!strcmp(second.c_str(), "rcut") || !strcmp(second.c_str(), "cut_radius"))  // Get cut radius
 				{
 					lens_temp.rcut=atof(third.c_str());
 				}
 				else if ( !strcmp(second.c_str(), "core_radius_kpc"))  // Get core radius
 				{
 					core_radius_kpc=atof(third.c_str());
 				}
 				else if (!strcmp(second.c_str(), "cut_radius_kpc"))  // Get cut radius
 				{
 					cut_radius_kpc=atof(third.c_str());
 				}
 				else if (!strcmp(second.c_str(), "NFW_rs") ||  // Get scale radius of NFW
 					 !strcmp(second.c_str(), "rscale"))
 					{
 						lens_temp.rscale=atof(third.c_str());
 					}
 				else if (!strcmp(second.c_str(), "exponent") )  // Get exponent
 					{
 						lens_temp.exponent=atof(third.c_str());
 					}
 				else if (!strcmp(second.c_str(), "alpha") )  // Get alpha
 					{
 						lens_temp.alpha=atof(third.c_str());
 					}
 				else if (!strcmp(second.c_str(), "einasto_kappacritic") ||  // Get critical kappa
 					 !strcmp(second.c_str(), "kappacritic"))
 				{
 					lens_temp.einasto_kappacritic=atof(third.c_str());
 				}
 				else if (!strcmp(second.c_str(), "z_lens"))  // Get redshift
 				{
 					lens_temp.z=atof(third.c_str());
 					//std::cerr << lens_temp.z << std::endl;
 				}
 				else if (!strcmp(second.c_str(), "v_disp"))  // Get Dispersion velocity
 				{
 					lens_temp.vdisp=atof(third.c_str());
 					//std::cerr << "vdisp : "<< third << " " << lens_temp.vdisp << std::endl;
 				}
 				else if ( !strncmp(second.c_str(), "virial_mass", 6) ||  // Get virial mass
 						  !strcmp(second.c_str(), "masse") ||
 						  !strcmp(second.c_str(), "m200") ||
 						  !strcmp(second.c_str(), "mass") )
 				{
 					lens_temp.weight=atof(third.c_str());
 				}
 
 
 
 			} // closes inner while loop
 
 	// Converting distance in kpc to arcsec.
 	double d1 = d0 / cosmology.h * module_cosmodistances_observerObject(lens_temp.z,cosmology);
 	printf(" D1 HPC : %f %f %f %f\n",d1, d0,cosmology.h,lens_temp.z );
 	// Set rcore value in kpc or in arcsec.
 	if ( core_radius_kpc != 0. )
 		lens_temp.rcore = core_radius_kpc / d1;
 	else
 		core_radius_kpc = lens_temp.rcore * d1;
 
 	// Set rcut value in kpc or in arcsec.
 	if ( cut_radius_kpc != 0. )
 	{
 		//std::cerr << "d1 " << d1 << std::endl;
 		lens_temp.rcut = cut_radius_kpc / d1;}
 	else
 		cut_radius_kpc = lens_temp.rcut * d1;
 
     //Calculate parameters like b0, potential ellipticity and anyother parameter depending on the profile
     module_readParameters_calculatePotentialparameter(&lens_temp);
 
     //assign value to SOA
     //std::cerr << "Type + indice :" << lens_temp.type << Indice_type[lens_temp.type-1] << std::endl;
 	if(Indice_type[lens_temp.type-1] <nhalos){
 
 		ind = Indice_type[lens_temp.type-1];
 		//std::cerr<< ind << std::endl;
 		lens_SOA->type[ind] 		     = lens_temp.type;
 		lens_SOA->position_x[ind]  	     = lens_temp.position.x;
 		lens_SOA->position_y[ind] 	     = lens_temp.position.y;
 		lens_SOA->b0[ind] 		     = 		lens_temp.b0;
 		lens_SOA->vdisp[ind] 		     = 		lens_temp.vdisp;
 		lens_SOA->ellipticity_angle[ind]     = lens_temp.ellipticity_angle;
 		lens_SOA->ellipticity[ind]           = lens_temp.ellipticity;
 		lens_SOA->ellipticity_potential[ind] = lens_temp.ellipticity_potential;
 		lens_SOA->rcore[ind] 		     = lens_temp.rcore;
 		lens_SOA->rcut[ind] 		     = lens_temp.rcut;
 		lens_SOA->z[ind] 		     = lens_temp.z;
 		lens_SOA->anglecos[ind] 	     = cos(lens_temp.ellipticity_angle);
 		lens_SOA->anglesin[ind] 	     = sin(lens_temp.ellipticity_angle);
 
 		Indice_type[lens_temp.type-1] += 1;
 	}
 }  // closes if loop
 
 }  // closes while loop
 	}
 	IN.close();
 
 }
 
 /** @brief This module function converts potentials to potentieal_SOA (AOS to SOA conversion)
 *
 */
 
 void module_readParameters_PotentialSOA(std::string infile, Potential *lens, Potential_SOA *lens_SOA, int nhalos){
 
 	lens_SOA->type = 	new int[nhalos];
 	lens_SOA->position_x  = 	new type_t[nhalos];
 	lens_SOA->position_y = 		new type_t[nhalos];
 	lens_SOA->b0 = 	new type_t[nhalos];
 	lens_SOA->ellipticity_angle = new type_t[nhalos];
 	lens_SOA->ellipticity = new type_t[nhalos];
 	lens_SOA->ellipticity_potential = new type_t[nhalos];
 	lens_SOA->rcore = 	new type_t[nhalos];
 	lens_SOA->rcut = 	new type_t[nhalos];
 	lens_SOA->z = 		new type_t[nhalos];
 	lens_SOA->anglecos = 	new type_t[nhalos];
 	lens_SOA->anglesin = 		new type_t[nhalos];
 
 	int N_type[100];
 	int Indice_type[100];
 	int ind;
 
 	for(int i=0;i < 100; ++i){
 			N_type[i] = 0;
 			Indice_type[i] = 0;
 	}
 
 	for (int i = 0; i < nhalos; ++i){
 		N_type[lens[i].type] += 1;
 	}
 	for(int i=1;i < 100; ++i){
 		Indice_type[i] = N_type[i]+Indice_type[i-1];
 		//printf("%d %d \n ",N_type[i], Indice_type[i]);
 	}
 
 
 	for (int i = 0; i < nhalos; ++i){
 
 		if(Indice_type[lens[i].type-1] <nhalos){
 
 			ind = Indice_type[lens[i].type-1];
 			//printf ("%d ", ind);
 			lens_SOA->type[ind] 		     = lens[i].type;
 			lens_SOA->position_x[ind]  	     = lens[i].position.x;
 			//std::cerr << lens_SOA[1].position_x[*i_point] << " " << lens[i].position.x  << std::endl;
 			lens_SOA->position_y[ind] 	     = lens[i].position.y;
 			lens_SOA->b0[ind] 		     = 		lens[i].b0;
 			lens_SOA->ellipticity_angle[ind]     = lens[i].ellipticity_angle;
 			lens_SOA->ellipticity[ind]           = lens[i].ellipticity;
 			lens_SOA->ellipticity_potential[ind] = lens[i].ellipticity_potential;
 			lens_SOA->rcore[ind] 		     = lens[i].rcore;
 			lens_SOA->rcut[ind] 		     = lens[i].rcut;
 			lens_SOA->z[ind] 		     = lens[i].z;
 			lens_SOA->anglecos[ind] 	     = cos(lens[i].ellipticity_angle);
 			lens_SOA->anglesin[ind] 	     = sin(lens[i].ellipticity_angle);
 
 			Indice_type[lens[i].type-1] += 1;
 		}
 	}
 
 	//printf("Bla anglecos = %f\n", lens_SOA->anglecos[0]);
 
 }
 
 /** @brief This module function calculates profile depended information like the impactparameter b0 and the potential ellipticity epot
  * 
  * @param lens: mass distribution for which to calculate parameters
 */
 
 void module_readParameters_calculatePotentialparameter(Potential *lens){
 
 	
 
 
 	switch (lens->type)
     {
 	
 	case(5): /*Elliptical Isothermal Sphere*/
 		//impact parameter b0
 		lens->b0 = 4* pi_c2 * lens->vdisp * lens->vdisp ;
 		//ellipticity_potential 
 		lens->ellipticity_potential = lens->ellipticity/3 ;
 	    break;
 	    
 	case(8): /* PIEMD */
 		//impact parameter b0
 		lens->b0 = 6.*pi_c2 * lens->vdisp * lens->vdisp;
 		//ellipticity_parameter
 	    if ( lens->ellipticity == 0. && lens->ellipticity_potential != 0. ){
 			// emass is (a2-b2)/(a2+b2)
 			lens->ellipticity = 2.*lens->ellipticity_potential / (1. + lens->ellipticity_potential * lens->ellipticity_potential);
 			//printf("1 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
 		}
 		else if ( lens->ellipticity == 0. && lens->ellipticity_potential == 0. ){
 			lens->ellipticity_potential = 0.00001;
 			//printf("2 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
 		}
 		else{
 			// epot is (a-b)/(a+b)
 			lens->ellipticity_potential = (1. - sqrt(1 - lens->ellipticity * lens->ellipticity)) / lens->ellipticity;
 			//printf("3 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
 		}
         break;
 
 	case(81): /* PIEMD */
 		//impact parameter b0
 		lens->b0 = 6.*pi_c2 * lens->vdisp * lens->vdisp;
 		//ellipticity_parameter
 	    if ( lens->ellipticity == 0. && lens->ellipticity_potential != 0. ){
 			// emass is (a2-b2)/(a2+b2)
 			lens->ellipticity = 2.*lens->ellipticity_potential / (1. + lens->ellipticity_potential * lens->ellipticity_potential);
 			printf("1 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
 		}
 		else if ( lens->ellipticity == 0. && lens->ellipticity_potential == 0. ){
 			lens->ellipticity_potential = 0.00001;
 			printf("2 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
 		}
 		else{
 			// epot is (a-b)/(a+b)
 			lens->ellipticity_potential = (1. - sqrt(1 - lens->ellipticity * lens->ellipticity)) / lens->ellipticity;
 			printf("3 : %f %f \n",lens->ellipticity,lens->ellipticity_potential);
 		}
         break;
 
 	default:
             printf( "ERROR: LENSPARA profil type of clump %s unknown : %d\n",lens->name, lens->type);
 		break;
     };
 	
 }
 
 void module_readParameters_calculatePotentialparameter_SOA(Potential_SOA *lens, int ind){
 
 
 
 
 	switch (lens->type[ind])
     {
 
 	case(5): /*Elliptical Isothermal Sphere*/
 		//impact parameter b0
 		lens->b0[ind] = 4* pi_c2 * lens->vdisp[ind] * lens->vdisp[ind] ;
 		//ellipticity_potential
 		lens->ellipticity_potential[ind] = lens->ellipticity[ind]/3 ;
 	    break;
 
 	case(8): /* PIEMD */
 		//impact parameter b0
 		lens->b0[ind] = 6.*pi_c2 * lens->vdisp[ind] * lens->vdisp[ind];
 		//ellipticity_parameter
 	    if ( lens->ellipticity[ind] == 0. && lens->ellipticity_potential[ind] != 0. ){
 			// emass is (a2-b2)/(a2+b2)
 			lens->ellipticity[ind] = 2.*lens->ellipticity_potential[ind] / (1. + lens->ellipticity_potential[ind] * lens->ellipticity_potential[ind]);
 			//printf("1 : %f %f \n",lens->ellipticity[ind],lens->ellipticity_potential[ind]);
 		}
 		else if ( lens->ellipticity[ind] == 0. && lens->ellipticity_potential[ind] == 0. ){
 			lens->ellipticity_potential[ind] = 0.00001;
 			//printf("2 : %f %f \n",lens->ellipticity[ind],lens->ellipticity_potential[ind]);
 		}
 		else{
 			// epot is (a-b)/(a+b)
 			lens->ellipticity_potential[ind] = (1. - sqrt(1 - lens->ellipticity[ind] * lens->ellipticity[ind])) / lens->ellipticity[ind];
 			//printf("3 : %f %f \n",lens->ellipticity[ind],lens->ellipticity_potential[ind]);
 		}
         break;
 
 	case(81): /* PIEMD */
 		//impact parameter b0
 		lens->b0[ind] = 6.*pi_c2 * lens->vdisp[ind] * lens->vdisp[ind];
 		//ellipticity_parameter
 	    if ( lens->ellipticity[ind] == 0. && lens->ellipticity_potential[ind] != 0. ){
 			// emass is (a2-b2)/(a2+b2)
 			lens->ellipticity[ind] = 2.*lens->ellipticity_potential[ind] / (1. + lens->ellipticity_potential[ind] * lens->ellipticity_potential[ind]);
 			//printf("1 : %f %f \n",lens->ellipticity[ind],lens->ellipticity_potential[ind]);
 		}
 		else if ( lens->ellipticity[ind] == 0. && lens->ellipticity_potential[ind] == 0. ){
 			lens->ellipticity_potential[ind] = 0.00001;
 			//printf("2 : %f %f \n",lens->ellipticity[ind],lens->ellipticity_potential[ind]);
 		}
 		else{
 			// epot is (a-b)/(a+b)
 			lens->ellipticity_potential[ind] = (1. - sqrt(1 - lens->ellipticity[ind] * lens->ellipticity[ind])) / lens->ellipticity[ind];
 			//printf("3 : %f %f \n",lens->ellipticity[ind],lens->ellipticity_potential[ind]);
 		}
         break;
 
 	default:
             printf( "ERROR: LENSPARA profil type of clump %f unknown : %d N %d \n",lens->name[ind], lens->type[ind], ind);
 		break;
     };
 
 }
 
 
 
 /** @brief This module function reads the grid information
  * 
 * @param infile path to input file
 * @param grid array where grid information will be stored
 */
 
 void module_readParameters_Grid(std::string infile, grid_param *grid)
 {
 
     std::string first, second, third, line1, line2;
     double cast_1;
     double dmax ;
 
 std::ifstream IN(infile.c_str(), std::ios::in);
     if ( IN )
     {
 	while(std::getline(IN,line1))
         {
 	    std::istringstream read1(line1); // create a stream for the line
 	    read1 >> first;
             if (!strncmp(first.c_str(), "grille", 7) || !strncmp(first.c_str(), "frame", 5) || !strncmp(first.c_str(), "champ", 5))  // Read in potential
 		{
 
     while(std::getline(IN,line2))
     {
     	std::istringstream read2(line2);
     	read2 >> second >> third;
     	if (strcmp(second.c_str(), "end") == 0)  // Move to next potential and initialize it
         {
             break; // Break while loop and move to next potential
         }
     
  	// Read in values
  	
         if (!strcmp(second.c_str(), "dmax"))
         {
             sscanf(third.c_str(), "%lf", &dmax);
             //printf( "\t%s\t%lf\n", second.c_str(), dmax);
             //grid->dmax = (type_t) cast_1;
             grid->xmin = -dmax;
             grid->xmax = dmax;
             grid->ymin = -dmax;
             grid->ymax = dmax;
             grid->rmax = dmax * sqrt(2.);
         }
         else if (!strcmp(second.c_str(), "xmin"))
         {
             sscanf(third.c_str(), "%lf", &cast_1);
             grid->xmin = (type_t) cast_1;
             //printf("\t%s\t%lf\n", second.c_str(), grid->xmin);
         }
         else if (!strcmp(second.c_str(), "xmax"))
         {
             sscanf(third.c_str(), "%lf", &cast_1);
             grid->xmax = (type_t) cast_1;
             //printf("\t%s\t%lf\n", second.c_str(), grid->xmax);
         }
         else if (!strcmp(second.c_str(), "ymin"))
         {
             sscanf(third.c_str(), "%lf", &cast_1);
             grid->ymin = (type_t) cast_1;
             //printf( "\t%s\t%lf\n", second.c_str(), grid->ymin);
         }
         else if (!strcmp(second.c_str(), "ymax"))
         {
             sscanf(third.c_str(), "%lf", &cast_1);
             grid->ymax = (type_t) cast_1;
             //printf( "\t%s\t%lf\n", second.c_str(), grid->ymax);
         }
 }
 
 }  // closes if loop
 
 }  // closes while loop
 
 }  // closes if(IN)
 
 
 
 IN.close();
 
 }
 
 
 /* @brief Get number of sets for cleanlens mode
  * !!Not used. Will be reworked!!
  * 
  * This module function reads in the "clean lens" mode sources: These sources are read in and lensed only once assuming a fixed mass model
 // Then we can see the predicted location of the images and compare with their real positions
 * 
 * @param clean lens file, number of clean lens images
 * @return coordinates for each image, shape of each image, redshifts, number of sets, number of images per set 
 */
 
 
 // Get number of sets for cleanlens mode
 void module_readParameters_SingleLensingSourcesNumberSets(std::string infile, int &nsetofimages_cleanlens )
 {
     std::string line1;
     int setNumber=0;
     nsetofimages_cleanlens=0;
 
 
     // Get number of sets of images
     std::ifstream IM(infile.c_str(),std::ios::in);
 	if ( IM )
     	{
         	while( std::getline(IM,line1))
         	{ 
                         // Read in parameters
 			sscanf(line1.c_str(), "%d", &setNumber);
 			if(setNumber > nsetofimages_cleanlens) nsetofimages_cleanlens = setNumber;
 		}
 	}
 	IM.close();
 }
 
 
 
 /** @brief Prints out cosmology
 */
 
 void module_readParameters_debug_cosmology(int DEBUG, cosmo_param cosmology)
 {
 
 if (DEBUG == 1)  // If we are in debug mode
 {
 	printf("\n\n####################### Summary of Input Parameters #######################\n");
     printf("Cosmology: Cosmology model = %d, omegaM = %lf, omegaX = %lf, curvature = %lf, wX = %lf, wa = %lf, H0 =  %lf, h = %lf\n", cosmology.model, cosmology.omegaM, cosmology.omegaX, cosmology.curvature, cosmology.wX, cosmology.wa, cosmology.H0, cosmology.h);
 	
 }
 
 }
 
 /** @brief Prints out runmode
 */
 
 void module_readParameters_debug_runmode(int DEBUG, runmode_param runmode)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 
     printf("Runmode: nhalos = %d, nsets = %d, nimagestot = %d, source = %d, image = %d, arclet  = %d, cline = %d, inverse= %d, multi= %d DEBUG = %d\n", runmode.nhalos, runmode.nsets, runmode.nimagestot, runmode.source, runmode.image, runmode.arclet, runmode.cline, runmode.inverse, runmode.multi, runmode.debug);
 
 }
 
 }
 /** @brief Prints out images
 */
 void module_readParameters_debug_image(int DEBUG, galaxy image[], int nImagesSet[], int nsets)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 	int index = 0;
 	for ( int i = 0; i < nsets; ++i){
 		for( int j = 0; j < nImagesSet[i]; ++j){
 			printf("Image [%d]: x = %lf, y = %lf, shape: a = %f, b = %f, theta = %lf, redshift = %lf,  nImagesSet = %d,\n",index , image[index].center.x, image[index].center.y,  image[index].shape.a, image[index].shape.b, image[index].shape.theta, image[index].redshift,  nImagesSet[i]);
 			index +=1;
 			//printf( "%d \n", index );
 		}
 	}
 }
 
 }
 /** @brief Prints out source
 */
 void module_readParameters_debug_source(int DEBUG, galaxy source[], int nsets)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 	for ( int i = 0; i < nsets; ++i){
 		printf("Source[%d]: x = %lf, y = %lf, shape: a = %f, b = %f, theta = %lf, redshift = %lf. \n\n", i, source[i].center.x, source[i].center.y,  source[i].shape.a, source[i].shape.b, source[i].shape.theta, source[i].redshift);
 	}
 }
 
 }
 /** @brief Prints out massdistributions
 */
 void module_readParameters_debug_potential(int DEBUG, Potential lenses[], int nhalos)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 	for ( int i = 0; i < nhalos; ++i){
 		printf("Potential[%d]: x = %f, y = %f, vdisp = %f, type = %d, type_name = %s, name = %s,\n \t ellipticity = %f, ellipticity_pot = %f, ellipticity angle (radians) = %f, rcore = %f, rcut = %f,\n \t rscale = %f, exponent = %f, alpha = %f, einasto kappa critical = %f, z = %f\n", i,lenses[i].position.x, lenses[i].position.y, lenses[i].vdisp, lenses[i].type, lenses[i].type_name, lenses[i].name, lenses[i].ellipticity, lenses[i].ellipticity_potential, lenses[i].ellipticity_angle, lenses[i].rcore, lenses[i].rcut, lenses[i].rscale, lenses[i].exponent, lenses[i].alpha, lenses[i].einasto_kappacritic, lenses[i].z);
 	}
 }
 
 }
 
 void module_readParameters_debug_potential_SOA(int DEBUG, Potential_SOA lenses, int nhalos)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 	for ( int i = 0; i < nhalos; ++i){
 		printf("Potential[%d]: x = %f, y = %f, b0 = %f, vdisp = %f, type = %d, \n \t ellipticity = %f, ellipticity_pot = %f, ellipticity angle (radians) = %f, rcore = %f, rcut = %f,\n \t z = %f\n, angle cos %f, sin %f \n", i,lenses.position_x[i], lenses.position_y[i], lenses.b0[i],lenses.vdisp[i], lenses.type[i], lenses.ellipticity[i], lenses.ellipticity_potential[i], lenses.ellipticity_angle[i], lenses.rcore[i], lenses.rcut[i], lenses.z[i], lenses.anglecos[i], lenses.anglesin[i]);
 	}
 }
 
 }
 
 /** @brief Prints out potfile_param
 */
 void module_readParameters_debug_potfileparam(int DEBUG, potfile_param *potfile)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 
 	printf("Potfile: potid = %d, filename = %s, ftype = %d, type = %d, zlens = %f, mag0 = %f, sigma = %f,\n \t core = %f, corekpc = %f, ircut = %d, cut1 = %f, cut2 = %f,\n \t cutkpc1 = %f, cutkpc2 = %f, islope = %d, slope1 = %f, slope2 = %f\n",    potfile->potid,potfile->potfile,potfile->ftype,potfile->type,potfile->zlens,potfile->mag0,potfile->sigma,potfile->core,potfile->corekpc,potfile->ircut,potfile->cut1,potfile->cut2,potfile->cutkpc1,potfile->cutkpc2,potfile->islope,potfile->slope1,potfile->slope2);
 }
 
 }
 /** @brief Prints out cline
 */
 void module_readParameters_debug_criticcaustic(int DEBUG, cline_param cline)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 
     printf("Cline: Number of planes = %d ", cline.nplan);
     for( int i=0; i < cline.nplan; ++i){
 		printf(" z[%d] = %f, ",i ,cline.cz[i]);
 		}  
 	printf(" dmax = %f, Low = %f, High= %f, Nb of gridcells %d \n", cline.dmax , cline.limitLow ,cline.limitHigh, cline.nbgridcells);
 
 }
 
 }
 /** @brief Prints out limits
 */
 void module_readParameters_debug_limit(int DEBUG, struct potentialoptimization host_potentialoptimization)
 {
 if (DEBUG == 1)  // If we are in debug mode
 {
 
     printf("DEBUG: Center.x B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.position.x.block, host_potentialoptimization.position.x.min, host_potentialoptimization.position.x.max, host_potentialoptimization.position.x.sigma);
     printf("DEBUG: Center.y B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.position.y.block, host_potentialoptimization.position.y.min, host_potentialoptimization.position.y.max, host_potentialoptimization.position.y.sigma);
     printf("DEBUG: weight.y B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.weight.block, host_potentialoptimization.weight.min, host_potentialoptimization.weight.max, host_potentialoptimization.weight.sigma);
     printf("DEBUG: ellipticity_angle B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.ellipticity_angle.block, host_potentialoptimization.ellipticity_angle.min, host_potentialoptimization.ellipticity_angle.max, host_potentialoptimization.ellipticity_angle.sigma);
     printf("DEBUG: ellipticity B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.ellipticity.block, host_potentialoptimization.ellipticity.min, host_potentialoptimization.ellipticity.max, host_potentialoptimization.ellipticity.sigma);
     printf("DEBUG: ellipticity_potential B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.ellipticity_potential.block, host_potentialoptimization.ellipticity_potential.min, host_potentialoptimization.ellipticity_potential.max, host_potentialoptimization.ellipticity_potential.sigma);
     printf("DEBUG: rcore B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.rcore.block, host_potentialoptimization.rcore.min, host_potentialoptimization.rcore.max, host_potentialoptimization.rcore.sigma);
     printf("DEBUG: rcut B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.rcut.block, host_potentialoptimization.rcut.min, host_potentialoptimization.rcut.max, host_potentialoptimization.rcut.sigma);
     printf("DEBUG: rscale B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.rscale.block, host_potentialoptimization.rscale.min, host_potentialoptimization.rscale.max, host_potentialoptimization.rscale.sigma);
     printf("DEBUG: exponent B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.exponent.block, host_potentialoptimization.exponent.min, host_potentialoptimization.exponent.max, host_potentialoptimization.exponent.sigma);
     printf("DEBUG: vdisp B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.vdisp.block, host_potentialoptimization.vdisp.min, host_potentialoptimization.vdisp.max, host_potentialoptimization.vdisp.sigma);
     printf("DEBUG: alpha B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.alpha.block, host_potentialoptimization.alpha.min, host_potentialoptimization.alpha.max, host_potentialoptimization.alpha.sigma);
     printf("DEBUG: z B = %d, min = %f, max = %f, sigma = %f \n", host_potentialoptimization.z.block, host_potentialoptimization.z.min, host_potentialoptimization.z.max, host_potentialoptimization.z.sigma);
             
 }
 
 }