/////////////////////////////////////////////////////////////////////////////////
//
// This file is part of SACAMOS, cable models for EMI simulations in SPICE.
// It was developed by the University of Nottingham and the Netherlands Aerospace
// Centre (NLR) for ESA under contract number 4000112765/14/NL/HK.
//
// Copyright (C) 2015 - 2017 University of Nottingham
//
// SACAMOS is free software: you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the Free Software
// Foundation, either version 3 of the License, or (at your option) any later
// version.
//
// SACAMOS is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
// for more details.
//
// A copy of the GNU General Public License version 3 can be found in the
// file GNU_GPL_v3 in the root or at .
//
// wxWidgets is currently licenced under the "wxWindows Library Licence".
// A copy of the wxWindows Library Licence, Version 3.1 can be found in the file
// wxWindows_Library_Licence_v3-1 in the root or at:
//
//
// The University of Nottingham can be contacted at: ggiemr@nottingham.ac.uk
//
// File Contents:
//
// NAME
// SPICEMODEL.cpp
//
// DESCRIPTION
// Application for the creation of Spice models
//
// AUTHOR(S)
// Steve Greedy
//
/////////////////////////////////////////////////////////////////////////////////
#include "SPICEMODEL.h"
#include
#include
#include
#include
#include
#include
#include
using namespace std;
//(*InternalHeaders(SPICEMODEL)
#include
#include
#include
//*)
//(*IdInit(SPICEMODEL)
const long SPICEMODEL::ID_STATICTEXT1 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL1 = wxNewId();
const long SPICEMODEL::ID_PANEL2 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT21 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL15 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT2 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL2 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT3 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT4 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT5 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL3 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT6 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL4 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT7 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL5 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT8 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL6 = wxNewId();
const long SPICEMODEL::ID_PANEL3 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT9 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL7 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT10 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL8 = wxNewId();
const long SPICEMODEL::ID_STATICTEXT11 = wxNewId();
const long SPICEMODEL::ID_TEXTCTRL9 = wxNewId();
const long SPICEMODEL::ID_PANEL4 = wxNewId();
const long SPICEMODEL::ID_NOTEBOOK1 = wxNewId();
const long SPICEMODEL::ID_BUTTON1 = wxNewId();
const long SPICEMODEL::ID_BUTTON2 = wxNewId();
const long SPICEMODEL::ID_BUTTON3 = wxNewId();
const long SPICEMODEL::ID_PANEL1 = wxNewId();
//*)
BEGIN_EVENT_TABLE(SPICEMODEL,wxDialog)
//(*EventTable(SPICEMODEL)
//*)
END_EVENT_TABLE()
SPICEMODEL::SPICEMODEL(wxWindow* parent,wxWindowID id,const wxPoint& pos,const wxSize& size)
{
//(*Initialize(SPICEMODEL)
wxStaticBoxSizer* StaticBoxSizer2;
wxFlexGridSizer* FlexGridSizer4;
wxFlexGridSizer* FlexGridSizer3;
wxFlexGridSizer* FlexGridSizer5;
wxFlexGridSizer* FlexGridSizer2;
wxBoxSizer* BoxSizer2;
wxFlexGridSizer* FlexGridSizer7;
wxStaticBoxSizer* StaticBoxSizer6;
wxBoxSizer* BoxSizer1;
wxStaticBoxSizer* StaticBoxSizer1;
wxFlexGridSizer* FlexGridSizer1;
wxBoxSizer* BoxSizer3;
Create(parent, wxID_ANY, _("SACAMOS: SPICE MODEL BUILDER"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE, _T("wxID_ANY"));
FlexGridSizer1 = new wxFlexGridSizer(0, 2, 0, 0);
FlexGridSizer2 = new wxFlexGridSizer(0, 1, 0, 0);
StaticBoxSizer2 = new wxStaticBoxSizer(wxVERTICAL, this, _("Spice Model Definition"));
BoxSizer1 = new wxBoxSizer(wxHORIZONTAL);
StaticText1 = new wxStaticText(this, ID_STATICTEXT1, _("Spice Model Name"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT1"));
BoxSizer1->Add(StaticText1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl1 = new wxTextCtrl(this, ID_TEXTCTRL1, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL1"));
BoxSizer1->Add(TextCtrl1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticBoxSizer2->Add(BoxSizer1, 1, wxALL|wxEXPAND, 5);
Panel2 = new wxPanel(this, ID_PANEL2, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL, _T("ID_PANEL2"));
StaticBoxSizer2->Add(Panel2, 5, wxALL|wxEXPAND, 5);
FlexGridSizer2->Add(StaticBoxSizer2, 1, wxALL|wxEXPAND, 5);
StaticBoxSizer6 = new wxStaticBoxSizer(wxHORIZONTAL, this, _("Cable Bundle Length"));
FlexGridSizer7 = new wxFlexGridSizer(0, 3, 0, 0);
StaticText21 = new wxStaticText(this, ID_STATICTEXT21, _("Length of Cable Bundle (m)"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT21"));
FlexGridSizer7->Add(StaticText21, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl15 = new wxTextCtrl(this, ID_TEXTCTRL15, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL15"));
FlexGridSizer7->Add(TextCtrl15, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
StaticBoxSizer6->Add(FlexGridSizer7, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(StaticBoxSizer6, 1, wxALL|wxEXPAND, 5);
BoxSizer3 = new wxBoxSizer(wxHORIZONTAL);
Notebook1 = new wxNotebook(this, ID_NOTEBOOK1, wxDefaultPosition, wxDefaultSize, 0, _T("ID_NOTEBOOK1"));
Panel3 = new wxPanel(Notebook1, ID_PANEL3, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL, _T("ID_PANEL3"));
FlexGridSizer4 = new wxFlexGridSizer(0, 4, 0, 0);
StaticText2 = new wxStaticText(Panel3, ID_STATICTEXT2, _("Amp (V/m)"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT2"));
FlexGridSizer4->Add(StaticText2, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl2 = new wxTextCtrl(Panel3, ID_TEXTCTRL2, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL2"));
FlexGridSizer4->Add(TextCtrl2, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText3 = new wxStaticText(Panel3, ID_STATICTEXT3, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT3"));
FlexGridSizer4->Add(StaticText3, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText4 = new wxStaticText(Panel3, ID_STATICTEXT4, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT4"));
FlexGridSizer4->Add(StaticText4, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText5 = new wxStaticText(Panel3, ID_STATICTEXT5, _("k theta"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT5"));
FlexGridSizer4->Add(StaticText5, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl3 = new wxTextCtrl(Panel3, ID_TEXTCTRL3, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL3"));
FlexGridSizer4->Add(TextCtrl3, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText6 = new wxStaticText(Panel3, ID_STATICTEXT6, _("k phi"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT6"));
FlexGridSizer4->Add(StaticText6, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl4 = new wxTextCtrl(Panel3, ID_TEXTCTRL4, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL4"));
FlexGridSizer4->Add(TextCtrl4, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText7 = new wxStaticText(Panel3, ID_STATICTEXT7, _("E theta"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT7"));
FlexGridSizer4->Add(StaticText7, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl5 = new wxTextCtrl(Panel3, ID_TEXTCTRL5, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL5"));
FlexGridSizer4->Add(TextCtrl5, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText8 = new wxStaticText(Panel3, ID_STATICTEXT8, _("E phi"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT8"));
FlexGridSizer4->Add(StaticText8, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl6 = new wxTextCtrl(Panel3, ID_TEXTCTRL6, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL6"));
FlexGridSizer4->Add(TextCtrl6, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
Panel3->SetSizer(FlexGridSizer4);
FlexGridSizer4->Fit(Panel3);
FlexGridSizer4->SetSizeHints(Panel3);
Panel4 = new wxPanel(Notebook1, ID_PANEL4, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL, _T("ID_PANEL4"));
FlexGridSizer5 = new wxFlexGridSizer(0, 2, 0, 0);
ConductorNumber = new wxStaticText(Panel4, ID_STATICTEXT9, _("Number of Transfer Impedances"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT9"));
FlexGridSizer5->Add(ConductorNumber, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl7 = new wxTextCtrl(Panel4, ID_TEXTCTRL7, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL7"));
FlexGridSizer5->Add(TextCtrl7, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText10 = new wxStaticText(Panel4, ID_STATICTEXT10, _("Conductor Number List"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT10"));
FlexGridSizer5->Add(StaticText10, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl8 = new wxTextCtrl(Panel4, ID_TEXTCTRL8, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL8"));
FlexGridSizer5->Add(TextCtrl8, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
StaticText11 = new wxStaticText(Panel4, ID_STATICTEXT11, _("Coupling Direction List"), wxDefaultPosition, wxDefaultSize, 0, _T("ID_STATICTEXT11"));
FlexGridSizer5->Add(StaticText11, 1, wxALL|wxALIGN_LEFT|wxALIGN_CENTER_VERTICAL, 5);
TextCtrl9 = new wxTextCtrl(Panel4, ID_TEXTCTRL9, _("0"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_TEXTCTRL9"));
FlexGridSizer5->Add(TextCtrl9, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
Panel4->SetSizer(FlexGridSizer5);
FlexGridSizer5->Fit(Panel4);
FlexGridSizer5->SetSizeHints(Panel4);
Notebook1->AddPage(Panel3, _("Incident Field Excitation"), false);
Notebook1->AddPage(Panel4, _("Transfer Impedance Model"), false);
BoxSizer3->Add(Notebook1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(BoxSizer3, 1, wxALL|wxEXPAND, 5);
BoxSizer2 = new wxBoxSizer(wxHORIZONTAL);
Button1 = new wxButton(this, ID_BUTTON1, _("SAVE"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_BUTTON1"));
BoxSizer2->Add(Button1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
Button2 = new wxButton(this, ID_BUTTON2, _("BUILD"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_BUTTON2"));
BoxSizer2->Add(Button2, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
Button3 = new wxButton(this, ID_BUTTON3, _("CLOSE"), wxDefaultPosition, wxDefaultSize, 0, wxDefaultValidator, _T("ID_BUTTON3"));
BoxSizer2->Add(Button3, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer2->Add(BoxSizer2, 1, wxALL|wxEXPAND, 5);
FlexGridSizer1->Add(FlexGridSizer2, 1, wxALL|wxALIGN_TOP|wxALIGN_CENTER_HORIZONTAL, 5);
FlexGridSizer3 = new wxFlexGridSizer(0, 1, 0, 0);
StaticBoxSizer1 = new wxStaticBoxSizer(wxHORIZONTAL, this, _("2D Cross Section"));
Panel1 = new wxPanel(this, ID_PANEL1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL, _T("ID_PANEL1"));
Panel1->SetMinSize(wxSize(500,500));
Panel1->SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
StaticBoxSizer1->Add(Panel1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer3->Add(StaticBoxSizer1, 1, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
FlexGridSizer1->Add(FlexGridSizer3, 1, wxALL|wxALIGN_TOP|wxALIGN_CENTER_HORIZONTAL, 5);
SetSizer(FlexGridSizer1);
FlexGridSizer1->Fit(this);
FlexGridSizer1->SetSizeHints(this);
Connect(ID_TEXTCTRL15,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl15Text);
Connect(ID_TEXTCTRL2,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl2Text);
Connect(ID_TEXTCTRL3,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl3Text);
Connect(ID_TEXTCTRL4,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl4Text);
Connect(ID_TEXTCTRL5,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl5Text);
Connect(ID_TEXTCTRL6,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl6Text);
Connect(ID_TEXTCTRL7,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl7Text);
Connect(ID_TEXTCTRL8,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl8Text);
Connect(ID_TEXTCTRL9,wxEVT_COMMAND_TEXT_UPDATED,(wxObjectEventFunction)&SPICEMODEL::OnTextCtrl9Text);
Connect(ID_BUTTON1,wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction)&SPICEMODEL::OnButton1Click);
Connect(ID_BUTTON2,wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction)&SPICEMODEL::OnButton2Click);
Connect(ID_BUTTON3,wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction)&SPICEMODEL::OnButton3Click);
Panel1->Connect(wxEVT_PAINT,(wxObjectEventFunction)&SPICEMODEL::OnPanel1Paint,0,this);
//*)
}
SPICEMODEL::~SPICEMODEL()
{
//(*Destroy(SPICEMODEL)
//*)
}
void SPICEMODEL::SetPathToMOD(wxString Path, wxString Name)
{
PathToMOD << Path;
MODname << Name;
}
void SPICEMODEL::SetPathForDir(wxString Path, wxString Name)
{
PathToMOD << Path;
MODname << Name;
PopulateTheDirectoryTree(PathToMOD);
}
void SPICEMODEL::PopulateTheDirectoryTree (wxString Path)
{
int size_h, size_v;
Panel2->GetSize(&size_h, &size_v );
//wxGenericDirCtrl *tree;
tree = (wxSpecificDirCtrl *) NULL;
tree = new wxSpecificDirCtrl (Panel2, -1, Path,
wxDefaultPosition,
wxSize(size_h, size_v),
wxSIMPLE_BORDER,//wxDIRCTRL_3D_INTERNAL|wxSUNKEN_BORDER,
wxEmptyString, 0,
_T("Directory Listing"));
Connect(tree->GetTreeCtrl()->GetId(),wxEVT_COMMAND_TREE_ITEM_ACTIVATED, (wxObjectEventFunction) (wxEventFunction)(wxCommandEventFunction) &SPICEMODEL::OnTreeSelectionChanged);
}
void SPICEMODEL::OnTreeSelectionChanged(wxTreeEvent& evt)
{
wxFileName fname (tree->GetFilePath());
wxString File_Path = fname.GetPath();
wxString File_FullName = fname.GetFullName();
wxString File_FullNamePath = fname.GetFullPath();
size_t Name = File_FullName.find_last_of(".");
bundleSelected = File_FullName.substr(0,Name);
if(File_FullName.substr(File_FullName.find_last_of(".") + 1) == "bundle_spec") {
draw_bundle(Panel1, PathToMOD, File_FullNamePath);
}
}
void SPICEMODEL::OnPanel1Paint(wxPaintEvent& event)
{
FormatPanel("temp");
}
void SPICEMODEL::FormatPanel(wxString TheFileNameToDraw)
{
int size_h, size_v;
Panel1->GetSize(&size_h, &size_v );
wxClientDC dc(Panel1);
dc.Clear();
// Draw centre lines
dc.SetPen( wxPen( wxColor(224,224,224),1 , wxDOT_DASH) );
dc.DrawLine( 0, size_v/2, size_h,size_v/2 );
dc.DrawLine( size_h/2, 0, size_h/2, size_v);
dc.SetTextForeground(*wxBLACK);
dc.DrawText("y=0", 5, (size_v/2)-15);
dc.DrawText("x=0", (size_h/2)+5, size_v-20);
// Draw ordinates
dc.SetPen( wxPen( wxColor(255,0,0),1 ) );
dc.DrawCircle( wxPoint(5,size_v-10), 5 );
dc.DrawLine( 5, size_v-10, 30, size_v-10 );
dc.DrawLine( 5, size_v-10, 5, size_v-35);
dc.DrawText("y", 10, size_v-45);
dc.DrawText("x", 30, size_v-25);
}
void SPICEMODEL::OnButton2Click(wxCommandEvent& event)
{
if (bundleSelected == "")
{
wxMessageBox("Please Select a Bundle" , _("Missing Bundle Specification"));
}
else
{
//SPICE CABLE BUNDLE MODEL
wxString fileName = TextCtrl1->GetValue();
//wxString fineName = fileName;
std::stringstream stream;
stream << "\"..\\BIN\\spice_cable_bundle_model_builder.exe\""
<< " "
<< "..\\" + MODname + "\\SPICE\\"
<< fileName;
system(stream.str().c_str());
RUN_STATUS *run_status = new RUN_STATUS(this);
run_status->ShowModal();
Button1->Enable();
}
}
void SPICEMODEL::OnButton1Click(wxCommandEvent& event)
{
int IsError = 0;
wxString fileName = TextCtrl1->GetValue();
TextCtrl1->SetBackgroundColour(wxColor(255,255,255));
if (fileName == "")
{
wxMessageBox("Please Specify a Cable Name" , _("Missing Cable Name"));
return;
}
check_is_empty(TextCtrl15, &IsError);
if ( IsError == 1)
{
wxMessageBox("Please Specify a Cable Length" , _("Missing Cable Length"));
return;
}
if ( IsError == 1)
{
wxMessageBox("Please fix highlighted errors" , _("Non numeric entry"));
return;
}
int conductor_number;
wxString cn = TextCtrl7->GetValue();
conductor_number = wxAtoi(cn);
wxArrayString conductor_id;
wxArrayString conductor_dn;
wxString conductor_ids = TextCtrl8->GetValue();
wxString conductor_dns = TextCtrl9->GetValue();
// First set of values
wxStringTokenizer tk_IDS( conductor_ids, " ", wxTOKEN_DEFAULT);
while ( tk_IDS.HasMoreTokens())
{
conductor_id.Add (tk_IDS.GetNextToken());
}
// Second set
wxStringTokenizer tk_DNS( conductor_dns, " ", wxTOKEN_DEFAULT);
while ( tk_DNS.HasMoreTokens())
{
conductor_dn.Add (tk_DNS.GetNextToken());
}
if (fileName == "" || bundleSelected == "")
{
if (fileName == "") wxMessageBox("Please Specify a Cable Name" , _("Missing Cable Name"));
else
{
if (bundleSelected == "") wxMessageBox("Please Select a Bundle" , _("Missing Bundle Specification"));
}
}
else
{
ofstream spiceFile;
wxString fullFileName = PathToMOD + "//SPICE//" + fileName + ".spice_model_spec";
spiceFile.open (fullFileName);
if (spiceFile.is_open())
{
// minimum requirements for type Cylindrical
spiceFile << "# MOD_cable_lib_dir \n";
spiceFile <<"../"<< MODname <<"/CABLE/"<<"\n";
spiceFile << "# MOD_bundle_lib_dir \n";
spiceFile <<"../"<< MODname <<"/BUNDLE/"<<"\n";
spiceFile << "# MOD_spice_bundle_lib_dir \n";
spiceFile <<"../"<< MODname <<"/SPICE/"<<"\n";
spiceFile << "# spice_symbol_dir \n";
spiceFile <<"../"<< MODname <<"/SPICE/SYMBOL/"<<"\n";
spiceFile << "# Specification for spice model of " + fileName + "\n";
spiceFile << bundleSelected<<"\n";//"wire_over_ground \n";
spiceFile << "# cable bundle length (m) \n";
spiceFile << TextCtrl15->GetValue() <<"\n";
spiceFile <<"# Incident field specification\n";
spiceFile <GetValue() <<" amplitude (V/m)\n";
spiceFile <GetValue()<<" "<GetValue()<<" "<<"ktheta kphi (degrees)\n";
spiceFile <GetValue()<<" "<GetValue()<<" "<<"Etheta Ephi (degrees)\n";
spiceFile <<"# Transfer Impedance Model\n";
spiceFile <GetValue()<<" # number of transfer impedances to include in the model\n";
if (conductor_number != 0)
{
for (size_t i = 0; i < conductor_dn.size(); ++i)
spiceFile <Disable();
}
void SPICEMODEL::OnButton3Click(wxCommandEvent& event)
{
Close();
}
void SPICEMODEL::OnTextCtrl15Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl15, &IsError);
check_is_positive(TextCtrl15, &IsError);
}
void SPICEMODEL::OnTextCtrl2Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl2, &IsError);
}
void SPICEMODEL::OnTextCtrl3Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl3, &IsError);
}
void SPICEMODEL::OnTextCtrl4Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl4, &IsError);
}
void SPICEMODEL::OnTextCtrl5Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl5, &IsError);
}
void SPICEMODEL::OnTextCtrl6Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl6, &IsError);
}
void SPICEMODEL::OnTextCtrl7Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric(TextCtrl6, &IsError);
}
void SPICEMODEL::OnTextCtrl8Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric_list(TextCtrl8, &IsError);
}
void SPICEMODEL::OnTextCtrl9Text(wxCommandEvent& event)
{
int IsError = 0;
check_is_numeric_list(TextCtrl9, &IsError);
}