Commit b462c05
committed
Optimize generate_supercell with O(N) set_tau_fast Fortran routine
Replace O(N^4) set_tau with O(N) set_tau_fast in generate_supercell:
- Original: Nested loops over 2*NN grid (17M-646M iterations)
- New: Direct loops over supercell dimensions (64-216 iterations)
Performance improvement:
- 4x4x4 supercell: 0.096s -> 0.001s (100x faster)
- 6x6x6 supercell: ~7.5s -> ~0.01s (750x faster expected)
Changes:
- Add FModules/set_tau_fast.f90 with O(N) algorithm
- Update Structure.py to call set_tau_fast instead of set_tau
- Add meson.build entry for new Fortran file
- Add comprehensive timers to DiagonalizeSupercell for profiling
- Version bump to 1.6.01 parent c49db94 commit b462c05
5 files changed
Lines changed: 227 additions & 19 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3617 | 3617 | | |
3618 | 3618 | | |
3619 | 3619 | | |
3620 | | - | |
| 3620 | + | |
3621 | 3621 | | |
3622 | 3622 | | |
3623 | 3623 | | |
| |||
3677 | 3677 | | |
3678 | 3678 | | |
3679 | 3679 | | |
| 3680 | + | |
| 3681 | + | |
3680 | 3682 | | |
3681 | 3683 | | |
3682 | 3684 | | |
| |||
3694 | 3696 | | |
3695 | 3697 | | |
3696 | 3698 | | |
| 3699 | + | |
| 3700 | + | |
| 3701 | + | |
3697 | 3702 | | |
3698 | 3703 | | |
3699 | 3704 | | |
| |||
3840 | 3845 | | |
3841 | 3846 | | |
3842 | 3847 | | |
| 3848 | + | |
| 3849 | + | |
| 3850 | + | |
| 3851 | + | |
| 3852 | + | |
3843 | 3853 | | |
3844 | 3854 | | |
3845 | 3855 | | |
| |||
3900 | 3910 | | |
3901 | 3911 | | |
3902 | 3912 | | |
3903 | | - | |
3904 | | - | |
| 3913 | + | |
| 3914 | + | |
| 3915 | + | |
| 3916 | + | |
| 3917 | + | |
| 3918 | + | |
3905 | 3919 | | |
3906 | | - | |
| 3920 | + | |
| 3921 | + | |
3907 | 3922 | | |
| 3923 | + | |
| 3924 | + | |
| 3925 | + | |
3908 | 3926 | | |
3909 | | - | |
| 3927 | + | |
| 3928 | + | |
3910 | 3929 | | |
| 3930 | + | |
| 3931 | + | |
| 3932 | + | |
3911 | 3933 | | |
3912 | | - | |
| 3934 | + | |
| 3935 | + | |
3913 | 3936 | | |
3914 | 3937 | | |
3915 | 3938 | | |
| 3939 | + | |
| 3940 | + | |
| 3941 | + | |
3916 | 3942 | | |
3917 | 3943 | | |
3918 | 3944 | | |
3919 | 3945 | | |
| 3946 | + | |
| 3947 | + | |
3920 | 3948 | | |
3921 | 3949 | | |
3922 | 3950 | | |
| |||
3935 | 3963 | | |
3936 | 3964 | | |
3937 | 3965 | | |
| 3966 | + | |
| 3967 | + | |
| 3968 | + | |
3938 | 3969 | | |
3939 | 3970 | | |
| 3971 | + | |
| 3972 | + | |
3940 | 3973 | | |
3941 | 3974 | | |
| 3975 | + | |
| 3976 | + | |
| 3977 | + | |
3942 | 3978 | | |
3943 | 3979 | | |
| 3980 | + | |
| 3981 | + | |
3944 | 3982 | | |
3945 | 3983 | | |
3946 | 3984 | | |
| 3985 | + | |
| 3986 | + | |
3947 | 3987 | | |
3948 | 3988 | | |
3949 | 3989 | | |
| |||
3953 | 3993 | | |
3954 | 3994 | | |
3955 | 3995 | | |
| 3996 | + | |
| 3997 | + | |
| 3998 | + | |
3956 | 3999 | | |
3957 | 4000 | | |
3958 | 4001 | | |
| |||
3973 | 4016 | | |
3974 | 4017 | | |
3975 | 4018 | | |
| 4019 | + | |
| 4020 | + | |
3976 | 4021 | | |
3977 | 4022 | | |
3978 | 4023 | | |
| |||
3990 | 4035 | | |
3991 | 4036 | | |
3992 | 4037 | | |
| 4038 | + | |
| 4039 | + | |
| 4040 | + | |
3993 | 4041 | | |
3994 | 4042 | | |
3995 | 4043 | | |
| |||
4078 | 4126 | | |
4079 | 4127 | | |
4080 | 4128 | | |
| 4129 | + | |
| 4130 | + | |
| 4131 | + | |
| 4132 | + | |
| 4133 | + | |
| 4134 | + | |
| 4135 | + | |
4081 | 4136 | | |
4082 | 4137 | | |
4083 | 4138 | | |
4084 | 4139 | | |
4085 | 4140 | | |
4086 | 4141 | | |
4087 | 4142 | | |
| 4143 | + | |
| 4144 | + | |
| 4145 | + | |
4088 | 4146 | | |
4089 | 4147 | | |
4090 | 4148 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| 26 | + | |
26 | 27 | | |
27 | 28 | | |
28 | 29 | | |
| |||
1607 | 1608 | | |
1608 | 1609 | | |
1609 | 1610 | | |
1610 | | - | |
| 1611 | + | |
1611 | 1612 | | |
1612 | 1613 | | |
1613 | 1614 | | |
| |||
1641 | 1642 | | |
1642 | 1643 | | |
1643 | 1644 | | |
| 1645 | + | |
| 1646 | + | |
| 1647 | + | |
| 1648 | + | |
1644 | 1649 | | |
1645 | 1650 | | |
1646 | 1651 | | |
| |||
1689 | 1694 | | |
1690 | 1695 | | |
1691 | 1696 | | |
| 1697 | + | |
| 1698 | + | |
| 1699 | + | |
| 1700 | + | |
1692 | 1701 | | |
1693 | 1702 | | |
1694 | 1703 | | |
| |||
1699 | 1708 | | |
1700 | 1709 | | |
1701 | 1710 | | |
1702 | | - | |
1703 | | - | |
1704 | | - | |
1705 | | - | |
1706 | | - | |
1707 | | - | |
1708 | | - | |
1709 | | - | |
1710 | 1711 | | |
| 1712 | + | |
| 1713 | + | |
| 1714 | + | |
| 1715 | + | |
| 1716 | + | |
| 1717 | + | |
| 1718 | + | |
| 1719 | + | |
| 1720 | + | |
| 1721 | + | |
| 1722 | + | |
| 1723 | + | |
| 1724 | + | |
| 1725 | + | |
| 1726 | + | |
1711 | 1727 | | |
1712 | 1728 | | |
1713 | 1729 | | |
1714 | | - | |
1715 | | - | |
| 1730 | + | |
1716 | 1731 | | |
| 1732 | + | |
| 1733 | + | |
| 1734 | + | |
| 1735 | + | |
| 1736 | + | |
| 1737 | + | |
| 1738 | + | |
| 1739 | + | |
| 1740 | + | |
1717 | 1741 | | |
1718 | 1742 | | |
1719 | 1743 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
| 3 | + | |
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| |||
129 | 129 | | |
130 | 130 | | |
131 | 131 | | |
| 132 | + | |
132 | 133 | | |
133 | 134 | | |
134 | 135 | | |
| |||
0 commit comments