aigroup-econ-mcp 1.3.3__py3-none-any.whl → 1.4.3__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- .gitignore +253 -0
- PKG-INFO +710 -0
- README.md +672 -0
- __init__.py +14 -0
- aigroup_econ_mcp-1.4.3.dist-info/METADATA +710 -0
- aigroup_econ_mcp-1.4.3.dist-info/RECORD +92 -0
- aigroup_econ_mcp-1.4.3.dist-info/entry_points.txt +2 -0
- aigroup_econ_mcp-1.4.3.dist-info/licenses/LICENSE +21 -0
- cli.py +28 -0
- econometrics/README.md +18 -0
- econometrics/__init__.py +191 -0
- econometrics/advanced_methods/modern_computing_machine_learning/__init__.py +0 -0
- econometrics/basic_parametric_estimation/__init__.py +31 -0
- econometrics/basic_parametric_estimation/gmm/__init__.py +13 -0
- econometrics/basic_parametric_estimation/gmm/gmm_model.py +256 -0
- econometrics/basic_parametric_estimation/mle/__init__.py +13 -0
- econometrics/basic_parametric_estimation/mle/mle_model.py +241 -0
- econometrics/basic_parametric_estimation/ols/__init__.py +13 -0
- econometrics/basic_parametric_estimation/ols/ols_model.py +141 -0
- econometrics/causal_inference/causal_identification_strategy/__init__.py +0 -0
- econometrics/missing_data/missing_data_measurement_error/__init__.py +0 -0
- econometrics/model_specification_diagnostics_robust_inference/README.md +173 -0
- econometrics/model_specification_diagnostics_robust_inference/__init__.py +78 -0
- econometrics/model_specification_diagnostics_robust_inference/diagnostic_tests/__init__.py +20 -0
- econometrics/model_specification_diagnostics_robust_inference/diagnostic_tests/diagnostic_tests_model.py +149 -0
- econometrics/model_specification_diagnostics_robust_inference/generalized_least_squares/__init__.py +15 -0
- econometrics/model_specification_diagnostics_robust_inference/generalized_least_squares/gls_model.py +130 -0
- econometrics/model_specification_diagnostics_robust_inference/model_selection/__init__.py +18 -0
- econometrics/model_specification_diagnostics_robust_inference/model_selection/model_selection_model.py +286 -0
- econometrics/model_specification_diagnostics_robust_inference/regularization/__init__.py +15 -0
- econometrics/model_specification_diagnostics_robust_inference/regularization/regularization_model.py +177 -0
- econometrics/model_specification_diagnostics_robust_inference/robust_errors/__init__.py +15 -0
- econometrics/model_specification_diagnostics_robust_inference/robust_errors/robust_errors_model.py +122 -0
- econometrics/model_specification_diagnostics_robust_inference/simultaneous_equations/__init__.py +15 -0
- econometrics/model_specification_diagnostics_robust_inference/simultaneous_equations/simultaneous_equations_model.py +246 -0
- econometrics/model_specification_diagnostics_robust_inference/weighted_least_squares/__init__.py +15 -0
- econometrics/model_specification_diagnostics_robust_inference/weighted_least_squares/wls_model.py +127 -0
- econometrics/nonparametric/nonparametric_semiparametric_methods/__init__.py +0 -0
- econometrics/spatial_econometrics/spatial_econometrics_new/__init__.py +0 -0
- econometrics/specific_data_modeling/micro_discrete_limited_data/__init__.py +0 -0
- econometrics/specific_data_modeling/survival_duration_data/__init__.py +0 -0
- econometrics/specific_data_modeling/time_series_panel_data/__init__.py +143 -0
- econometrics/specific_data_modeling/time_series_panel_data/arima_model.py +104 -0
- econometrics/specific_data_modeling/time_series_panel_data/cointegration_vecm.py +334 -0
- econometrics/specific_data_modeling/time_series_panel_data/dynamic_panel_models.py +653 -0
- econometrics/specific_data_modeling/time_series_panel_data/exponential_smoothing.py +176 -0
- econometrics/specific_data_modeling/time_series_panel_data/garch_model.py +198 -0
- econometrics/specific_data_modeling/time_series_panel_data/panel_diagnostics.py +125 -0
- econometrics/specific_data_modeling/time_series_panel_data/panel_var.py +60 -0
- econometrics/specific_data_modeling/time_series_panel_data/structural_break_tests.py +87 -0
- econometrics/specific_data_modeling/time_series_panel_data/time_varying_parameter_models.py +106 -0
- econometrics/specific_data_modeling/time_series_panel_data/unit_root_tests.py +204 -0
- econometrics/specific_data_modeling/time_series_panel_data/var_svar_model.py +372 -0
- econometrics/statistical_inference/statistical_inference_techniques/__init__.py +0 -0
- econometrics/statistics/distribution_decomposition_methods/__init__.py +0 -0
- econometrics/tests/basic_parametric_estimation_tests/__init__.py +3 -0
- econometrics/tests/basic_parametric_estimation_tests/test_gmm.py +128 -0
- econometrics/tests/basic_parametric_estimation_tests/test_mle.py +127 -0
- econometrics/tests/basic_parametric_estimation_tests/test_ols.py +100 -0
- econometrics/tests/model_specification_diagnostics_tests/__init__.py +3 -0
- econometrics/tests/model_specification_diagnostics_tests/test_diagnostic_tests.py +86 -0
- econometrics/tests/model_specification_diagnostics_tests/test_robust_errors.py +89 -0
- econometrics/tests/specific_data_modeling_tests/__init__.py +3 -0
- econometrics/tests/specific_data_modeling_tests/test_arima.py +98 -0
- econometrics/tests/specific_data_modeling_tests/test_dynamic_panel.py +198 -0
- econometrics/tests/specific_data_modeling_tests/test_exponential_smoothing.py +105 -0
- econometrics/tests/specific_data_modeling_tests/test_garch.py +118 -0
- econometrics/tests/specific_data_modeling_tests/test_unit_root.py +156 -0
- econometrics/tests/specific_data_modeling_tests/test_var.py +124 -0
- prompts/__init__.py +0 -0
- prompts/analysis_guides.py +43 -0
- pyproject.toml +78 -0
- resources/MCP_MASTER_GUIDE.md +422 -0
- resources/MCP_TOOLS_DATA_FORMAT_GUIDE.md +185 -0
- resources/__init__.py +0 -0
- server.py +83 -0
- tools/README.md +88 -0
- tools/__init__.py +45 -0
- tools/data_loader.py +213 -0
- tools/decorators.py +38 -0
- tools/econometrics_adapter.py +286 -0
- tools/mcp_tool_groups/__init__.py +1 -0
- tools/mcp_tool_groups/basic_parametric_tools.py +173 -0
- tools/mcp_tool_groups/model_specification_tools.py +402 -0
- tools/mcp_tool_groups/time_series_tools.py +494 -0
- tools/mcp_tools_registry.py +114 -0
- tools/model_specification_adapter.py +369 -0
- tools/output_formatter.py +563 -0
- tools/time_series_panel_data_adapter.py +858 -0
- tools/time_series_panel_data_tools.py +65 -0
- aigroup_econ_mcp/__init__.py +0 -19
- aigroup_econ_mcp/cli.py +0 -82
- aigroup_econ_mcp/config.py +0 -561
- aigroup_econ_mcp/server.py +0 -452
- aigroup_econ_mcp/tools/__init__.py +0 -19
- aigroup_econ_mcp/tools/base.py +0 -470
- aigroup_econ_mcp/tools/cache.py +0 -533
- aigroup_econ_mcp/tools/data_loader.py +0 -195
- aigroup_econ_mcp/tools/file_parser.py +0 -1027
- aigroup_econ_mcp/tools/machine_learning.py +0 -60
- aigroup_econ_mcp/tools/ml_ensemble.py +0 -210
- aigroup_econ_mcp/tools/ml_evaluation.py +0 -272
- aigroup_econ_mcp/tools/ml_models.py +0 -54
- aigroup_econ_mcp/tools/ml_regularization.py +0 -186
- aigroup_econ_mcp/tools/monitoring.py +0 -555
- aigroup_econ_mcp/tools/optimized_example.py +0 -229
- aigroup_econ_mcp/tools/panel_data.py +0 -619
- aigroup_econ_mcp/tools/regression.py +0 -214
- aigroup_econ_mcp/tools/statistics.py +0 -154
- aigroup_econ_mcp/tools/time_series.py +0 -698
- aigroup_econ_mcp/tools/timeout.py +0 -283
- aigroup_econ_mcp/tools/tool_descriptions.py +0 -410
- aigroup_econ_mcp/tools/tool_handlers.py +0 -1016
- aigroup_econ_mcp/tools/tool_registry.py +0 -478
- aigroup_econ_mcp/tools/validation.py +0 -482
- aigroup_econ_mcp-1.3.3.dist-info/METADATA +0 -525
- aigroup_econ_mcp-1.3.3.dist-info/RECORD +0 -30
- aigroup_econ_mcp-1.3.3.dist-info/entry_points.txt +0 -2
- /aigroup_econ_mcp-1.3.3.dist-info/licenses/LICENSE → /LICENSE +0 -0
- {aigroup_econ_mcp-1.3.3.dist-info → aigroup_econ_mcp-1.4.3.dist-info}/WHEEL +0 -0
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
数据加载辅助模块
|
|
3
|
-
提供通用的文件加载功能,支持CSV、JSON和TXT格式
|
|
4
|
-
"""
|
|
5
|
-
|
|
6
|
-
from typing import Dict, List, Union
|
|
7
|
-
from pathlib import Path
|
|
8
|
-
import pandas as pd
|
|
9
|
-
from .file_parser import FileParser
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
async def load_data_if_path(
|
|
13
|
-
data: Union[Dict[str, List[float]], str],
|
|
14
|
-
ctx = None
|
|
15
|
-
) -> Dict[str, List[float]]:
|
|
16
|
-
"""
|
|
17
|
-
智能加载数据:如果是字符串则作为文件路径加载,否则直接返回
|
|
18
|
-
|
|
19
|
-
Args:
|
|
20
|
-
data: 数据字典或文件路径(支持CSV/JSON/TXT)
|
|
21
|
-
ctx: MCP上下文对象(可选,用于日志)
|
|
22
|
-
|
|
23
|
-
Returns:
|
|
24
|
-
数据字典
|
|
25
|
-
|
|
26
|
-
Raises:
|
|
27
|
-
ValueError: 文件不存在或读取失败
|
|
28
|
-
"""
|
|
29
|
-
# 如果已经是字典,直接返回
|
|
30
|
-
if isinstance(data, dict):
|
|
31
|
-
return data
|
|
32
|
-
|
|
33
|
-
# 如果是字符串,作为文件路径处理
|
|
34
|
-
if isinstance(data, str):
|
|
35
|
-
if ctx:
|
|
36
|
-
await ctx.info(f"📁 检测到文件路径,正在加载: {data}")
|
|
37
|
-
|
|
38
|
-
try:
|
|
39
|
-
# 检查文件是否存在
|
|
40
|
-
path = Path(data)
|
|
41
|
-
if not path.exists():
|
|
42
|
-
raise ValueError(f"文件不存在: {data}")
|
|
43
|
-
|
|
44
|
-
# 使用FileParser解析文件(支持CSV/JSON/TXT自动检测)
|
|
45
|
-
parsed = FileParser.parse_file_path(str(path), "auto")
|
|
46
|
-
|
|
47
|
-
# 返回数据字典
|
|
48
|
-
result = parsed["data"]
|
|
49
|
-
|
|
50
|
-
if ctx:
|
|
51
|
-
await ctx.info(
|
|
52
|
-
f"✅ {parsed['format'].upper()}文件加载成功:"
|
|
53
|
-
f"{parsed['n_variables']}个变量,{parsed['n_observations']}个观测"
|
|
54
|
-
)
|
|
55
|
-
|
|
56
|
-
return result
|
|
57
|
-
|
|
58
|
-
except FileNotFoundError:
|
|
59
|
-
raise ValueError(f"文件不存在: {data}")
|
|
60
|
-
except Exception as e:
|
|
61
|
-
raise ValueError(f"文件读取失败: {str(e)}")
|
|
62
|
-
|
|
63
|
-
# 其他类型报错
|
|
64
|
-
raise TypeError(f"不支持的数据类型: {type(data)},期望Dict或str")
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
async def load_single_var_if_path(
|
|
68
|
-
data: Union[List[float], str],
|
|
69
|
-
ctx = None,
|
|
70
|
-
column_name: str = None
|
|
71
|
-
) -> List[float]:
|
|
72
|
-
"""
|
|
73
|
-
智能加载单变量数据:如果是字符串则作为文件路径加载,否则直接返回
|
|
74
|
-
|
|
75
|
-
Args:
|
|
76
|
-
data: 数据列表或文件路径(支持CSV/JSON/TXT)
|
|
77
|
-
ctx: MCP上下文对象(可选,用于日志)
|
|
78
|
-
column_name: 文件中要读取的列名(可选,默认读取第一列)
|
|
79
|
-
|
|
80
|
-
Returns:
|
|
81
|
-
数据列表
|
|
82
|
-
|
|
83
|
-
Raises:
|
|
84
|
-
ValueError: 文件不存在或读取失败
|
|
85
|
-
"""
|
|
86
|
-
# 如果已经是列表,直接返回
|
|
87
|
-
if isinstance(data, list):
|
|
88
|
-
return data
|
|
89
|
-
|
|
90
|
-
# 如果是字符串,作为文件路径处理
|
|
91
|
-
if isinstance(data, str):
|
|
92
|
-
if ctx:
|
|
93
|
-
await ctx.info(f"📁 检测到文件路径,正在加载: {data}")
|
|
94
|
-
|
|
95
|
-
try:
|
|
96
|
-
# 检查文件是否存在
|
|
97
|
-
path = Path(data)
|
|
98
|
-
if not path.exists():
|
|
99
|
-
raise ValueError(f"文件不存在: {data}")
|
|
100
|
-
|
|
101
|
-
# 使用FileParser解析文件
|
|
102
|
-
parsed = FileParser.parse_file_path(str(path), "auto")
|
|
103
|
-
data_dict = parsed["data"]
|
|
104
|
-
|
|
105
|
-
# 确定要读取的列
|
|
106
|
-
if column_name:
|
|
107
|
-
if column_name not in data_dict:
|
|
108
|
-
raise ValueError(
|
|
109
|
-
f"列'{column_name}'不存在于文件中。"
|
|
110
|
-
f"可用列: {list(data_dict.keys())}"
|
|
111
|
-
)
|
|
112
|
-
result = data_dict[column_name]
|
|
113
|
-
else:
|
|
114
|
-
# 默认读取第一列
|
|
115
|
-
first_col = parsed["variables"][0]
|
|
116
|
-
result = data_dict[first_col]
|
|
117
|
-
if ctx:
|
|
118
|
-
await ctx.info(f"未指定列名,使用第一列: {first_col}")
|
|
119
|
-
|
|
120
|
-
if ctx:
|
|
121
|
-
await ctx.info(
|
|
122
|
-
f"✅ {parsed['format'].upper()}文件加载成功:{len(result)}个观测"
|
|
123
|
-
)
|
|
124
|
-
|
|
125
|
-
return result
|
|
126
|
-
|
|
127
|
-
except FileNotFoundError:
|
|
128
|
-
raise ValueError(f"文件不存在: {data}")
|
|
129
|
-
except Exception as e:
|
|
130
|
-
raise ValueError(f"文件读取失败: {str(e)}")
|
|
131
|
-
|
|
132
|
-
# 其他类型报错
|
|
133
|
-
raise TypeError(f"不支持的数据类型: {type(data)},期望List或str")
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
async def load_x_data_if_path(
|
|
137
|
-
data: Union[List[List[float]], str],
|
|
138
|
-
ctx = None
|
|
139
|
-
) -> List[List[float]]:
|
|
140
|
-
"""
|
|
141
|
-
智能加载自变量数据:如果是字符串则作为文件路径加载,否则直接返回
|
|
142
|
-
|
|
143
|
-
Args:
|
|
144
|
-
data: 自变量数据(二维列表)或文件路径(支持CSV/JSON/TXT)
|
|
145
|
-
ctx: MCP上下文对象(可选,用于日志)
|
|
146
|
-
|
|
147
|
-
Returns:
|
|
148
|
-
自变量数据(二维列表)
|
|
149
|
-
|
|
150
|
-
Raises:
|
|
151
|
-
ValueError: 文件不存在或读取失败
|
|
152
|
-
"""
|
|
153
|
-
# 如果已经是二维列表,直接返回
|
|
154
|
-
if isinstance(data, list) and all(isinstance(item, list) for item in data):
|
|
155
|
-
return data
|
|
156
|
-
|
|
157
|
-
# 如果是字符串,作为文件路径处理
|
|
158
|
-
if isinstance(data, str):
|
|
159
|
-
if ctx:
|
|
160
|
-
await ctx.info(f"📁 检测到自变量文件路径,正在加载: {data}")
|
|
161
|
-
|
|
162
|
-
try:
|
|
163
|
-
# 检查文件是否存在
|
|
164
|
-
path = Path(data)
|
|
165
|
-
if not path.exists():
|
|
166
|
-
raise ValueError(f"文件不存在: {data}")
|
|
167
|
-
|
|
168
|
-
# 使用FileParser解析文件
|
|
169
|
-
parsed = FileParser.parse_file_path(str(path), "auto")
|
|
170
|
-
data_dict = parsed["data"]
|
|
171
|
-
|
|
172
|
-
# 转换为二维列表格式
|
|
173
|
-
variables = parsed["variables"]
|
|
174
|
-
n_obs = parsed["n_observations"]
|
|
175
|
-
|
|
176
|
-
result = []
|
|
177
|
-
for i in range(n_obs):
|
|
178
|
-
row = [data_dict[var][i] for var in variables]
|
|
179
|
-
result.append(row)
|
|
180
|
-
|
|
181
|
-
if ctx:
|
|
182
|
-
await ctx.info(
|
|
183
|
-
f"✅ 自变量{parsed['format'].upper()}文件加载成功:"
|
|
184
|
-
f"{len(result)}个观测,{len(variables)}个自变量"
|
|
185
|
-
)
|
|
186
|
-
|
|
187
|
-
return result
|
|
188
|
-
|
|
189
|
-
except FileNotFoundError:
|
|
190
|
-
raise ValueError(f"文件不存在: {data}")
|
|
191
|
-
except Exception as e:
|
|
192
|
-
raise ValueError(f"自变量文件读取失败: {str(e)}")
|
|
193
|
-
|
|
194
|
-
# 其他类型报错
|
|
195
|
-
raise TypeError(f"不支持的数据类型: {type(data)},期望List[List[float]]或str")
|