Structure de l’atome

(code sous licence creative commun CC BY-NC-SA BY Alexis Dendiével)

Télécharger le pdf

Télécharger le notebook

Lancer le notebook sur binder (lent)

A partir du numéro atomique et du nombre de masse, ce programme:

  • donne le nom et le symbole de l’atome

  • précise le nombre de protons, neutrons, et électrons

  • calcule la masse (approchée) du noyau et de l’atome entier

  • donne la répartition électronique par couche (pour les 18 premiers éléments)

  • donne la structure électronique selon la règle de Klechkowski (les exeptions n’ont pas été traitées)

Sans entrer dans la compréhension détaillée du code, je vous propose d’exécuter le programme suivant (mais vous pouvez quand même lire les commentaires :) :

[1]:
# fonction affichant la structure de l'atome
def structure(A, Z):
    #données
    # la masse des protons et des neutrons est approchée:
    masse_nucleon = 1.67e-27
    # masse de l'électron
    masse_electron = 9.109e-31
    # liste des orbitales atomiques
    liste_orbitales = ( (1, 's', 2),  (2, 's', 2),  (2, 'p', 6),
                        (3, 's', 2),  (3, 'p', 6),  (4, 's', 2),
                        (3, 'd', 10), (4, 'p', 6),  (5, 's', 2),
                        (4, 'd', 10), (5, 'p', 6),  (6, 's', 2),
                        (4, 'f', 14), (5, 'd', 10), (6, 'p', 6),
                        (7, 's', 2),  (5, 'f', 14), (6, 'd', 10),
                        (7, 'p', 6) )
    # liste des éléments chimiques de la classification
    elements = (
    "Hydrogène H", "Hélium He", "Lithium Li", "Béryllium Be",
    "Bore B", "Carbone C", "Azote N", "Oxygène O",
    "Fluor F", "Néon Ne", "Sodium Na", "Magnésium Mg",
    "Aluminium Al", "Silicium Si", "Phosphore P",
    "Soufre S", "Chlore Cl", "Argon Ar", "Potassium K",
    "Calcium Ca", "Scandium Sc", "Titane Ti", "Vanadium V",
    "Chrome Cr", "Manganèse Mn", "Fer Fe", "Cobalt Co",
    "Nickel Ni", "Cuivre Cu", "Zinc Zn", "Gallium Ga",
    "Germanium Ge", "Arsenic As", "Sélénium Se",
    "Brome Br", "Krypton Kr", "Rubidium Rb",
    "Strontium Sr", "Yttrium Y", "Zirconium Zr",
    "Niobium Nb", "Molybdène Mo", "Technétium Tc",
    "Ruthénium Ru", "Rhodium Rh", "Palladium Pd",
    "Argent Ag", "Cadmium Cd", "Indium In", "Étain Sn",
    "Antimoine Sb", "Tellure Te", "Iode I", "Xénon Xe",
    "Césium Cs", "Baryum Ba", "Lanthane La", "Cérium Ce",
    "Praséodyme Pr", "Néodyme Nd", "Prométhium Pm",
    "Samarium Sm", "Europium Eu", "Gadolinium Gd",
    "Terbium Tb", "Dysprosium Dy", "Holmium Ho",
    "Erbium Er", "Thulium Tm", "Ytterbium Yb",
    "Lutécium Lu", "Hafnium Hf", "Tantale Ta",
    "Tungstène W", "Rhénium Re", "Osmium Os",
    "Iridium Ir", "Platine Pt", "Or Au", "Mercure Hg",
    "Thallium Tl", "Plomb Pb", "Bismuth Bi", "Polonium Po",
    "Astate At", "Radon Rn", "Francium Fr", "Radium Ra",
    "Actinium Ac",  "Thorium Th", "Protactinium Pa",
    "Uranium U", "Neptunium Np", "Plutonium Pu",
    "Américium Am", "Curium Cm", "Berkélium Bk",
    "Californium Cf", "Einsteinium Es", "Fermium Fm",
    "Mendélévium Md", "Nobélium No", "Lawrencium Lr",
    "Rutherfordium Rf", "Dubnium Db", "Seaborgium Sg",
    "Bohrium Bh", "Hassium Hs", "Meitnérium Mt",
    "Darmstadtium Ds", "Roentgenium Rg", "Ununbium Uub",
    "Ununtrium Uut", "Ununquadium Uuq", "Ununpentium Uup",
    "Ununhexium Uuh", "Ununseptium Uus", "Ununoctium Uuo")


    #calcul des masses
    masse_noyau = A * masse_nucleon
    masse = A * masse_nucleon + Z * masse_electron

    # calcul des couches électroniques

    if Z <= 2:
        couches = "(K)" + str(Z)
    elif Z <=10:
        couches = "(K)" + str(2) + "(L)" + str(Z-2)
    elif Z <= 18:
        couches = "(K)" + str(2) + "(L)" + str(8) \
                          + "(M)" + str(Z-10)
    else:
        couches = "\nce calcul est limité à des numéros " + \
                  "atomiques inférieurs ou égal à 18"


    # calcul des orbitales atomiques
    orbitale = 0
    n_restant = Z
    structure = ""
    while n_restant > 0:
        (n, nom, ne) = liste_orbitales [orbitale]
        if n_restant < ne:
            nmin = n_restant
        else:
            nmin = ne
        structure = structure + str(n) + nom + str(nmin) + ' '
        n_restant = n_restant - nmin
        orbitale = orbitale + 1

    # impression des résultats
    print("---------------------")
    print ("RESULTATS pour A =", A, " et Z =",Z)
    # impression de l'élément et de son symbole
    print("il s'agit de l'élément :", elements[Z-1])
    # impression de la structure de l'atome
    print("nombre de protons : ", Z )
    print("nombre de neutrons : ", A - Z)
    print("nombre d'électrons : ", Z)
    # impression des masses, du noyau et de l'atome
    print("masse du noyau : ",
          "{0:.3e}".format(masse_noyau), ' kg')
    print("masse de l'atome : ",
          "{0:.3e}".format(masse), ' kg')
    print("")
    # impression des couches et structure électronique
    print("remplissage des couches électroniques :",
          couches)
    print("la structure électronique est :",
          structure)
[2]:
# Utilisation : calcul de la structure
# Chlore
structure(A=36,Z=17)
# Carbone
structure(A=12,Z=6)
---------------------
RESULTATS pour A = 36  et Z = 17
il s'agit de l'élément : Chlore Cl
nombre de protons :  17
nombre de neutrons :  19
nombre d'électrons :  17
masse du noyau :  6.012e-26  kg
masse de l'atome :  6.014e-26  kg

remplissage des couches électroniques : (K)2(L)8(M)7
la structure électronique est : 1s2 2s2 2p6 3s2 3p5
---------------------
RESULTATS pour A = 12  et Z = 6
il s'agit de l'élément : Carbone C
nombre de protons :  6
nombre de neutrons :  6
nombre d'électrons :  6
masse du noyau :  2.004e-26  kg
masse de l'atome :  2.005e-26  kg

remplissage des couches électroniques : (K)2(L)4
la structure électronique est : 1s2 2s2 2p2