image thumbnail
from Dielectric resonator antenna (DRA) design and analysis utility by Alexandre Perron
Rapidly analyze and/or design dielectric resonator antennas of various shapes.

dRing_fr
%--------------------------------------------------------------------------
%                               dRing_fr.m                                   
%--------------------------------------------------------------------------
%  Conception d'un rsonateur annulaire (franais)                                              
%
%    A) ENTRES
%
%    1. 'freq' = frquence de rsonance vise                        
%    2. 'choix_mode' = mode de rayonnement choisi             
%    3. 'BW' = bande passante fractionnelle minimale dsire         
%    4. 'VSWR' = taux d'ondes stationnaires tolr pour le calcul    
%    5. 'er' = constante dilectrique relative du matriau disponible
%    6. 'ratio' = ratio 'hauteur/rayon externe' du rsonateur (facultatif)
%    7. 'ratio2' = ratio 'rayon interne/rayon externe' du rsonateur 
%       (facultatif)
%
%    B) SORTIES
%
%    - Les dimensions (rayon externe, rayon interne et hauteur) du 
%      rsonateur qui respectent la bande passante minimale fixe pour la 
%      frquence de rsonance choisie (si le ratio 'rayon externe/hauteur' 
%      et/ou le ratio 'rayon interne/rayon externe' n'est (ne sont) pas 
%      fourni(s) par l'utilisateur, une liste des dimensions respectant ces
%      critres est gnre pour la (les) plage(s) de ratios dfinie(s)).
%--------------------------------------------------------------------------
%  Rfrences :
%
%  - M. Verplanken et J. Van Bladel, "The electric dipole resonances of
%    ring resonators of very high permittivity", IEEE Transactions on 
%    microwave theory and techniques, Vol. 24, Num. 2, fvrier 1976, pp. 
%    108-112.
%  - M. Verplanken et J. Van Bladel, "The magnetic dipole resonances of
%    ring resonators of very high permittivity", IEEE Transactions on 
%    microwave theory and techniques, Vol. 27, Num. 4, avril 1979, pp.
%    328-332
%--------------------------------------------------------------------------
%  Note : Ce fichier fait partie de l'Outil de conception et d'analyse 
%         des rsonateurs dilectriques (DRA.m)
%
%  Programmation : Alexandre Perron (perrona@emt.inrs.ca)               
%  Affiliation : Institut national de la recherche scientifique (INRS)  
%  Dernire modification : Le 31 juillet 2008                              
%--------------------------------------------------------------------------

function dRing_fr

% Entte :
clc
disp(strvcat('===============================================================',...
             ' Outil de conception et d''analyse des rsonateur dilectriques',...
             '==============================================================='));
disp(sprintf('\n------------ Conception d''un rsonateur annulaire -------------'));

freq = [];
while isempty(freq)||(isnumeric(freq) == 0)
   freq = input('\nEntrez la frquence de rsonance dsire (en GHz) : ');
end

choix_mode = [];
while isempty(choix_mode)||(choix_mode ~= 1 && choix_mode ~= 2)
    choix_mode = input(['\nPour quel mode de rayonnement?\n',...
                        '   (1) Mode TE01d\n', ...
                        '   (2) Mode TM01d\n', ...
                        'Faites votre choix : ']);
end

BW = [];
while isempty(BW)||(isnumeric(BW) == 0)
   BW = input('\nEntrez la bande passante fractionelle minimale (ex.: 0.05 pour 5%) : ');
end

VSWR = [];
while isempty(VSWR)||(isnumeric(VSWR) == 0)
    VSWR = input('\nEntrez le VSWR pour le calcul de la bande passante (ex.: 2) : ');
end

er = [];
while isempty(er)||(isnumeric(er) == 0)
    er = input('\nEntrez la constante dilectrique (er) du matriau disponible : ');
end

ratio = [];
if (choix_mode == 1)
    while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 3)
        ratio = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 3)\nou ''0'' si vous ne voulez pas le spcifier : ');
    end
else
    while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 1.3)
        ratio = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 1.3)\nou ''0'' si vous ne voulez pas le spcifier : ');
    end
end
    
ratio2 = [];
while isempty(ratio2)||(isnumeric(ratio2) == 0)||(ratio2 < 0)||(ratio2 > 0.75)
    ratio2 = input('\nEntrez le ratio ''rayon interne/rayon externe'' (b/a) dsir (<= 0.75)\nou ''0'' si vous ne voulez pas le spcifier : ');
end

repeter = 1;
definir_plage_ratio = 1;
definir_plage_ratio2 = 1;
while (repeter == 1)
    % Dtermination du facteur-Q maximal  partir du VSWR et de la bande passante spcifie :
    facteurQ_max = (VSWR-1)/(sqrt(VSWR)*BW);
    facteurQ = [];
    % Si les ratios sont spcifis par l'utilisateur, il faut vrifier s'il est possible d'obtenir la bande
    % passante dsire pour le mode de rayonnement choisi :
    if (ratio ~= 0 && ratio2 ~= 0)
        if (choix_mode == 1)
            facteurQ = polyval(coeffQTE(ratio2),ratio)*er^1.5;
        else 
            facteurQ = polyval(coeffQTM(ratio2),ratio)*er^2.5;
        end
        % Si ce n'est pas possible, il faut que l'utilisateur change certaines spcifications :
        if (facteurQ_max < facteurQ)
            clc
            choix = [];
            while isempty(choix)||(choix ~= 1 && choix ~= 2 && choix ~= 3 && choix ~= 4 && choix ~= 5 && choix ~= 6)
                choix = input(['\nLa bande passante dsire ne peut tre atteinte pour ce mode avec la\n',...
                               'combinaison de ratios et la constante dilectrique choisie. Dsirez-vous :\n', ...
                               '   (1) Modifier le ratio ''hauteur/rayon externe'' (h/a) (ou ne pas en spcifier)?\n', ...
                               '   (2) Modifier le ratio ''rayon interne/rayon externe'' (b/a) (ou ne pas en spcifier)?\n', ...
                               '   (3) Modifier la constante dilectrique du rsonateur?\n', ...
                               '   (4) Modifier la bande passante minimale?\n', ...
                               '   (5) Choisir un autre mode de rayonnement?\n', ...
                               '   (6) Retourner au menu principal?\n', ...                               
                               'Faites votre choix : ']);
            end

            switch choix
                case 1
                    ratio = [];
                    if (choix_mode == 1)
                        while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 3)
                            ratio = input('\nEntrez le nouveau ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 3)\nou ''0'' si vous ne voulez pas le spcifier : ');
                        end
                    else
                        while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 1.3)
                            ratio = input('\nEntrez le nouveau ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 1.3)\nou ''0'' si vous ne voulez pas le spcifier : ');
                        end
                    end    
                    if(ratio == 0)
                        definir_plage_ratio = 1;
                    end
                case 2
                    ratio2 = [];
                    while isempty(ratio2)||(isnumeric(ratio2) == 0)||(ratio2 < 0)||(ratio2 > 0.75)
                        ratio2 = input('\nEntrez le ratio ''rayon interne/rayon externe'' (b/a) dsir (<= 0.75)\nou ''0'' si vous ne voulez pas le spcifier : ');
                    end
                    if(ratio2 == 0)
                        definir_plage_ratio2 = 1;
                    end
                case 3
                    er = [];
                    while isempty(er)||(isnumeric(er) == 0)
                        er = input('\nEntrez la nouvelle constante dilectrique du rsonateur : ');
                    end
                case 4
                    BW = [];
                    while isempty(BW)||(isnumeric(BW) == 0)
                        BW = input('\nEntrez la nouvelle bande passante fractionnelle minimale (ex.: 0.05 pour 5%) : ');
                    end
                case 5 
                    choix_mode = [];
                    while isempty(choix_mode)||(choix_mode ~= 1 && choix_mode ~= 2)
                        choix_mode = input(['\nPour quel mode de rayonnement?\n',...
                                            '   (1) Mode TE01d\n', ...
                                            '   (2) Mode TM01d\n', ...
                                            'Faites votre choix : ']);
                    end
                case 6     
                    return
            end    
        
        % Lorsque tous les parametres sont corrects, on calcule les dimensions du rsonateur :
        else
            if (choix_mode == 1)
                a = 4.7713*polyval(coeffTE(ratio2),ratio)/sqrt(er)/freq;
            else
                a = 299792458*sqrt(pi^2/4/ratio^2+calcX0(ratio2)^2)/(2*pi*sqrt(er)*freq)/1e7;
            end
            h = ratio*a;
            b = ratio2*a;
            BW_reelle = (VSWR-1)/(sqrt(VSWR)*facteurQ)*100;
            repeter = 0;
        end
             
    elseif(ratio ~= 0 && ratio2 == 0)
        
        if(definir_plage_ratio2 == 1)
        
            ratio2_min = [];
            while isempty(ratio2_min)||(isnumeric(ratio2_min) == 0)||(ratio2_min < 0)||(ratio2_min >= 0.75)
                ratio2_min = input('\nEntrez le ratio ''rayon interne/rayon externe'' (b/a) minimal  tudier (0 <= ratio < 0.75) : ');
            end
        
            ratio2_max = [];
            while isempty(ratio2_max)||(isnumeric(ratio2_max) == 0)||(ratio2_max <= ratio2_min)||(ratio2_max > 0.75)
                ratio2_max = input('\nEntrez le ratio ''rayon interne/rayon externe'' (b/a) maximal  tudier (<= 0.75) : ');
            end
        
            nombre = [];
            while isempty(nombre)||(isnumeric(nombre) == 0)||(nombre < 2)
                nombre = input('\nEn incluant ces limites, entrez le nombre de ratios  tudier : ');
            end
        
            definir_plage_ratio2 = 0;
        
            % Le pas de calcul reprsente l'incrment du ratio pour chaque srie de calculs
            pas = (ratio2_max - ratio2_min)/(nombre-1);
            % Cration d'une matrice pour le stockage des rsultats valides
            resultats = [];
            % Indice de la ligne o entrer les rsultats qui respectent les paramtres de conception 
            ligne = 1;
        end    
        
        for n = ratio2_min:pas:ratio2_max
            
            % Pour chaque valeur de n (de ratio b/a), on value le facteur-Q
            if (choix_mode == 1)
                facteurQ = polyval(coeffQTE(n),ratio)*er^1.5;
            else    
                facteurQ = polyval(coeffQTM(n),ratio)*er^2.5;
            end
            
            % Si le facteur-Q calcul permet d'atteindre la bande passante minimale, on calcule les 
            % dimensions du rsonateur, sa bande passante relle et on garde les rsultats 
            if (facteurQ_max > facteurQ)
                if (choix_mode == 1)
                    a = 4.7713*polyval(coeffTE(n),ratio)/sqrt(er)/freq;
                else 
                    a = 299792458*sqrt(pi^2/4/ratio^2+calcX0(n)^2)/(2*pi*sqrt(er)*freq)/1e7;
                end
                h = ratio*a;
                b = n*a;
                BW_reelle = (VSWR-1)/(sqrt(VSWR)*facteurQ)*100;
                resultats(ligne,:) = [n a b h facteurQ BW_reelle]; 
                ligne = ligne+1;
            end    
        end
        
        if(ligne == 1)
            clc
            choix = [];
            while isempty(choix)||(choix ~= 1 && choix ~= 2 && choix ~= 3 && choix ~= 4 && choix ~= 5)
                choix = input(['\nLa bande passante minimale ne peut tre atteinte pour ce mode pour la\n',...
                               'constante dilectrique et la plage de ratios choisies. Dsirez-vous :\n', ...
                               '   (1) Modifier la plage de ratios ''rayon interne/rayon externe'' (b/a) (ou fixer un ratio unique)?\n', ...
                               '   (2) Modifier la constante dilectrique du rsonateur?\n', ...
                               '   (3) Modifier la bande passante minimale?\n', ...
                               '   (4) Choisir un autre mode de rayonnement?\n', ...
                               '   (5) Retourner au menu principal?\n', ...
                               'Faites votre choix : ']);
            end
            
            switch choix
                case 1
                    ratio2 = [];
                    while isempty(ratio2)||(isnumeric(ratio2) == 0)||(ratio2 < 0)||(ratio2 > 0.75)
                        ratio2 = input('\nEntrez le nouveau ratio ''rayon interne/rayon externe'' (b/a) dsir (0 < ratio <= 0.75) \nou ''0'' si vous ne voulez pas le spcifier : ');
                    end
                    if(ratio2 == 0)
                        definir_plage_ratio2 = 1;
                    end    
                case 2
                    er = [];
                    while isempty(er)||(isnumeric(er) == 0)
                        er = input('\nEntrez la nouvelle constante dilectrique du rsonateur : ');
                    end
                case 3
                    BW = [];
                    while isempty(BW)||(isnumeric(BW) == 0)
                        BW = input('\nEntrez la nouvelle bande passante fractionnelle minimale (ex.: 0.05 pour 5%) : ');
                    end
                case 4
                    choix_mode = [];
                    while isempty(choix_mode)||(choix_mode ~= 1 && choix_mode ~= 2)
                        choix_mode = input(['\nPour quel mode de rayonnement?\n',...
                                            '   (1) Mode TE01d\n', ...
                                            '   (2) Mode TM01d\n', ...
                                            'Faites votre choix : ']);
                    end
                case 5    
                    return
            end
            
        else
            repeter = 0;
        end

    elseif(ratio == 0 && ratio2 ~= 0)
        
        if(definir_plage_ratio == 1)
        
            ratio_min = [];
            ratio_max = [];
            
            if (choix_mode == 1)
                while isempty(ratio_min)||(isnumeric(ratio_min) == 0)||(ratio_min < 0.1)||(ratio_min >= 3)
                    ratio_min = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) minimal  tudier (0.1 <= ratio < 3) : ');
                end
                while isempty(ratio_max)||(isnumeric(ratio_max) == 0)||(ratio_max <= ratio_min)||(ratio_max > 3)
                    ratio_max = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) maximal  tudier (<= 3) : ');
                end
            else
                while isempty(ratio_min)||(isnumeric(ratio_min) == 0)||(ratio_min < 0.1)||(ratio_min >= 1.3)
                    ratio_min = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) minimal  tudier (0.1 <= ratio < 1.3) : ');
                end
                while isempty(ratio_max)||(isnumeric(ratio_max) == 0)||(ratio_max <= ratio_min)||(ratio_max > 1.3)
                    ratio_max = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) maximal  tudier (<= 1.3) : ');
                end
            end    
        
            nombre = [];
            while isempty(nombre)||(isnumeric(nombre) == 0)||(nombre < 2)
                nombre = input('\nEn incluant ces limites, entrez le nombre de ratios  tudier : ');
            end
        
            definir_plage_ratio = 0;
        
            % Le pas de calcul reprsente l'incrment du ratio pour chaque srie de calculs
            pas = (ratio_max - ratio_min)/(nombre-1);
            % Cration d'une matrice pour le stockage des rsultats valides
            resultats = [];
            % Indice de la ligne o entrer les rsultats qui respectent les paramtres de conception 
            ligne = 1;
        end    
        
        for n = ratio_min:pas:ratio_max
            
            % Pour chaque valeur de n (de ratio h/a), on value le facteur-Q
            if (choix_mode == 1)
                facteurQ = polyval(coeffQTE(ratio2),n)*er^1.5;
            else    
                facteurQ = polyval(coeffQTM(ratio2),n)*er^2.5;
            end
            
            % Si le facteur-Q calcul permet d'atteindre la bande passante minimale, on calcule les 
            % dimensions du rsonateur, sa bande passante relle et on garde les rsultats
            if (facteurQ_max > facteurQ)
                if (choix_mode == 1)
                    a = 4.7713*polyval(coeffTE(ratio2),n)/sqrt(er)/freq;
                else 
                    a = 299792458*sqrt(pi^2/4/n^2+calcX0(ratio2)^2)/(2*pi*sqrt(er)*freq)/1e7;
                end
                h = n*a;
                b = ratio2*a;
                BW_reelle = (VSWR-1)/(sqrt(VSWR)*facteurQ)*100;
                resultats(ligne,:) = [n a b h facteurQ BW_reelle]; 
                ligne = ligne+1;
            end    
        end
        
        if(ligne == 1)
            clc
            choix = [];
            while isempty(choix)||(choix ~= 1 && choix ~= 2 && choix ~= 3 && choix ~= 4 && choix ~= 5)
                choix = input(['\nLa bande passante minimale ne peut tre atteinte pour ce mode pour la\n',...
                               'constante dilectrique et la plage de ratios choisies. Dsirez-vous :\n', ...
                               '   (1) Modifier la plage de ratios ''hauteur/rayon externe'' (h/a) (ou fixer un ratio unique)?\n', ...
                               '   (2) Modifier la constante dilectrique du rsonateur?\n', ...
                               '   (3) Modifier la bande passante minimale?\n', ...
                               '   (4) Choisir un autre mode de rayonnement?\n', ...
                               '   (5) Retourner au menu principal?\n', ...
                               'Faites votre choix : ']);
            end
            
            switch choix
                case 1
                    ratio = [];
                    if (choix_mode == 1)
                        while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 3)
                            ratio = input('\nEntrez le nouveau ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 3)\nou ''0'' si vous ne voulez pas le spcifier : ');
                        end
                    else
                        while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 1.3)
                            ratio = input('\nEntrez le nouveau ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 1.3)\nou ''0'' si vous ne voulez pas le spcifier : ');
                        end
                    end
                    if(ratio == 0)
                        definir_plage_ratio = 1;
                    end    
                case 2
                    er = [];
                    while isempty(er)||(isnumeric(er) == 0)
                        er = input('\nEntrez la nouvelle constante dilectrique du rsonateur : ');
                    end
                case 3
                    BW = [];
                    while isempty(BW)||(isnumeric(BW) == 0)
                        BW = input('\nEntrez la nouvelle bande passante fractionnelle minimale (ex.: 0.05 pour 5%) : ');
                    end
                case 4
                    choix_mode = [];
                    while isempty(choix_mode)||(choix_mode ~= 1 && choix_mode ~= 2)
                        choix_mode = input(['\nPour quel mode de rayonnement?\n',...
                                            '   (1) Mode TE01d\n', ...
                                            '   (2) Mode TM01d\n', ...
                                            'Faites votre choix : ']);
                    end
                case 5    
                    return
            end
            
        else
            repeter = 0;
        end
        
    else
        if(definir_plage_ratio == 1)

            ratio_min = [];
            ratio_max = [];
            
            if (choix_mode == 1)
                while isempty(ratio_min)||(isnumeric(ratio_min) == 0)||(ratio_min < 0.1)||(ratio_min >= 3)
                    ratio_min = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) minimal  tudier (0.1 <= ratio < 3) : ');
                end
                while isempty(ratio_max)||(isnumeric(ratio_max) == 0)||(ratio_max <= ratio_min)||(ratio_max > 3)
                    ratio_max = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) maximal  tudier (<= 3) : ');
                end
            else
                while isempty(ratio_min)||(isnumeric(ratio_min) == 0)||(ratio_min < 0.1)||(ratio_min >= 1.3)
                    ratio_min = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) minimal  tudier (0.1 <= ratio < 1.3) : ');
                end
                while isempty(ratio_max)||(isnumeric(ratio_max) == 0)||(ratio_max <= ratio_min)||(ratio_max > 1.3)
                    ratio_max = input('\nEntrez le ratio ''hauteur/rayon externe'' (h/a) maximal  tudier (<= 1.3) : ');
                end
            end     
        
            nombre = [];
            while isempty(nombre)||(isnumeric(nombre) == 0)||(nombre < 2)
                nombre = input('\nEn incluant ces limites, entrez le nombre de ratios  tudier : ');
            end
        
            definir_plage_ratio = 0;
        
            % Le pas de calcul reprsente l'incrment du ratio pour chaque srie de calculs
            pas = (ratio_max - ratio_min)/(nombre-1);
            % Cration d'une matrice pour le stockage des rsultats valides
            resultats = [];
            % Indice de la ligne o entrer les rsultats qui respectent les paramtres de conception 
            ligne = 1;
        end
        
        if(definir_plage_ratio2 == 1)

            ratio2_min = [];
            while isempty(ratio2_min)||(isnumeric(ratio2_min) == 0)||(ratio2_min < 0)||(ratio2_min >= 0.75)
                ratio2_min = input('\nEntrez le ratio ''rayon interne/rayon externe'' (b/a) minimal  tudier (0 < ratio < 0.75) : ');
            end
        
            ratio2_max = [];
            while isempty(ratio2_max)||(isnumeric(ratio2_max) == 0)||(ratio2_max <= ratio2_min)||(ratio2_max > 0.75)
                ratio2_max = input('\nEntrez le ratio ''rayon interne/rayon externe'' (b/a) maximal  tudier (<= 0.75) : ');
            end
        
            nombre2 = [];
            while isempty(nombre2)||(isnumeric(nombre2) == 0)||(nombre2 < 2)
                nombre2 = input('\nEn incluant ces limites, entrez le nombre de ratios  tudier : ');
            end
        
            definir_plage_ratio2 = 0;
        
            % Le pas de calcul reprsente l'incrment du ratio pour chaque srie de calculs
            pas2 = (ratio2_max - ratio2_min)/(nombre2-1);
            % Cration d'une matrice pour le stockage des rsultats valides
            resultats = [];
            % Indice de la ligne o entrer les rsultats qui respectent les paramtres de conception 
            ligne = 1;
        end
        
        for n = ratio_min:pas:ratio_max
            for m = ratio2_min:pas2:ratio2_max 
                % Pour chaque valeur de n et m (de ratio h/a et de ratio b/a), on value le facteur-Q
                if (choix_mode == 1)
                    facteurQ = polyval(coeffQTE(m),n)*er^1.5;
                else    
                    facteurQ = polyval(coeffQTM(m),n)*er^2.5;
                end
            
                % Si le facteur-Q calcul permet d'atteindre la bande passante minimale, on calcule les 
                % dimensions du rsonateur, sa bande passante relle et on garde les rsultats
                if (facteurQ_max > facteurQ)
                    if (choix_mode == 1)
                        a = 4.7713*polyval(coeffTE(m),n)/sqrt(er)/freq;
                    else 
                        a = 299792458*sqrt(pi^2/4/n^2+calcX0(m)^2)/(2*pi*sqrt(er)*freq)/1e7;
                    end
                    h = n*a;
                    b = m*a;
                    BW_reelle = (VSWR-1)/(sqrt(VSWR)*facteurQ)*100;
                    resultats(ligne,:) = [n m a b h facteurQ BW_reelle]; 
                    ligne = ligne+1;
                end    
            end
        end
        
        if(ligne == 1)
            clc
            choix = [];
            while isempty(choix)||(choix ~= 1 && choix ~= 2 && choix ~= 3 && choix ~= 4 && choix ~= 5 && choix ~= 6)
                choix = input(['\nLa bande passante minimale ne peut tre atteinte pour ce mode pour la\n',...
                               'constante dilectrique et la plage de ratios choisies. Dsirez-vous :\n', ...
                               '   (1) Modifier la plage de ratios ''hauteur/rayon externe'' (h/a) (ou fixer un ratio unique)?\n', ...
                               '   (2) Modifier la plage de ratios ''rayon externe/rayon interne'' (b/a) (ou fixer un ratio unique)?\n', ...
                               '   (3) Modifier la constante dilectrique du rsonateur?\n', ...
                               '   (4) Modifier la bande passante minimale?\n', ...
                               '   (5) Choisir un autre mode de rayonnement?\n', ...
                               '   (6) Retourner au menu principal?\n', ...
                               'Faites votre choix : ']);
            end
            
            switch choix
                case 1
                    ratio = [];
                    if (choix_mode == 1)
                        while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 3)
                            ratio = input('\nEntrez le nouveau ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 3)\nou ''0'' si vous ne voulez pas le spcifier : ');
                        end
                    else
                        while isempty(ratio)||(isnumeric(ratio) == 0)||(ratio < 0.1 && ratio ~= 0)||(ratio > 1.3)
                            ratio = input('\nEntrez le nouveau ratio ''hauteur/rayon externe'' (h/a) dsir (0.1 <= ratio <= 1.3)\nou ''0'' si vous ne voulez pas le spcifier : ');
                        end
                    end
                    if(ratio == 0)
                        definir_plage_ratio = 1;
                    end
                case 2
                    ratio2 = [];
                    while isempty(ratio2)||(isnumeric(ratio2) == 0)||(ratio2 < 0)||(ratio2 > 0.75)
                        ratio2 = input('\nEntrez le nouveau ratio ''rayon interne/rayon externe'' (b/a) dsir (0 < ratio <= 0.75) \nou ''0'' si vous ne voulez pas le spcifier : ');
                    end
                    if(ratio2 == 0)
                        definir_plage_ratio2 = 1;
                    end
                case 3
                    er = [];
                    while isempty(er)||(isnumeric(er) == 0)
                        er = input('\nEntrez la nouvelle constante dilectrique du rsonateur : ');
                    end
                case 4
                    BW = [];
                    while isempty(BW)||(isnumeric(BW) == 0)
                        BW = input('\nEntrez la nouvelle bande passante fractionnelle minimale (ex.: 0.05 pour 5%) : ');
                    end
                case 5
                    choix_mode = [];
                    while isempty(choix_mode)||(choix_mode ~= 1 && choix_mode ~= 2)
                        choix_mode = input(['\nPour quel mode de rayonnement?\n',...
                                            '   (1) Mode TE01d\n', ...
                                            '   (2) Mode TM01d\n', ...
                                            'Faites votre choix : ']);
                    end
                case 6    
                    return
            end
        else
            repeter = 0;
        end    
    end
    
    if (repeter == 0)
        
        % Entte :
        clc
        disp(strvcat('===============================================================',...
                     ' Outil de conception et d''analyse des rsonateur dilectriques',...
                     '==============================================================='));
        disp(sprintf('\n------------ Conception d''un rsonateur annulaire -------------\n'));

        % Affichage des paramtres d'entre :
        disp(sprintf('Frquence de rsonance (en GHz) = %5.4f',freq));
    
        if (choix_mode == 1)
            disp(sprintf('Mode de rayonnement = TE01d'));
        else  
            disp(sprintf('Mode de rayonnement = TM01d'));
        end
    
        disp(sprintf('Bande passante fractionnelle minimale = %5.4f',BW));
        disp(sprintf('VSWR pour le calcul de la bande passante = %5.4f',VSWR));
        disp(sprintf('Constante dilectrique du rsonateur = %5.4f',er));
        
        % Affichage des rsultats :
        if (ratio ~= 0 && ratio2 ~= 0)
            disp(sprintf('Ratio ''hauteur/rayon externe'' (h/a) = %5.4f',ratio));
            disp(sprintf('Ratio ''rayon interne/rayon externe'' (b/a) = %5.4f',ratio2));
            
            disp(sprintf('\n'));
            disp(strvcat('        Rsultats pour le mode choisi', ...
                         '--------------------------------------------'));
            disp(sprintf('Rayon interne (b) du rsonateur (en cm) = %5.4f',b));
            disp(sprintf('Rayon externe (a) du rsonateur (en cm) = %5.4f',a));
            disp(sprintf('Hauteur (h) du rsonateur (en cm) = %5.4f',h));
            disp(sprintf('Facteur-Q = %5.4f',facteurQ));
            disp(sprintf('Bande passante (en pourcentage) = %5.4f',BW_reelle));
            
        elseif (ratio ~= 0 && ratio2 == 0)
            disp(sprintf('Ratio ''hauteur/rayon externe'' (h/a) = %5.4f',ratio));
            disp(sprintf('Ratio ''rayon interne/rayon externe'' (b/a) minimal = %5.4f',ratio2_min));
            disp(sprintf('Ratio ''rayon interne/rayon externe'' (b/a) maximal = %5.4f',ratio2_max));
            disp(sprintf('Nombre de ratios  tudier = %5.5f',nombre));
            
            disp(sprintf('\n'));
            disp(strvcat('                  Rsultats pour le mode choisi', ...                   
                         '===================================================================='));
            disp('b/a         a           b           h           facteurQ    BW');   
            disp('--------------------------------------------------------------------');
            for n = 1:1:size(resultats,1)
                disp(sprintf('%-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g',resultats(n,:)));
            end
        elseif (ratio == 0 && ratio2 ~= 0)
            disp(sprintf('Ratio ''rayon interne/rayon externe'' (b/a) = %5.4f',ratio2));
            disp(sprintf('Ratio ''hauteur/rayon externe'' (h/a) minimal = %5.4f',ratio_min));
            disp(sprintf('Ratio ''hauteur/rayon externe'' (h/a) maximal = %5.4f',ratio_max));
            disp(sprintf('Nombre de ratios  tudier = %5.4f',nombre));
            
            disp(sprintf('\n'));
            disp(strvcat('                  Rsultats pour le mode choisi', ...     
                         '===================================================================='));
            disp('h/a         a           b           h           facteurQ    BW');
            disp('--------------------------------------------------------------------');
            for n = 1:1:size(resultats,1)
                disp(sprintf('%-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g',resultats(n,:)));
            end
        else
            disp(sprintf('Ratio ''hauteur/rayon externe'' (h/a) minimal = %5.4f',ratio_min));
            disp(sprintf('Ratio ''hauteur/rayon externe'' (h/a) maximal = %5.4f',ratio_max));
            disp(sprintf('Nombre de ratios  tudier = %5.4f',nombre));
            disp(sprintf('\n'));
            disp(sprintf('Ratio ''rayon interne/rayon externe'' (b/a) minimal = %5.4f',ratio2_min));
            disp(sprintf('Ratio ''rayon interne/rayon externe'' (b/a) maximal = %5.4f',ratio2_max));
            disp(sprintf('Nombre de ratios  tudier = %5.4f',nombre2));
            
            disp(sprintf('\n'));
            disp(strvcat('                         Rsultats pour le mode choisi', ...                              
                         '================================================================================'));
            disp('h/a         b/a         a           b           h           facteurQ    BW');
            disp('--------------------------------------------------------------------------------');
            for n = 1:1:size(resultats,1)
                disp(sprintf('%-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g    %-8.4g',resultats(n,:)));
            end    
        end
    end
end

end

Contact us at files@mathworks.com