No project description provided
Project description
pcurvepy
Principal Curves
This is an implementation of the Principal Curves (Hastie '89) algorithm in Python.
It is a fork of the zsteve/pcurvepy
package where
the projection indices are selected according to our
translation of the R/C++ princurve
package.
Installation:
pip install git+https://github.com/mossjacob/pcurvepy
Example:
import pandas as pd
import matplotlib.pyplot as plt
import numpy as np
import pcurve
data = pd.read_csv('test_data.csv')
x = data.loc[:, ('X1', 'X2')].to_numpy()
# transform data to have zero mean
x = x - np.mean(x, 0)
index = np.arange(0, len(x))
curve = pcurve.PrincipalCurve(k=5)
curve.fit(x)
plt.scatter(x[:, 0], x[:, 1], alpha=0.25, c=index)
plt.plot(curve.points[:, 0], curve.points[:, 1], c='k')
# get interpolation indices
pseudotime_interp, point_interp, order = curve.unpack_params()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pcurvepy2-0.1.0.tar.gz
(16.2 kB
view hashes)
Built Distribution
pcurvepy2-0.1.0-py3-none-any.whl
(16.8 kB
view hashes)
Close
Hashes for pcurvepy2-0.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a7d90d2d60a8dfa5fbcebe7adb03217339bed4fcc755de78867c8eed957171d3 |
|
MD5 | 6fca359cf211a7534f31ce2b2e5aa7e1 |
|
BLAKE2b-256 | 74860bba994f555b2b4913414fd25d116da93d16580ce08183f0e26d84f492d8 |