COMMUNICATION NUMÉRIQUE ENTRE OPENVSP ET MATLAB
Le logiciel OpenVSP présenté dans la section 2.3.1 de ce document, est utilisé pour effectuer les calculs aérodynamiques. Les coefficients sont alors calculés pour une géométrie (aile, fuselage, avion, etc.), en fonction de l’angle d’incidence, l’angle de déviation et d’un nombre de Mach. De par l’objectif de cette recherche, nous sommes amenés à effectuer un très grand nombre de calculs, et c’est pour cela que la transmission des données entre OpenVSP et Matlab a été automatisée, Matlab étant l’outil de calcul numérique que nous utilisons.
Avec OpenVSP, Il est possible d’effectuer les calculs selon deux manières. La première consiste à utiliser l’interface graphique du logiciel, soit définir la géométrie, renseigner les conditions de l’expérience (méthode de calcul, vitesse et angle de fluide, etc.), et enfin exploiter les données via la fenêtre de résultats que propose l’interface. La seconde manière est plus « informatique », car elle consiste à, numériquement, écrire les fichiers intermédiaires de géométrie, et d’analyse qu’OpenVSP crée lorsqu’on utilise l’interface. En « court-circuitant » l’interface, nous pouvons tout de même effectuer un calcul aérodynamique. Concernant l’analyse des résultats, il faudra alors traiter directement le fichier qu’OpenVSP lit lors de l’affichage des coefficients dans l’interface.
Pour commencer, OpenVSP écrit un fichier « *.vspscript » qui répertorie les éléments géométriques. Le début du fichier « *.vspscript » correspondant à une aile d’une section est présenté dans le Tableau-A II-1. Pour définir n sections d’aile, il sera nécessaire de copier la section correspondante n fois à la suite de ce script. Enfin, il faudra informer en conséquence les différents paramètres. Par ailleurs, pour ajouter un autre type de géométrie, comme un fuselage, il suffit d’ajouter, à la suite, la description d’un fuselage comme indiqué dans le Tableau-A II-2. Le principe de section du fuselage fonctionne de la même manière que pour l’aile.
Enfin, lorsque la géométrie est renseignée, il est nécessaire de clôturer le fichier « *.vspscript ». Les éléments nécessaires à la clôture du fichier figurent dans le Tableau-A II- 3.
En parallèle, il est aussi nécessaire de renseigner un fichier « *.vspaero » désignant les conditions dans lesquelles OpenVSP va devoir calculer les coefficients (Surface alaire de référence, envergure, angle d’incidence, etc.) Le fichier « *.vspaero » à renseigner est indiqué dans le Tableau-A II-4.
Tableau-A II-1 Début du fichier « *.vspscript » et description de la géométrie d’une aile
// Début du script
void main ()
{
// Initialisation et Création d’une géométrie “Aile”
ClearVSPModel(); // Nettoyage (Seulement si c’est la 1ère géométrie)
string hsid = AddGeom("WING",""); // Création de l’aile
SetParmVal(hsid, "Tess_W", "Shape", X.XX); // Maillage en profondeur
Update();
// Insertion de n sections (Exemple pour 2 sections)
InsertXSec (hsid, 1, XS_FOUR_SERIES); InsertXSec (hsid, 1, XS_FOUR_SERIES); Update();
// Suppression de la section originale
CutXSec( hsid, 1 ); Update();
//============== Description de la 1ère section ==============//
// Définition de la plus grande corde de l’aile
SetDriverGroup( wid, X.XX, SPAN_WSECT_DRIVER, ROOTC_WSECT_DRIVER, TIPC_WSECT_DRIVER );
SetParmVal( wid,"SectTess_U", "XSec_0", X.XX); SetParmVal( wid, "Twist", "XSec_0", X.XX); Update();
// Création de la surface ‘xsec_surf0’qui sera associé à la 1ère section
string xsec_surf0 = GetXSecSurf( wid, X.XX );
ChangeXSecShape( xsec_surf0, X.XX, XS_FILE_AIRFOIL ); string xsec0 = GetXSec( xsec_surf0, X.XX );
ReadFileAirfoil( xsec0, "C:/… " );
array< vec3d > @up_array0 = GetAirfoilUpperPnts( xsec0 ); // extrados
array< vec3d > @low_array0 = GetAirfoilLowerPnts( xsec0 ); // intrados
SetAirfoilPnts( xsec0, up_array0, low_array0 ); Update();
// Localisation dans l’espace de la première section
SetParmVal( hsid, "X_Rel_Location", "XForm", X.XX); // axe longitudinal
SetParmVal( hsid, "Z_Rel_Location", "XForm", X.XX); // axe transversal
Update();
// Dimension de la 1ère section
SetParmVal( hsid, "Span", "XSec_1", X.XX); // envergure
SetParmVal( hsid, "Root_Chord", "XSec_1", X.XX); // grande corde
SetParmVal( hsid, "Tip_Chord", "XSec_1", X.XX); // petite corde
SetParmVal( hsid, "Sweep", "XSec_1", X.XX); // flèche
SetParmVal( hsid, "Dihedral", "XSec_1", X.XX); // dièdre
SetParmVal( hsid, "SectTess_U", "XSec_1", X.XX); // maillage en
Update(); longueur
Dans notre cas, les fichiers « *.vspscript » et « *.vspaero » ont été créé depuis Matlab. Cependant, un ordre d’écriture est à prendre en compte. En effet, le fichier « *.vspaero » est à écrire en premier avec le nom suivant, où NAME est un nom quelconque sans espaces.
- NAME_DegenGeom.vspaero pour une méthode de calcul VLM, - NAME.vspaero pour une méthode des panneaux.
Ensuite, le fichier « *.vspscript » peut être écrit. Notons que nous l’écrivons après le fichier « *.vspaero » car, c’est le fichier « *.vspscript » qui permet de créer le fichier « *.vsp3 » en charge de véhiculer les informations de géométrie, d’analyse, et de méthode de calcul. En conséquence, si les informations concernant l’analyse ne sont pas renseigner avant, le logiciel prendra des données d’analyse par défaut.
Une fois écrit, le fichier « *.vsp3 » est créé en exécutant la commande communiqué dans le Tableau-A II-5 depuis Matlab dépendamment du système d’exploitation de l’ordinateur. En exécutant le fichier « *.vsp3 » (Tableau-A II-6), le calcul aérodynamique est alors effectué. Enfin, à l’issue des calculs, OpenVSP créer 3 fichiers de résultats: « *.history », « *.fem » et « *.lod ». Dans notre étude, nous nous sommes servis du fichier « *.history » indiquant, pour chaque itération de calcul effectuée les coefficients aérodynamiques correspondant. Une fonction Matlab a alors été programmée pour lire les résultats inscris dans ce fichier « *.history » et renvoyer un tableau de coefficient CL et CD en fonction de l’angle d’incidence
α et du nombre de Mach.
Tableau-A II-2 Description de la géométrie du fuselage dans le fichier « *.vspscript »
...
string fid = AddGeom("FUSELAGE",""); // Création du fuselage
SetParmVal(fid, "Tess_W", "Shape", X.XX); // Maillage en profondeur
SetParmVal(fid, "Length", "Design", X.XX); // Longueur du fuselage
Update();
// Insertion de n sections (Exemple pour 2 sections elliptiques)
InsertXSec (fid, 1, XS_ELLIPSE); InsertXSec (fid, 1, XS_ ELLIPSE); Update();
// Suppression de la section originale
CutXSec( fid, 0 ); Update();
//============== Description de la 1ère section ==============//
SetParmVal( fid,"XLocPercent", "XSec_0", X.XX);
SetParmVal( fid,"Ellipse_Width", "XSecCurve_0", X.XX); SetParmVal( fid,"Ellipse_Height", "XSecCurve_0", X.XX); SetParmVal( fid,"ZLocPercent", "XSec_0", X.XX);
Update();
...
Tableau-A II-3 Description de la fin du fichier « *.vspscript »
...
//==== Écriture du fichier géométrie+analyse en “*.vsp3”
string fname_vspaerotests = "C:/… *.vsp3"; WriteVSPFile(fname_vspaerotests, SET_ALL ); Update();
// (OPTIONNEL) Début //==== Écriture d’un fichier de géométrie (pour l’affichage) en “*.m”
SetComputationFileName( DEGEN_GEOM_M_TYPE, "C:/… *.m"); ComputeDegenGeom( SET_ALL, DEGEN_GEOM_M_TYPE );
Update();
// (OPTIONNEL) Fin
//==== Lecture du fichier “*.vspscript”
ClearVSPModel();
ReadVSPFile( fname_vspaerotests );
string analysis_name = "VSPAEROComputeGeometry";
array <int> analysis_method = GetIntAnalysisInput(analysis_name,
"AnalysisMethod");
analysis_method[0] = (VSPAERO_ANALYSIS_METHOD::X.XX); //VORTEX_LATTICE où PANEL
SetIntAnalysisInput(analysis_name, "AnalysisMethod", analysis_method); Update();
//==== Analyse des erreurs
string rid = ExecAnalysis(analysis_name);
while ( GetNumTotalErrors() > 0 )
{
ErrorObj err = PopLastError(); Print( err.GetErrorString()); }
}
// Fin du script
Tableau-A II-4 Description du fichier d’analyse « *.vspaero »
Sref = X.XX // Surface de référence
Cref = X.XX // Corde de référence
Bref = X.XX // Envergure de référence
X_cg = X.XX // Position en x du Centre de Gravité (CG)
Y_cg = X.XX // Position en y du Centre de Gravité (CG)
Z_cg = X.XX // Position en z du Centre de Gravité (CG)
Mach = X.XX // Nombre de Mach à étudier (pour 1)
AoA = X.XX, X.XX, X.XX // Angles d’attaque à étudier (pour 3)
Beta = X.XX // Angles de déviation à étudier (pour 1)
Vinf = X.XX // Par défaut
Rho = X.XX // Par défaut (slug/ft3)
ReCref = X.XX // Par défaut
ClMax = X.XX // Par défaut
Tableau-A II-5 Commande Matlab pour exécuter le fichier « *. vspscript »
Système d’exploitation Commande
Windows dos('vspscript –script NAME.vspscript');
OS dos('./vspscript –script NAME.vspscript');
Tableau-A II-6 Commande Matlab pour exécuter le fichier « *.vsp3 »
Système d’exploitation Méthode de calcul Commande
Windows VLM dos('vspaero –omp 4 NAME_DegenGeom');
3D panneaux dos('vspaero –omp 4 NAME');
OS VLM dos('./vspaero –omp 4 NAME_DegenGeom');