voly 0.0.141__tar.gz → 0.0.142__tar.gz
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.
- {voly-0.0.141/src/voly.egg-info → voly-0.0.142}/PKG-INFO +1 -1
- {voly-0.0.141 → voly-0.0.142}/pyproject.toml +2 -2
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/rnd.py +56 -43
- {voly-0.0.141 → voly-0.0.142/src/voly.egg-info}/PKG-INFO +1 -1
- {voly-0.0.141 → voly-0.0.142}/LICENSE +0 -0
- {voly-0.0.141 → voly-0.0.142}/README.md +0 -0
- {voly-0.0.141 → voly-0.0.142}/setup.cfg +0 -0
- {voly-0.0.141 → voly-0.0.142}/setup.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/__init__.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/client.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/__init__.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/charts.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/data.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/fit.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/hd.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/core/interpolate.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/exceptions.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/formulas.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/models.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/utils/__init__.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly/utils/logger.py +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly.egg-info/SOURCES.txt +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly.egg-info/dependency_links.txt +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly.egg-info/requires.txt +0 -0
- {voly-0.0.141 → voly-0.0.142}/src/voly.egg-info/top_level.txt +0 -0
| @@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta" | |
| 4 4 |  | 
| 5 5 | 
             
            [project]
         | 
| 6 6 | 
             
            name = "voly"
         | 
| 7 | 
            -
            version = "0.0. | 
| 7 | 
            +
            version = "0.0.142"
         | 
| 8 8 | 
             
            description = "Options & volatility research package"
         | 
| 9 9 | 
             
            readme = "README.md"
         | 
| 10 10 | 
             
            authors = [
         | 
| @@ -60,7 +60,7 @@ line_length = 100 | |
| 60 60 | 
             
            multi_line_output = 3
         | 
| 61 61 |  | 
| 62 62 | 
             
            [tool.mypy]
         | 
| 63 | 
            -
            python_version = "0.0. | 
| 63 | 
            +
            python_version = "0.0.142"
         | 
| 64 64 | 
             
            warn_return_any = true
         | 
| 65 65 | 
             
            warn_unused_configs = true
         | 
| 66 66 | 
             
            disallow_untyped_defs = true
         | 
| @@ -221,54 +221,48 @@ def get_all_moments(x, pdf, model_params=None): | |
| 221 221 | 
             
                return moments
         | 
| 222 222 | 
             
            '''
         | 
| 223 223 |  | 
| 224 | 
            +
             | 
| 224 225 | 
             
            @catch_exception
         | 
| 225 226 | 
             
            def get_all_moments(x, pdf, model_params=None):
         | 
| 226 227 | 
             
                # Precompute dx for integration
         | 
| 227 228 | 
             
                dx = np.diff(x, prepend=x[0])
         | 
| 228 229 |  | 
| 229 230 | 
             
                # Raw Moments (μ_k = E[X^k])
         | 
| 230 | 
            -
                 | 
| 231 | 
            -
             | 
| 232 | 
            -
             | 
| 233 | 
            -
             | 
| 234 | 
            -
             | 
| 235 | 
            -
             | 
| 236 | 
            -
             | 
| 237 | 
            -
             | 
| 238 | 
            -
                 | 
| 239 | 
            -
             | 
| 240 | 
            -
                mean = raw_moments['raw_1']
         | 
| 231 | 
            +
                raw_0 = np.trapz(pdf, x)           # Zeroth (~1)
         | 
| 232 | 
            +
                raw_1 = np.trapz(x * pdf, x)       # First (mean)
         | 
| 233 | 
            +
                raw_2 = np.trapz(x**2 * pdf, x)    # Second
         | 
| 234 | 
            +
                raw_3 = np.trapz(x**3 * pdf, x)    # Third
         | 
| 235 | 
            +
                raw_4 = np.trapz(x**4 * pdf, x)    # Fourth
         | 
| 236 | 
            +
                raw_5 = np.trapz(x**5 * pdf, x)    # Fifth
         | 
| 237 | 
            +
                raw_6 = np.trapz(x**6 * pdf, x)    # Sixth
         | 
| 238 | 
            +
             | 
| 239 | 
            +
                mean = raw_1
         | 
| 241 240 | 
             
                variance = np.trapz((x - mean)**2 * pdf, x)  # m_2
         | 
| 242 241 | 
             
                std_dev = np.sqrt(variance)
         | 
| 243 242 |  | 
| 244 243 | 
             
                # Central Moments (m_k = E[(X - μ)^k])
         | 
| 245 | 
            -
                 | 
| 246 | 
            -
             | 
| 247 | 
            -
             | 
| 248 | 
            -
             | 
| 249 | 
            -
             | 
| 250 | 
            -
             | 
| 251 | 
            -
             | 
| 252 | 
            -
                    'cent_6': np.trapz((x - mean)**6 * pdf, x),  # Sixth
         | 
| 253 | 
            -
                }
         | 
| 244 | 
            +
                cent_0 = raw_0                     # Zeroth (~1)
         | 
| 245 | 
            +
                cent_1 = np.trapz((x - mean) * pdf, x)  # First (~0)
         | 
| 246 | 
            +
                cent_2 = variance                  # Second (variance)
         | 
| 247 | 
            +
                cent_3 = np.trapz((x - mean)**3 * pdf, x)  # Third
         | 
| 248 | 
            +
                cent_4 = np.trapz((x - mean)**4 * pdf, x)  # Fourth
         | 
| 249 | 
            +
                cent_5 = np.trapz((x - mean)**5 * pdf, x)  # Fifth
         | 
| 250 | 
            +
                cent_6 = np.trapz((x - mean)**6 * pdf, x)  # Sixth
         | 
| 254 251 |  | 
| 255 252 | 
             
                # Standardized Moments (m̄_k = E[((X - μ)/σ)^k])
         | 
| 256 253 | 
             
                z = (x - mean) / std_dev
         | 
| 257 | 
            -
                 | 
| 258 | 
            -
             | 
| 259 | 
            -
             | 
| 260 | 
            -
             | 
| 261 | 
            -
             | 
| 262 | 
            -
             | 
| 263 | 
            -
             | 
| 264 | 
            -
                    'std_6': np.trapz(z**6 * pdf, x),    # Sixth
         | 
| 265 | 
            -
                }
         | 
| 254 | 
            +
                std_0 = np.trapz(pdf, x)           # Zeroth (~1)
         | 
| 255 | 
            +
                std_1 = np.trapz(z * pdf, x)       # First (~0)
         | 
| 256 | 
            +
                std_2 = np.trapz(z**2 * pdf, x)    # Second (~1)
         | 
| 257 | 
            +
                std_3 = np.trapz(z**3 * pdf, x)    # Skewness
         | 
| 258 | 
            +
                std_4 = np.trapz(z**4 * pdf, x)    # Kurtosis
         | 
| 259 | 
            +
                std_5 = np.trapz(z**5 * pdf, x)    # Fifth
         | 
| 260 | 
            +
                std_6 = np.trapz(z**6 * pdf, x)    # Sixth
         | 
| 266 261 |  | 
| 267 262 | 
             
                # Extra statistics
         | 
| 268 263 | 
             
                cdf = np.cumsum(pdf * dx)
         | 
| 269 264 | 
             
                median = x[np.searchsorted(cdf, 0.5)]  # Median
         | 
| 270 | 
            -
                 | 
| 271 | 
            -
                excess_kurtosis = standardized_moments['std_4'] - 3
         | 
| 265 | 
            +
                excess_kurtosis = std_4 - 3
         | 
| 272 266 | 
             
                q25 = x[np.searchsorted(cdf, 0.25)]    # 25th percentile
         | 
| 273 267 | 
             
                q75 = x[np.searchsorted(cdf, 0.75)]    # 75th percentile
         | 
| 274 268 | 
             
                iqr = q75 - q25
         | 
| @@ -284,25 +278,44 @@ def get_all_moments(x, pdf, model_params=None): | |
| 284 278 | 
             
                o3n = np.sum(pdf[(z <= -2) & (z > -3)] * dx[(z <= -2) & (z > -3)])
         | 
| 285 279 | 
             
                o4n = np.sum(pdf[z <= -3] * dx[z <= -3])
         | 
| 286 280 |  | 
| 287 | 
            -
                # Combine results
         | 
| 281 | 
            +
                # Combine results as flat columns
         | 
| 288 282 | 
             
                moments = {
         | 
| 289 | 
            -
                    ' | 
| 290 | 
            -
                    ' | 
| 291 | 
            -
                    ' | 
| 292 | 
            -
                    ' | 
| 293 | 
            -
                    ' | 
| 294 | 
            -
                    ' | 
| 283 | 
            +
                    'raw_0': raw_0,
         | 
| 284 | 
            +
                    'raw_1': raw_1,
         | 
| 285 | 
            +
                    'raw_2': raw_2,
         | 
| 286 | 
            +
                    'raw_3': raw_3,
         | 
| 287 | 
            +
                    'raw_4': raw_4,
         | 
| 288 | 
            +
                    'raw_5': raw_5,
         | 
| 289 | 
            +
                    'raw_6': raw_6,
         | 
| 290 | 
            +
                    'cent_0': cent_0,
         | 
| 291 | 
            +
                    'cent_1': cent_1,
         | 
| 292 | 
            +
                    'cent_2': cent_2,
         | 
| 293 | 
            +
                    'cent_3': cent_3,
         | 
| 294 | 
            +
                    'cent_4': cent_4,
         | 
| 295 | 
            +
                    'cent_5': cent_5,
         | 
| 296 | 
            +
                    'cent_6': cent_6,
         | 
| 297 | 
            +
                    'std_0': std_0,
         | 
| 298 | 
            +
                    'std_1': std_1,
         | 
| 299 | 
            +
                    'std_2': std_2,
         | 
| 300 | 
            +
                    'std_3': std_3,
         | 
| 301 | 
            +
                    'std_4': std_4,
         | 
| 302 | 
            +
                    'std_5': std_5,
         | 
| 303 | 
            +
                    'std_6': std_6,
         | 
| 295 304 | 
             
                    'median': median,
         | 
| 296 | 
            -
                    ' | 
| 305 | 
            +
                    'std_dev': std_dev,
         | 
| 297 306 | 
             
                    'excess_kurtosis': excess_kurtosis,
         | 
| 298 307 | 
             
                    'q25': q25,
         | 
| 299 308 | 
             
                    'q75': q75,
         | 
| 300 309 | 
             
                    'iqr': iqr,
         | 
| 301 310 | 
             
                    'entropy': entropy,
         | 
| 302 | 
            -
                    ' | 
| 303 | 
            -
             | 
| 304 | 
            -
             | 
| 305 | 
            -
                     | 
| 311 | 
            +
                    'o1p': o1p,
         | 
| 312 | 
            +
                    'o2p': o2p,
         | 
| 313 | 
            +
                    'o3p': o3p,
         | 
| 314 | 
            +
                    'o4p': o4p,
         | 
| 315 | 
            +
                    'o1n': o1n,
         | 
| 316 | 
            +
                    'o2n': o2n,
         | 
| 317 | 
            +
                    'o3n': o3n,
         | 
| 318 | 
            +
                    'o4n': o4n
         | 
| 306 319 | 
             
                }
         | 
| 307 320 |  | 
| 308 321 | 
             
                if model_params is not None:
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |