Skip to content

Commit

Permalink
first commit
Browse files Browse the repository at this point in the history
  • Loading branch information
aromanro committed May 26, 2019
0 parents commit 73fd064
Show file tree
Hide file tree
Showing 18 changed files with 1,969 additions and 0 deletions.
31 changes: 31 additions & 0 deletions DFTAtom.sln
@@ -0,0 +1,31 @@

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio 15
VisualStudioVersion = 15.0.27703.2047
MinimumVisualStudioVersion = 10.0.40219.1
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "DFTAtom", "DFTAtom\DFTAtom.vcxproj", "{9181CE73-78FB-4533-8496-E23C59E3831F}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|x64 = Debug|x64
Debug|x86 = Debug|x86
Release|x64 = Release|x64
Release|x86 = Release|x86
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{9181CE73-78FB-4533-8496-E23C59E3831F}.Debug|x64.ActiveCfg = Debug|x64
{9181CE73-78FB-4533-8496-E23C59E3831F}.Debug|x64.Build.0 = Debug|x64
{9181CE73-78FB-4533-8496-E23C59E3831F}.Debug|x86.ActiveCfg = Debug|Win32
{9181CE73-78FB-4533-8496-E23C59E3831F}.Debug|x86.Build.0 = Debug|Win32
{9181CE73-78FB-4533-8496-E23C59E3831F}.Release|x64.ActiveCfg = Release|x64
{9181CE73-78FB-4533-8496-E23C59E3831F}.Release|x64.Build.0 = Release|x64
{9181CE73-78FB-4533-8496-E23C59E3831F}.Release|x86.ActiveCfg = Release|Win32
{9181CE73-78FB-4533-8496-E23C59E3831F}.Release|x86.Build.0 = Release|Win32
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {0C97B709-0F21-4636-9E30-A90D290C5A27}
EndGlobalSection
EndGlobal
69 changes: 69 additions & 0 deletions DFTAtom/AufbauPrinciple.h
@@ -0,0 +1,69 @@
#pragma once

namespace DFT {

struct Subshell
{
Subshell(int N = 0, int L = 0, int nrElectrons = 0) : m_N(N), m_L(L), m_nrElectrons(nrElectrons), E(0) {}


bool operator<(const Subshell& o) const
{
return m_N < o.m_N || (m_N == o.m_N && m_L < o.m_L);
}

int m_N;
int m_L;
int m_nrElectrons;

double E;
};


class AufbauPrinciple
{
public:

static std::vector<Subshell> GetSubshells(int Z)
{
std::vector<Subshell> levels;
bool exitLoops = false;

int electronCount = 0;

for (int NplusL = 0; !exitLoops && NplusL < 10; ++NplusL)
for (int N = 0; N <= NplusL; ++N)
{
const int L = NplusL - N;

if (L <= N)
{
int nrElectrons = 2 * (2 * L + 1);

if (Z - electronCount < nrElectrons)
nrElectrons = Z - electronCount;

electronCount += nrElectrons;

levels.emplace_back(Subshell(N, L, nrElectrons));

if (electronCount == Z)
{
exitLoops = true;
break;
}
}
}

std::cout << std::endl;

return levels;
}

};

}




164 changes: 164 additions & 0 deletions DFTAtom/DFTAtom.vcxproj
@@ -0,0 +1,164 @@
<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Debug|Win32">
<Configuration>Debug</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Debug|x64">
<Configuration>Debug</Configuration>
<Platform>x64</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Release|x64">
<Configuration>Release</Configuration>
<Platform>x64</Platform>
</ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<VCProjectVersion>15.0</VCProjectVersion>
<ProjectGuid>{9181CE73-78FB-4533-8496-E23C59E3831F}</ProjectGuid>
<RootNamespace>DFTAtom</RootNamespace>
<WindowsTargetPlatformVersion>10.0.17134.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>true</UseDebugLibraries>
<PlatformToolset>v141</PlatformToolset>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>false</UseDebugLibraries>
<PlatformToolset>v141</PlatformToolset>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>true</UseDebugLibraries>
<PlatformToolset>v141</PlatformToolset>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>false</UseDebugLibraries>
<PlatformToolset>v141</PlatformToolset>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
</ImportGroup>
<ImportGroup Label="Shared">
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<IncludePath>C:\wxWidgets-3.0.4\include;C:\wxWidgets-3.0.4\include\msvc;$(IncludePath)</IncludePath>
<LibraryPath>C:\wxWidgets-3.0.4\lib\vc_x64_lib;$(VCInstallDir)PlatformSDK\lib\amd64;$(VSInstallDir)SDK\v2.0\lib\amd64;$(LibraryPath)</LibraryPath>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<IncludePath>C:\wxWidgets-3.0.4\include;C:\wxWidgets-3.0.4\include\msvc;$(VCInstallDir)PlatformSDK\include;$(IncludePath)</IncludePath>
<LibraryPath>C:\wxWidgets-3.0.4\lib\vc_x64_lib;$(VCInstallDir)PlatformSDK\lib\amd64;$(VSInstallDir)SDK\v2.0\lib\amd64;$(LibraryPath)</LibraryPath>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<IncludePath>C:\wxWidgets-3.0.4\include;C:\wxWidgets-3.0.4\include\msvc;$(VC_IncludePath);C:\Program Files %28x86%29\Windows Kits\10\Include\10.0.10240.0\ucrt;$(IncludePath);$(WindowsSDK_IncludePath)include;$(VCInstallDir)include;$(VCInstallDir)atlmfc\include;$(VCInstallDir)PlatformSDK\include;$(VCInstallDir)PlatformSDK\common\include;$(WindowsSdkDir)include;$(FrameworkSDKDir)\include;C:\Program Files (x86)\Microsoft DirectX SDK (August 2007)\Include;C:\Program Files (x86)\Java\jdk1.6.0_20\include;C:\Program Files (x86)\Java\jdk1.6.0_20\include\win32</IncludePath>
<LibraryPath>C:\wxWidgets-3.0.4\lib\vc_x64_lib;$(LibraryPath)</LibraryPath>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<IncludePath>C:\wxWidgets-3.0.4\include;C:\wxWidgets-3.0.4\include\msvc;$(VC_IncludePath);C:\Program Files %28x86%29\Windows Kits\10\Include\10.0.10240.0\ucrt;$(IncludePath);$(WindowsSDK_IncludePath)include;$(VCInstallDir)include;$(VCInstallDir)atlmfc\include;$(VCInstallDir)PlatformSDK\include;$(VCInstallDir)PlatformSDK\common\include;$(WindowsSdkDir)include;$(FrameworkSDKDir)\include;C:\Program Files (x86)\Microsoft DirectX SDK (August 2007)\Include;C:\Program Files (x86)\Java\jdk1.6.0_20\include;C:\Program Files (x86)\Java\jdk1.6.0_20\include\win32</IncludePath>
<LibraryPath>C:\wxWidgets-3.0.4\lib\vc_x64_lib;$(LibraryPath)</LibraryPath>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<Optimization>Disabled</Optimization>
<SDLCheck>true</SDLCheck>
<ConformanceMode>true</ConformanceMode>
<PreprocessorDefinitions>WIN32;_DEBUG;__WXMSW__;_WINDOWS;wxUSE_GUI=1;NOPCH;%(PreprocessorDefinitions)</PreprocessorDefinitions>
</ClCompile>
<Link>
<AdditionalDependencies>wxmsw30ud_html.lib;wxmsw30ud_core.lib;wxbase30ud.lib;wxtiffd.lib;wxjpegd.lib;wxpngd.lib;wxzlibd.lib;wxregexud.lib;wxexpatd.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link>
</ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<Optimization>Disabled</Optimization>
<SDLCheck>true</SDLCheck>
<ConformanceMode>true</ConformanceMode>
<PreprocessorDefinitions>WIN32;_DEBUG;__WXMSW__;_WINDOWS;wxUSE_GUI=1;NOPCH;%(PreprocessorDefinitions)</PreprocessorDefinitions>
</ClCompile>
<Link>
<AdditionalDependencies>wxmsw30ud_html.lib;wxmsw30ud_core.lib;wxbase30ud.lib;wxtiffd.lib;wxjpegd.lib;wxpngd.lib;wxzlibd.lib;wxregexud.lib;wxexpatd.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link>
</ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<Optimization>MaxSpeed</Optimization>
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<ConformanceMode>true</ConformanceMode>
<PreprocessorDefinitions>WIN32;__WXMSW__;_WINDOWS;wxUSE_GUI=1;NOPCH;%(PreprocessorDefinitions)</PreprocessorDefinitions>
</ClCompile>
<Link>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
</Link>
</ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<Optimization>MaxSpeed</Optimization>
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<ConformanceMode>true</ConformanceMode>
<PreprocessorDefinitions>WIN32;__WXMSW__;_WINDOWS;wxUSE_GUI=1;NOPCH;;%(PreprocessorDefinitions)</PreprocessorDefinitions>
</ClCompile>
<Link>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
<AdditionalDependencies>wxmsw30u_html.lib;wxmsw30u_core.lib;wxbase30u.lib;wxtiff.lib;wxjpeg.lib;wxpng.lib;wxzlib.lib;wxregexu.lib;wxexpat.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link>
</ItemDefinitionGroup>
<ItemGroup>
<ClCompile Include="DFTAtomApp.cpp" />
<ClCompile Include="DFTAtomFrame.cpp" />
<ClCompile Include="Options.cpp" />
<ClCompile Include="OptionsFrame.cpp" />
<ClCompile Include="PoissonSolver.cpp" />
</ItemGroup>
<ItemGroup>
<ClInclude Include="AufbauPrinciple.h" />
<ClInclude Include="DFTAtomApp.h" />
<ClInclude Include="DFTAtomFrame.h" />
<ClInclude Include="Integral.h" />
<ClInclude Include="Numerov.h" />
<ClInclude Include="Options.h" />
<ClInclude Include="OptionsFrame.h" />
<ClInclude Include="PoissonSolver.h" />
<ClInclude Include="VWNExcCor.h" />
</ItemGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets">
</ImportGroup>
</Project>
63 changes: 63 additions & 0 deletions DFTAtom/DFTAtom.vcxproj.filters
@@ -0,0 +1,63 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
<UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
<Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
</Filter>
<Filter Include="Header Files">
<UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
<Extensions>h;hh;hpp;hxx;hm;inl;inc;ipp;xsd</Extensions>
</Filter>
<Filter Include="Resource Files">
<UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>
<Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>
</Filter>
</ItemGroup>
<ItemGroup>
<ClCompile Include="PoissonSolver.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="DFTAtomApp.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="DFTAtomFrame.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="Options.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="OptionsFrame.cpp">
<Filter>Source Files</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="PoissonSolver.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="VWNExcCor.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="Integral.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="Numerov.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="AufbauPrinciple.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="DFTAtomApp.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="DFTAtomFrame.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="Options.h">
<Filter>Header Files</Filter>
</ClInclude>
<ClInclude Include="OptionsFrame.h">
<Filter>Header Files</Filter>
</ClInclude>
</ItemGroup>
</Project>
6 changes: 6 additions & 0 deletions DFTAtom/DFTAtom.vcxproj.user
@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<ShowAllFiles>true</ShowAllFiles>
</PropertyGroup>
</Project>
19 changes: 19 additions & 0 deletions DFTAtom/DFTAtomApp.cpp
@@ -0,0 +1,19 @@
#include "DFTAtomApp.h"
#include "DFTAtomFrame.h"


wxIMPLEMENT_APP(DFTAtomApp);

bool DFTAtomApp::OnInit()
{
if (!wxApp::OnInit())
return false;

options.Open();
options.Load();

frame = new DFTAtomFrame("DFTAtom", wxPoint(50, 50), wxSize(1024, 800));
frame->Show(true);

return true;
}
30 changes: 30 additions & 0 deletions DFTAtom/DFTAtomApp.h
@@ -0,0 +1,30 @@
#pragma once

#define wxNEEDS_DECL_BEFORE_TEMPLATE

// For compilers that support precompilation, includes "wx/wx.h".
#include "wx/wxprec.h"

#ifdef __BORLANDC__
#pragma hdrstop
#endif

// for all others, include the necessary headers (this file is usually all you
// need because it includes almost all "standard" wxWidgets headers
#ifndef WX_PRECOMP
#include "wx/wx.h"
#endif


#include "DFTAtomFrame.h"
#include "Options.h"

class DFTAtomApp : public wxApp
{
public:
DFTAtomFrame * frame = nullptr;
Options options;

virtual bool OnInit();
};

0 comments on commit 73fd064

Please sign in to comment.