-
Notifications
You must be signed in to change notification settings - Fork 108
/
Copy pathprimarydirections.py
51 lines (38 loc) · 1.48 KB
/
primarydirections.py
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
"""
Author: João Ventura <flatangleweb@gmail.com>
This recipe shows sample code for handling the
primary directions.
"""
from flatlib import const
from flatlib.chart import Chart
from flatlib.datetime import Datetime
from flatlib.geopos import GeoPos
from flatlib.predictives import primarydirections
# Build a chart for a date and location
date = Datetime('2015/03/13', '17:00', '+00:00')
pos = GeoPos('38n32', '8w54')
chart = Chart(date, pos)
# MC will be used for calculating arcs
mc = chart.get(const.MC)
# Get a promissor and significator
prom = chart.get(const.MARS)
sig = chart.get(const.MERCURY)
# Compute arc in zodiaco (zerolat = True)
arc = primarydirections.getArc(prom, sig, mc, pos, zerolat=True)
print(arc) # 56.17347
# Compute arc in mundo
arc = primarydirections.getArc(prom, sig, mc, pos, zerolat=False)
print(arc) # 56.74266
# Create Primary Directions class
from flatlib.predictives.primarydirections import PrimaryDirections
pd = PrimaryDirections(chart)
# Get arcs
arc = pd.getArc(pd.N(const.MARS), pd.N(const.MERCURY))
print(arc['arcm']) # 56.74266 (arc in-mundo)
print(arc['arcz']) # 56.17347 (arc in-zodiaco)
# Create Primary Directions table class
from flatlib.predictives.primarydirections import PDTable
pd = PDTable(chart, const.MAJOR_ASPECTS)
pd.byPromissor(const.MARS) # List all directions by promissor
pd.bySignificator(const.MERCURY) # List all directions by significator
pd.view(20, 30) # List all directions between 20 and 30 of arc