带有 Lahiri Ayanamsha 的瑞士星历恒星模式给出了错误的值

noo*_*ama 3 c# pyephem

我正在尝试生成行星的经度。我使用瑞士星历 dll 来完成我所有的艰苦工作。然而,不幸的是,瑞士星历为恒星模式 Lahiri Ayanamsha 生成的值与我从其他吠陀软件或包括JuniorJyothsh在内的在线门户网站获得的值相去甚远(大约 25 分钟,尤其是月亮)

我已经下载了 .se1 文件(针对行星和月球),并且正在使用非常准确的瑞士星历模式。此外,我还设置了恒星模式、Lahiri Ayanmsha Flag、Topocentric Flag。我还设置了拓扑纬度和经度位置。

最让我困扰的是,包括 Jumior Jyothish 在内的所有其他在线吠陀本命图生成器的值似乎彼此匹配。我不确定我做错了什么。这是我的代码Swiss ephemeris 在 git 上的 .NET 中使用的链接,其中包含示例代码片段

[Test]
    public void ShouldGetAllPlanetValues()
    {
        var errorMessage = new StringBuilder(1000);
        var longitudeAndLatitude = new Double[6];
        var cusps = new Double[13];
        var ascentantAndMore = new Double[10];
        var julianDayNumbersInEtAndUt = new double[2];
        TimeZoneInfo indiaTimeZone = TimeZoneInfo.FindSystemTimeZoneById(IndiaStandardTimeZoneId);
        var ephemerisTablesPath = new StringBuilder(@"../../../EphemerisFiles/");

        swe_set_ephe_path(ephemerisTablesPath);
        var birthTimeInIndianZone = new DateTime(1989, 8, 21, 10, 29, 0);
        DateTime birthTimeInUtc = TimeZoneInfo.ConvertTimeToUtc(birthTimeInIndianZone, indiaTimeZone);

        int errorCOde = swe_utc_to_jd(birthTimeInUtc.Year, birthTimeInUtc.Month, birthTimeInUtc.Day,
                                      birthTimeInUtc.Hour, birthTimeInUtc.Minute, birthTimeInUtc.Second, 1,
                                      julianDayNumbersInEtAndUt, errorMessage);
        if (errorCOde != 0)
        {
            Assert.Fail("Error ho gaya julian date conversion par !!");
        }
        Console.WriteLine("Julian Day Number from UTC: " + julianDayNumbersInEtAndUt[1]);
        Console.WriteLine(swe_sidtime(julianDayNumbersInEtAndUt[1]));
        var computationFlag = EphemerisModes.Sidereal | EphemerisModes.SwissEphemeris
                                                                        | EphemerisModes.Topocentric;
        var longitude = ConvertDegreeAngleToDouble(80, 15, 0);
        var latitude = ConvertDegreeAngleToDouble(13, 4, 0);
        swe_set_topo(12.9667, 77.5667, 0);
        swe_set_sid_mode(SiderealFlag.Lahiri, 0, 0);
        foreach (var planet in Planets.AllPlanets)
        {
            int sweCalcUt = swe_calc_ut(julianDayNumbersInEtAndUt[1], planet, computationFlag, longitudeAndLatitude, errorMessage);
            Console.WriteLine("Planet Number " + planet + ": " + GetDegreesMinutesSeconds(longitudeAndLatitude[0]));
        }
        swe_houses_ex(julianDayNumbersInEtAndUt[1], EphemerisModes.Sidereal, 12.9667, 77.5667, 'A', cusps, ascentantAndMore);
        Console.WriteLine("Ascendant: " + GetDegreesMinutesSeconds(ascentantAndMore[0]));
    }
Run Code Online (Sandbox Code Playgroud)

以下是我自己的出生日期(1989 年 8 月 21 日上午 10:29)的值有多么不同的示例,根据我的代码从瑞士星历生成:

Planet Number 0: 124:24:30   SUN
Planet Number 1: 359:38:55   Moon
Planet Number 2: 150:20:40   Mercury
Planet Number 3: 160:0:11    Venus
Planet Number 4: 137:26:47   Mars
Planet Number 5: 70:20:45    Jupiter
Planet Number 6: 253:56:35   Satrun
Planet Number 10: 301:46:40  Rahu (Mean Node)
Ascendant:        187.27:46
Run Code Online (Sandbox Code Playgroud)

大多数其他来源的价值(JuniorJyothishProKeralaNadiAstrologyAstrosage):

Planet Number  0: 124:24:35    SUN
Planet Number  1: 0:6:21       Moon
Planet Number  2: 150:20:45    Mercury
Planet Number  3: 160:00:17    Venus
Planet Number  4: 137:26:56    Mars
Planet Number  5: 70:20:57     Jupiter
Planet Number  6: 253:56:48    Satrun
Planet Number 10: 301:46:52    Rahu
Ascendant       : 187:28:6     Ascendant   
Run Code Online (Sandbox Code Playgroud)

非常感谢任何帮助/提示/建议为我指明正确的方向。

谢谢

noo*_*ama 5

经过几个小时的谷歌搜索和绞尽脑汁后,我发现吠陀星座传统上使用地心值。我使用地心值作为月球的经度。这对于其他行星来说并没有太大区别,因为它们与地球的距离与月球不同。一旦我生成了地心值,月球经度也匹配了。

尽管当有更准确的地心值可用时,吠陀占星术使用地心经度似乎是错误的,但占星术传统上就是这样工作的。此外,占星规则的建立是为了用错误的数据给出正确的预测:P