±±¾©Ê¯ÓÍ»¯¹¤Ñ§Ôº2026ÄêÑо¿ÉúÕÐÉú½ÓÊÕµ÷¼Á¹«¸æ
²é¿´: 1520  |  »Ø¸´: 6
µ±Ç°Ö»ÏÔʾÂú×ãÖ¸¶¨Ìõ¼þµÄ»ØÌû£¬µã»÷ÕâÀï²é¿´±¾»°ÌâµÄËùÓлØÌû

ÄäÃû

Óû§×¢Ïú (СÓÐÃûÆø)

±¾Ìû½öÂ¥Ö÷¿É¼û

» ²ÂÄãϲ»¶

» ±¾Ö÷ÌâÏà¹Ø¼ÛÖµÌùÍÆ¼ö£¬¶ÔÄúͬÑùÓаïÖú:

ÒÑÔÄ   ͬ·½Ïò¹ã²¥   ÉêÇë1STÇ¿Ìû   »Ø¸´´ËÂ¥   ±à¼­   ²é¿´ÎÒµÄÖ÷Ò³

ÄäÃû

Óû§×¢Ïú (СÓÐÃûÆø)

±¾Ìû½öÂ¥Ö÷¿É¼û
4Â¥2014-07-01 08:59:37
ÒÑÔÄ   ÉêÇë1STÇ¿Ìû   »Ø¸´´ËÂ¥   ±à¼­   ²é¿´ÎÒµÄÖ÷Ò³
²é¿´È«²¿ 7 ¸ö»Ø´ð

liqizuiyang

ľ³æ (ÖøÃûдÊÖ)

¡¾´ð°¸¡¿Ó¦Öú»ØÌû

¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï ¡ï
¸Ðл²ÎÓ룬ӦÖúÖ¸Êý +1
lijunlhc: ½ð±Ò+20, ¡ï¡ï¡ïºÜÓаïÖú 2014-07-01 08:57:25
Ö»ÓÐÀàÇâÔ­×Ó²ÅÓÐ1s 2s 2pÕâÑùµÄ½â¡£Êµ¼ÊÌåϵÖÐÓÉÓÚÊÆ³¡²»ÔÙÊÇÖÐÐÄÊÆ£¬½Ç¶¯Á¿²»ÔÙÊÇÊØºãÁ¿£¬²»ÔÙ´æÔÚs,pÕâÑùµÄ̬¡£

ÕâÊÇÒ»¸öÊä³öÀàÇâÔ­×Ó²¨º¯ÊýµÄC³ÌÐòÔ´Â룺
/******************************************************************************
  This program generates wavefunction for hydrogen-like atoms using analytical
  solution to Shrodinger's equation.
  
  This program requires no command-line parameters, but an input file called
  orb.inp. This input file must be in the form:
  ---------------------------------------------
    H4f2.real.cube  //  output filename
    1               //  which part to output, 1 for real, -1 for imaginary
    1               //  Zval of the nuclea
    4 3 2           //  n l m
    20.0 20.0 20.0  //  size of the box, which will be multiplied by 2
    0.20 0.20 0.20  //  resolution
  ----------------------------------------------

******************************************************************************/

#include <stdio.h>
#include <math.h>
#include <stdlib.h>

double factor( int );
double ReNormFactor( int, int, int );
double KummerFunc( int, int, double );
double RadialFunc( int, int, int, double );
double RealSphereHarm( int, int, double, double );
double ImagSphereHarm( int, int, double, double );
int checkinp( int, int, int );

double factor( int n )
{
    if ( n == 0 )
        return 1.0;
    else{
        double y;
        int i;
        y = 1.0;
        for( i = 1; i < n + 1; i ++ )
            y = y * (double)(i);
        return y;
    }
}

double ReNormFactor( int Z, int n, int l )
{
    double A, B, C;
    A = 2.0 / ( (double)(n*n) * factor(2*l+1));
    B = sqrt( factor(n+l) / factor(n-l-1) );
    C = sqrt( (double)(Z*Z*Z) );
    return A * B * C;
}

double KummerFunc( int alpha, int gamma, double ita )
{
    double sum, ck;
    int k;
    sum = 1.0;
    ck = 1.0;
    for( k = 1; k < -alpha+1; k ++ )
    {
        ck = ck * (double)(alpha+k-1) / (double)(gamma+k-1) * (1.0/(double)(k));
        sum = sum+ ck * pow( ita, (double)(k) );
    }
    return sum;
}

double RadialFunc( int Z, int n, int l, double r )
{
    double ita, NormFactor, A, B, C;
    ita = 2.0 * (double)(Z) / (double)(n) * r;
    NormFactor = ReNormFactor( Z, n, l );
    A = exp( -0.5 * ita  );
    B = pow( ita, (double)(l) );
    C = KummerFunc( -n+l+1, 2*l+2, ita );
    return NormFactor * A * B * C;
}

double RealSphereHarm( int l, int m, double theta, double phi )
{
    if (l == 0)
        return 2.820947917738782e-1;
    else if (l == 1)
        switch(m)
        {
            case -1: return  3.454941494713355e-1 * cos(m*phi) * sin(theta); break;
            case  0: return  4.886025119029199e-1 * cos(m*phi) * cos(theta); break;
            case  1: return -3.454941494713355e-1 * cos(m*phi) * sin(theta); break;
            default: return 0.0; break;
        }
    else if (l == 2)
        switch(m)
        {
            case -2: return  3.862742020231896e-1 * cos(m*phi) * sin(theta) * sin(theta); break;
            case -1: return  7.725484040463792e-1 * cos(m*phi) * sin(theta) * cos(theta); break;
            case  0: return  3.153915652525200e-1 * cos(m*phi) * ( 3.0*cos(theta)*cos(theta) - 1.0 ); break;
            case  1: return -7.725484040463792e-1 * cos(m*phi) * sin(theta) * cos(theta); break;
            case  2: return  3.862742020231896e-1 * cos(m*phi) * sin(theta) * sin(theta); break;
            default: return 0.0; break;
        }
    else if (l == 3)
        switch(m)
        {
            case -3: return  4.172238236327841e-1 * cos(m*phi) * sin(theta) * sin(theta) * sin(theta); break;
            case -2: return  1.021985476433282    * cos(m*phi) * sin(theta) * sin(theta) * cos(theta); break;
            case -1: return  3.231801841141507e-1 * cos(m*phi) * sin(theta) * ( 5.0*cos(theta)*cos(theta) - 1.0 ); break;
            case  0: return  3.731763325901154e-1 * cos(m*phi) * cos(theta) * ( 5.0*cos(theta)*cos(theta) - 3.0 ); break;
            case  1: return -3.231801841141507e-1 * cos(m*phi) * sin(theta) * ( 5.0*cos(theta)*cos(theta) - 1.0 ); break;
            case  2: return  1.021985476433282    * cos(m*phi) * sin(theta) * sin(theta) * cos(theta); break;
            case  3: return -4.172238236327841e-1 * cos(m*phi) * sin(theta) * sin(theta) * sin(theta); break;
            default: return 0.0; break;
        }
    else
        return 0.0;
}

double ImagSphereHarm( int l, int m, double theta, double phi )
{
    if (l == 0)
        return 0.0;
    else if (l == 1)
        switch(m)
        {
            case -1: return  3.454941494713355e-1 * sin(m*phi) * sin(theta); break;
            case  0: return  4.886025119029199e-1 * sin(m*phi) * cos(theta); break;
            case  1: return -3.454941494713355e-1 * sin(m*phi) * sin(theta); break;
            default: return 0.0; break;
        }
    else if (l == 2)
        switch(m)
        {
            case -2: return  3.862742020231896e-1 * sin(m*phi) * sin(theta) * sin(theta); break;
            case -1: return  7.725484040463792e-1 * sin(m*phi) * sin(theta) * cos(theta); break;
            case  0: return  3.153915652525200e-1 * sin(m*phi) * ( 3.0*cos(theta)*cos(theta) - 1.0 ); break;
            case  1: return -7.725484040463792e-1 * sin(m*phi) * sin(theta) * cos(theta); break;
            case  2: return  3.862742020231896e-1 * sin(m*phi) * sin(theta) * sin(theta); break;
            default: return 0.0; break;
        }
    else if (l == 3)
        switch(m)
        {
            case -3: return  4.172238236327841e-1 * sin(m*phi) * sin(theta) * sin(theta) * sin(theta); break;
            case -2: return  1.021985476433282    * sin(m*phi) * sin(theta) * sin(theta) * cos(theta); break;
            case -1: return  3.231801841141507e-1 * sin(m*phi) * sin(theta) * ( 5.0*cos(theta)*cos(theta) - 1.0 ); break;
            case  0: return  3.731763325901154e-1 * sin(m*phi) * cos(theta) * ( 5.0*cos(theta)*cos(theta) - 3.0 ); break;
            case  1: return -3.231801841141507e-1 * sin(m*phi) * sin(theta) * ( 5.0*cos(theta)*cos(theta) - 1.0 ); break;
            case  2: return  1.021985476433282    * sin(m*phi) * sin(theta) * sin(theta) * cos(theta); break;
            case  3: return -4.172238236327841e-1 * sin(m*phi) * sin(theta) * sin(theta) * sin(theta); break;
            default: return 0.0; break;
        }
    else
        return 0.0;
}

int checkinp( int l, int m, int flavor )
{
    if ( l < 0 )
        return -1;
    else if ( l > 3 )
        return -2;
    else if ( m < 0 && -m > l )
        return -3;
    else if ( m >= 0 && m > l )
        return -3;
    else if ( flavor != -1 && flavor != 1 )
        return -4;
    else
        return 0;
}

int main( void )
{
    //  these variables are related to orb.inp
    char cubename[32];
    int flavor;
    int Z;
    int n, l, m;
    double xmax, ymax, zmax;
    double hx, hy, hz;
   
    //  these variables are related to mesh-info
    int NGX, NGY, NGZ, NX, NY, NZ;
    int i, j, k;
    double orgx, orgy, orgz;
    double x, y, z, r, theta, phi, gridval;
   
    // files used through the program
    FILE *cube, *inp;
   
    // program status
    int status;
   
    // global constant
    const double PI = 3.14159265358979;
   
    // read in 'orb.inp'
    inp = fopen("orb.inp","r";
    fscanf( inp, "%s\n", &cubename );
    fscanf( inp, "%d\n", &flavor );
    fscanf( inp, "%d\n", &Z );
    fscanf( inp, "%d%d%d\n", &n, &l, &m );
    fscanf( inp, "%lf%lf%lf\n", &xmax, &ymax, &zmax );
    fscanf( inp, "%lf%lf%lf\n", &hx, &hy, &hz );
    fclose( inp );
   
    // check input parameters
    status = checkinp( l, m, flavor );
    if ( status != 0 )
    {
        printf( "\nProgram exited with error code:" );
        printf( "%4d\n", status );
        printf( "Check your input" );
        printf("\n";
        return status;
    }
    else
    {
        // calculate NGX, NGY, NGZ
        NGX = (int)(xmax/hx);
        NGY = (int)(ymax/hy);
        NGZ = (int)(zmax/hz);
        
        // origin of grid
        orgx = -hx * (NGX - 1) + hx * 0.5;
        orgy = -hy * (NGY - 1) + hy * 0.5;
        orgz = -hz * (NGZ - 1) + hz * 0.5;
        
        // size of grid
        NX = 2 * NGX;
        NY = 2 * NGY;
        NZ = 2 * NGZ;
        
        // open cube file
        cube = fopen(cubename,"w";
        
        // write first 2 lines to cube
        if ( flavor == 1)
            fprintf( cube, "Real part of atomic orbitals of H-like atoms\n";
        else
            fprintf( cube, "Imag part of atomic orbitals of H-like atoms\n";
        fprintf( cube, "Generated by programm orb.x\n";
        
        // write natom and origin of data
        fprintf( cube, "%5d%12.6f%12.6f%12.6f\n", 1, orgx, orgy, orgz  );
        
        // write mesh info
        fprintf( cube, "%5d%12.6f%12.6f%12.6f\n", NX,  hx, 0.0, 0.0 );
        fprintf( cube, "%5d%12.6f%12.6f%12.6f\n", NY, 0.0,  hy, 0.0 );
        fprintf( cube, "%5d%12.6f%12.6f%12.6f\n", NZ, 0.0, 0.0,  hz );
        
        // write atoms info
        fprintf( cube, "%5d%12.6f%12.6f%12.6f%12.6f\n", Z, 1.0*Z, 0.0, 0.0, 0.0 );
        
        // entering main loop
        if ( flavor == 1 )
        {
            for ( i = 1; i <= NX; i ++ )
                for ( j = 1; j <= NY; j ++ )
                    for( k = 1; k <= NZ; k ++ )
                    {
                        x = orgx + hx * ( i - 1 );
                        y = orgy + hy * ( j - 1 );
                        z = orgz + hz * ( k - 1 );
                        r = sqrt( x*x + y*y + z*z );
                        theta = acos( z/r );
                        if ( y >= 0.0 )
                            phi = acos( x / sqrt(x*x+y*y) );
                        else
                            phi = 2.0 * PI - acos( x / sqrt(x*x+y*y) );
                        gridval = RadialFunc( Z, n, l, r ) * RealSphereHarm( l, m, theta, phi );
                        fprintf( cube, "%13.5e", gridval );
                        if ( k == NZ || k%6==0 )
                            fprintf( cube, "\n" );
                    }
        }
        else
        {
            for ( i = 1; i <= NX; i ++ )
                for ( j = 1; j <= NY; j ++ )
                    for( k = 1; k <= NZ; k ++ )
                    {
                        x = orgx + hx * ( i - 1 );
                        y = orgy + hy * ( j - 1 );
                        z = orgz + hz * ( k - 1 );
                        r = sqrt( x*x + y*y + z*z );
                        theta = acos( z/r );
                        if ( y >= 0.0 )
                            phi = acos( x / sqrt(x*x+y*y) );
                        else
                            phi = 2.0 * PI - acos( x / sqrt(x*x+y*y) );
                        gridval = RadialFunc( Z, n, l, r ) * ImagSphereHarm( l, m, theta, phi );
                        fprintf( cube, "%13.5e", gridval );
                        if ( k == NZ || k%6==0 )
                            fprintf( cube, "\n" );
                    }
        }
            
        fclose(cube);
        return 0;
    }
}
===================================================
2Â¥2014-06-30 10:45:43
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

liqizuiyang

ľ³æ (ÖøÃûдÊÖ)

²¹³ä£º

px, py, pzºÍm=-1,1,0Ö®¼äµÄ¹ØÏµ±È½Ï¸´ÔÓ¡£pz¶ÔÓ¦m=0£¬µ«pxºÍpyÊÇm=1ºÍm=-1µÄÏßÐÔ×éºÏ¡£
3Â¥2014-06-30 10:48:44
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

liqizuiyang

ľ³æ (ÖøÃûдÊÖ)

ÒýÓûØÌû:
4Â¥: Originally posted by lijunlhc at 2014-07-01 08:59:37
ËäÈ»¿´²»Ì«¶®£¬»¹ÊÇлл¥Ö÷»Ø¸´ÁË¡£ÎÒ¿´µÄһЩÂÛÎÄÖÐÈ·ÓйìµÀ²¨º¯Êý£¬¶øÇÒ²¢·ÇÏÞÓÚÀàÇâÔ­×Ó£¬Â¥Ö÷Ôõô¿´£¿...

ÊDz»ÊǸøµÄÊÇPDOS£¿ÄÜ·ñ·¢¸öÎÄÕÂÁ´½Ó£¿
5Â¥2014-07-01 09:11:53
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû
×î¾ßÈËÆøÈÈÌûÍÆ¼ö [²é¿´È«²¿] ×÷Õß »Ø/¿´ ×îºó·¢±í
[¿¼ÑÐ] ÄϾ©´óѧ»¯Ñ§µ÷¼Á +4 ¾°Ëæ·ç 2026-03-29 7/350 2026-03-29 10:36 by lsw010101
[¿¼ÑÐ] 356Çóµ÷¼Á +3 gysy?s?a 2026-03-28 3/150 2026-03-29 00:33 by 544594351
[¿¼ÑÐ] 295Çóµ÷¼Á +4 wei-5 2026-03-26 4/200 2026-03-28 23:20 by Сľ³ætim
[¿¼ÑÐ] 0703»¯Ñ§µ÷¼Á£¬Çóµ¼Ê¦ÊÕ +9 ÌìÌìºÃÔËÀ´Éϰ¶° 2026-03-24 10/500 2026-03-28 22:17 by chemzp
[¿¼ÑÐ] 085701Çóµ÷¼Á³õÊÔ286·Ö +4 secret0328 2026-03-28 4/200 2026-03-28 21:09 by 15366876211
[¿¼ÑÐ] ÉúÎïѧѧ˶£¬Ò»Ö¾Ô¸ºþÄÏ´óѧ£¬³õÊԳɼ¨338 +6 YYYYYNNNNN 2026-03-26 7/350 2026-03-28 20:52 by ÌÆãå¶ù
[¿¼ÑÐ] Ò»Ö¾Ô¸ÖÐÄÏ´óѧ»¯Ñ§0703×Ü·Ö337Çóµ÷¼Á +5 niko- 2026-03-27 5/250 2026-03-28 14:25 by ÌÆãå¶ù
[¿¼ÑÐ] 347Çóµ÷¼Á +3 ɽ¶¥¼û¦Á 2026-03-25 3/150 2026-03-28 14:13 by ÌÆãå¶ù
[¿¼ÑÐ] 317Çóµ÷¼Á +6 Ê®ÏÐwx 2026-03-24 6/300 2026-03-28 13:27 by Iveryant
[¿¼ÑÐ] 0703±¾¿ÆÖ£ÖÝ´óѧÇóµ÷¼Á +3 nhj_ 2026-03-25 3/150 2026-03-28 13:24 by Iveryant
[¿¼ÑÐ] ²ÄÁÏÓ뻯¹¤£¨0856£©304ÇóBÇøµ÷¼Á +8 Çñgl 2026-03-27 8/400 2026-03-28 12:42 by ÌÆãå¶ù
[¿¼ÑÐ] 086502»¯Ñ§¹¤³Ì342Çóµ÷¼Á +6 °¢Ò̸´¹Å²»¹ý 2026-03-27 6/300 2026-03-28 07:06 by wangy0907
[¿¼ÑÐ] 291Çóµ÷¼Á +7 ‹üÈA 2026-03-22 7/350 2026-03-28 04:02 by fmesaito
[¿¼ÑÐ] 265Çóµ÷¼Á +8 Сľ³æ085600 2026-03-27 8/400 2026-03-27 22:16 by Î޼ʵIJÝÔ­
[¿¼ÑÐ] 283Çóµ÷¼Á£¨080500£© +4 A child 2026-03-27 4/200 2026-03-27 15:34 by XPUÀîÇì
[¿¼ÑÐ] ÉúÎïѧ 296 Çóµ÷¼Á +4 ¶ä¶ä- 2026-03-26 6/300 2026-03-26 19:01 by ²»³Ôô~µÄ؈
[¿¼ÑÐ] 085602 289·ÖÇóµ÷¼Á +8 WWWÎ÷Î÷¸¥Ë¹ 2026-03-24 8/400 2026-03-26 16:33 by ²»³Ôô~µÄ؈
[¿¼ÑÐ] 26¿¼ÑÐ-291·Ö-ÏÃÃÅ´óѧ£¨085601£©-ÈáÐÔµç×ÓѧԺ²ÄÁϹ¤³ÌרҵÇóµ÷¼Á +3 min3 2026-03-24 4/200 2026-03-25 18:22 by xcjcqu
[¿¼ÑÐ] ÇóbÇøÔºÐ£µ÷¼Á +4 ÖÜ56 2026-03-24 5/250 2026-03-25 17:12 by yishunmin
[¿¼ÑÐ] 0854AI CV·½ÏòÕÐÊÕµ÷¼Á +4 ÕÂСÓã567 2026-03-23 4/200 2026-03-25 17:04 by CoderLoser
ÐÅÏ¢Ìáʾ
ÇëÌî´¦ÀíÒâ¼û