• Aucun résultat trouvé

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');