- stage3.py 
    - Contains the stage_embedding method which implements the STAGE algorithm, along with various helper functions
    - Stage_embeding must receive exactly one of r (radius) or k (number of neighbors) to generate neighborhoods, as well as an embedding type, "linreg" or "laplacian"
    - ex. stage_embedding(X, k = 50, embedding = "linreg")
- curve.py 
    - contains a class for general parametric curves, as well as the RandomFourierCurve class 
    - The parametric curve class also has methods for the functional form of the curve, as well as its first and second derivatives
    - ex. RandomFourierCurve(d = 100, K = 10, alpha = 2, span = 0.5, seed = 0)
        - d: dimension
        - K: number of components (increase for higher curvature)
        - alpha: decay of components (decrease for higher curvature)
        - span: value from 0 to 1 determining how much of the total curve to use (span = 1 is a closed curve)
- high_dim_experiments.py and experiment_utils.py
    - Contain the code to run the experiments whose results are in the Table 2 in the appendix, utilizing stage3 and RandomFourierCurve
- plot_denoising.py
    - Creates various plots for visualization of random Fourier curves
    - Used to generate Figure 3 and Figure 4a/b/c
- sweep.py
    - script to compare t-SNE and STAGE with different parameter settings
    - ex. sweep.py --n_iter 30 --k 30 50 70 100 200 300 --perplexity 30 50 70 100 200 300 --noise_sd 5 --n_points 3000
    - Used to generate Figure 5 