Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

find_highly_variable_features [PERFORMANCE] #156

Open
maithermbarros opened this issue Aug 21, 2024 · 9 comments
Open

find_highly_variable_features [PERFORMANCE] #156

maithermbarros opened this issue Aug 21, 2024 · 9 comments

Comments

@maithermbarros
Copy link

Hello. Thanks for developing SCENIC+, it is super dope and it is giving me nice results so far.

What type of problem are you experiencing and which function is you problem related too
While preparing multiome datasets to run SCENIC+, when running find_highly_variable_features my python process gets killed. I am running a python script directly in my workstation which has good memory:

image

Is this problem data set related? If so, provide information on the problematic data set
It works without issues on another dataset of mine (~26k cells, ~ 480k regions) except in this larger dataset with cells ~45k cells and ~540k regions

Describe alternatives you've considered
I tried running this step within Rstudio through reticulate() and in a python jupyter notebook too but it also gets killed because of memory.

Additional context
I am running all of this in a conda environment where I installed scenicplus, pycistopic and pycistarget.
I tried running this step of the pipeline using a python script:

import scenicplus
import pycisTopic 
import scanpy as sc
import pandas as pd
import os
import pickle
import numpy as np

from pycisTopic.diff_features import (
  impute_accessibility,
  normalize_scores,
  find_highly_variable_features,
  find_diff_features)

import matplotlib.pyplot as plt

# Directories and working paths
projDir = "/mnt/data/SCENICplus_P1-B1-B2P1-B2P3R2/"
outDir = "/mnt/data/SCENICplus_P1-B1-B2P1-B2P3R2/output"
work_dir = "/mnt/data/SCENICplus_P1-B1-B2P1-B2P3R2/"
tmpDir = "/mnt/scratch/SCENICplus_temp/"

# Load the imputed accessibility object
with open(os.path.join(outDir, 'DARs', 'imputed_acc_obj.pkl'), 'rb') as infile:
    imputed_acc_obj = pickle.load(infile)

# Normalize the imputed data
normalized_imputed_acc_obj = normalize_scores(imputed_acc_obj, scale_factor=10**4)

# Find highly variable features without plotting to save memory
variable_regions = find_highly_variable_features(normalized_imputed_acc_obj,
                                                 min_disp=0.05,
                                                 min_mean=0.0125,
                                                 max_mean=3,
                                                 max_disp=np.inf,
                                                 n_bins=20,
                                                 n_top_features=None,
                                                 plot=True,
                                           	 save= outDir + '/DARs/HVR_plot.pdf')

# Save the results
with open(os.path.join(outDir, "DARs", "variable_regions.pkl"), "wb") as outfile:
    pickle.dump(variable_regions, outfile)

Then it gets killed:
image

I also tried running normalize_scores first, save the output as a pkl file to then run find_highly_variable_features but it doesn't work either.

Version information
Report versions of modules relevant to this error
image

Any help/insight would be greatly appreciated as I really need to finish preparing this file to then run SCENIC+. Thank you!

@ghuls
Copy link
Member

ghuls commented Aug 22, 2024

There is some ongoing work to improve memory usage for this code and some other memory intensive functions in pycisTopic that will eventually appear in the polars_1xx branch of pycisTopic.
https://github.com/aertslab/pycisTopic/tree/polars_1xx

@maithermbarros
Copy link
Author

Thanks for getting back to me. Do you have any workarounds for the meantime? I would really like to be able to run SCENIC+ on this dataset and to do so I need to run this step. I tried using multiprocessing in python but it still doesn't work.

@ghuls
Copy link
Member

ghuls commented Aug 29, 2024

Thanks for getting back to me. Do you have any workarounds for the meantime? I would really like to be able to run SCENIC+ on this dataset and to do so I need to run this step. I tried using multiprocessing in python but it still doesn't work.

No workarounds for now, but likely in a few weeks. Topic modeling with Mallet got some speedup and reduced memory usage. diff_features code will be next.

@eliascrapa
Copy link

Hi,
just wanted to ask if there are any updates. I used 780GB of memory on the HPC but still not able to get normalize_scores running.
" Unable to allocate 710. GiB for an array with shape (680104, 140085) and data type float64."

@ghuls
Copy link
Member

ghuls commented Sep 19, 2024

Not yet. Last weeks other projects had higher priority.

@yojetsharma
Copy link

Would reading the data in chunks help for now? Or downsampling the number of cells before running this step?

@ghuls
Copy link
Member

ghuls commented Oct 14, 2024

Would reading the data in chunks help for now? Or downsampling the number of cells before running this step?

Downsampling the number of cells would help.

@yojetsharma
Copy link

I managed it as a job the HPC though without having to downsample :) thank you for your response!

@ghuls
Copy link
Member

ghuls commented Nov 6, 2024

I finally had some time to work on it. Now it would be possible to theoretically even run it on a laptop:
#179 (comment)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants