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

Fix Aperture vectorisation issue #268

Merged
merged 34 commits into from
Nov 28, 2024

Conversation

jank324
Copy link
Member

@jank324 jank324 commented Oct 3, 2024

Description

Add survival_probabilities property to ParticleBeam. The particles blocked by the Aperture will be marked with 0 and surviving particles will have 1.

Right now Aperture still blocks differentiability, but can be addressed later using a sigmoid function for a smoothed blocking.

Motivation and Context

  • I have raised an issue to propose this change (required for new features and bug fixes)

Fixes #241. Also closes #93.

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)
  • Documentation (update in the documentation)

Checklist

  • I have updated the changelog accordingly (required).
  • My change requires a change to the documentation.
  • I have updated the tests accordingly (required for a bug fix or a new feature).
  • I have updated the documentation accordingly.
  • I have reformatted the code and checked that formatting passes (required).
  • I have have fixed all issues found by flake8 (required).
  • I have ensured that all pytest tests pass (required).
  • I have run pytest on a machine with a CUDA GPU and made sure all tests pass (required).
  • I have checked that the documentation builds (required).

Note: We are using a maximum length of 88 characters per line.

@jank324 jank324 added the bug Something isn't working label Oct 3, 2024
@jank324 jank324 linked an issue Oct 3, 2024 that may be closed by this pull request
@jank324
Copy link
Member Author

jank324 commented Oct 3, 2024

We kind of already talked about this a little bit, but I think this will basically require that the survived_mask is moved to be a permanent property of ParticleBeam ... and then all other non-aperture computations will have to be changed to respect the mask.

Correct? Am I missing something?

@cr-xu
Copy link
Member

cr-xu commented Oct 7, 2024

We kind of already talked about this a little bit, but I think this will basically require that the survived_mask is moved to be a permanent property of ParticleBeam ... and then all other non-aperture computations will have to be changed to respect the mask.

Correct? Am I missing something?

Yes, the properties of the beam should be calculated only w.r.t. ParticleBeam[survived_mask].

Then we need to think of how other elements handle the tracking.
Probably it's easier to still propagate the whole beam (for the vectorized implementation) even if a portion of the macroparticles are already lost.

I would suggest adding another property like particle_lost_at to keep track of where the particles are lost along the segment. But this requires probably keeping track of the s positions as #216 proposed.

@jank324
Copy link
Member Author

jank324 commented Oct 15, 2024

So, I think we should possibly approach this PR slightly differently. A mask and the way apertures currently work are not gradient-friendly, because it's all step functions. Maybe we should instead consider a survival probability for each function. And then consider beam properties as survival probability-weighted. Apterture would then apply a smooth mirrored Sigmoid-like function to the probabilities, which would give us nice gradients.

Another handy thing about this would be that we could leave the masked implementation of Aperture in place for now and use the mask as probabilities in other computations. We then wouldn't have to implement the smooth masking now and could do that in a later PR if we wanted, but the rest of the code would already be able to work with it.

@cr-xu
Copy link
Member

cr-xu commented Oct 15, 2024

This sounds good for me. I guess we'll see how this scales with collective effects later...

@jank324 will you finish this PR?

@jank324
Copy link
Member Author

jank324 commented Oct 15, 2024

This sounds good for me. I guess we'll see how this scales with collective effects later...

@jank324 will you finish this PR?

I actually think it will scale very nicely. Masking always flattens tensors, so you have to run a bunch of reshaping with Python operations. Multiplying with probabilities is one multiplication operation that can completely run concurrently and in machine code, so should be super fast.

I meant to finish it myself, but right now I'm not on top enough of my submission schedule to dedicate time to Cheetah development. So if you want to work on this, go right ahead.

@cr-xu cr-xu marked this pull request as ready for review October 25, 2024 13:46
@jank324
Copy link
Member Author

jank324 commented Nov 28, 2024

Some todo notes for myself:

@jank324
Copy link
Member Author

jank324 commented Nov 28, 2024

So ... the last thing this PR is missing now is that the Screen reading should account for the survival probabilities. As part of this, it should also account for the particle charges, so

histogram_weights = read_beam.survival_probabilities * read_beam.particle_charges

@jank324 jank324 requested review from cr-xu and removed request for cr-xu November 28, 2024 21:57
@jank324 jank324 merged commit 6cb0c99 into master Nov 28, 2024
8 checks passed
@jank324 jank324 deleted the 241-vectorised-aperture-tracking-is-broken branch November 28, 2024 21:59
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Vectorised aperture tracking is broken What is the purpose of Beam.empty?
2 participants