Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
A
alpha-mind
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Dr.李
alpha-mind
Commits
585f4004
Commit
585f4004
authored
Mar 06, 2018
by
Dr.李
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
using detail impl
parent
c01d9010
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
17 deletions
+27
-17
crosssetctions.py
alphamind/analysis/crosssetctions.py
+27
-17
No files found.
alphamind/analysis/crosssetctions.py
View file @
585f4004
...
...
@@ -12,19 +12,13 @@ from alphamind.utilities import alpha_logger
from
alphamind.data.processing
import
factor_processing
def
cross_section_analysis
(
ref_date
,
factor_name
,
universe
,
horizon
,
constraint_risk
,
engine
):
codes
=
engine
.
fetch_codes
(
ref_date
,
universe
)
risk_exposure
=
engine
.
fetch_risk_model
(
ref_date
,
codes
)[
1
][[
'code'
]
+
constraint_risk
]
factor_data
=
engine
.
fetch_factor
(
ref_date
,
factor_name
,
codes
)
industry_matrix
=
engine
.
fetch_industry_matrix
(
ref_date
,
codes
,
'sw_adj'
,
1
)
def
cs_impl
(
ref_date
,
factor_data
,
factor_name
,
risk_exposure
,
constraint_risk
,
industry_matrix
,
dx_returns
):
total_data
=
pd
.
merge
(
factor_data
,
risk_exposure
,
on
=
'code'
)
total_data
=
pd
.
merge
(
total_data
,
industry_matrix
,
on
=
'code'
)
.
dropna
()
total_risk_exp
=
total_data
[
constraint_risk
]
...
...
@@ -38,8 +32,6 @@ def cross_section_analysis(ref_date,
'weight'
:
er
,
'industry'
:
industry
})
target_pos
[
'weight'
]
=
target_pos
[
'weight'
]
/
target_pos
[
'weight'
]
.
abs
()
.
sum
()
dx_returns
=
engine
.
fetch_dx_return
(
ref_date
,
codes
,
horizon
=
horizon
,
offset
=
1
)
target_pos
=
pd
.
merge
(
target_pos
,
dx_returns
,
on
=
[
'code'
])
target_pos
=
pd
.
merge
(
target_pos
,
total_data
[[
'code'
]
+
constraint_risk
],
on
=
[
'code'
])
activate_weight
=
target_pos
.
weight
.
values
...
...
@@ -55,6 +47,23 @@ def cross_section_analysis(ref_date,
return
port_ret
,
ic
,
t_stats
def
cross_section_analysis
(
ref_date
,
factor_name
,
universe
,
horizon
,
constraint_risk
,
engine
):
codes
=
engine
.
fetch_codes
(
ref_date
,
universe
)
risk_exposure
=
engine
.
fetch_risk_model
(
ref_date
,
codes
)[
1
][[
'code'
]
+
constraint_risk
]
factor_data
=
engine
.
fetch_factor
(
ref_date
,
factor_name
,
codes
)
industry_matrix
=
engine
.
fetch_industry_matrix
(
ref_date
,
codes
,
'sw_adj'
,
1
)
dx_returns
=
engine
.
fetch_dx_return
(
ref_date
,
codes
,
horizon
=
horizon
,
offset
=
1
)
return
cs_impl
(
ref_date
,
factor_data
,
factor_name
,
risk_exposure
,
constraint_risk
,
industry_matrix
,
dx_returns
)
if
__name__
==
'__main__'
:
import
numpy
as
np
import
pandas
as
pd
...
...
@@ -70,9 +79,10 @@ if __name__ == '__main__':
universe
=
Universe
(
'custom'
,
[
'ashare_ex'
])
horizon
=
9
cross_section_analysis
(
'2018-02-08'
,
x
=
cross_section_analysis
(
'2018-02-08'
,
factor_name
,
universe
,
horizon
,
constraint_risk
,
engine
=
engine
)
\ No newline at end of file
engine
=
engine
)
print
(
x
)
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment