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

[NPU] Support Baichuan groupwise & gw code refactor #12337

Merged
merged 23 commits into from
Nov 8, 2024

Conversation

cyita
Copy link
Contributor

@cyita cyita commented Nov 5, 2024

Description

  1. Groupwise code refactor
  2. Support baichuan groupwise

TODOs:

  • ov test
  • l0 test
  • remove unused code

1. Why the change?

2. User API changes

3. Summary of the change

4. How to test?

  • N/A
  • Unit test: Please manually trigger the PR Validation here by inputting the PR number (e.g., 1234). And paste your action link here once it has been successfully finished.
  • Application test
  • Document test
  • ...

5. New dependencies

  • New Python dependencies
    - Dependency1
    - Dependency2
    - ...
  • New Java/Scala dependencies and their license
    - Dependency1 and license1
    - Dependency2 and license2
    - ...

@cyita cyita changed the title [NPU] Support Baichuan groupwise [WIP][NPU] Support Baichuan groupwise Nov 5, 2024
@cyita cyita changed the title [WIP][NPU] Support Baichuan groupwise [NPU] Support Baichuan groupwise Nov 7, 2024
@cyita cyita marked this pull request as ready for review November 7, 2024 10:18
@cyita cyita requested a review from plusbang November 8, 2024 02:43
@cyita cyita changed the title [NPU] Support Baichuan groupwise [NPU] Support Baichuan groupwise & gw code refactor Nov 8, 2024
Copy link
Contributor

@plusbang plusbang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please carefully verify models, other LGTM.

mlp_module_names = ["down_proj", "up_proj", "gate_proj"]
if (
isinstance(module, (Qwen2Attention, LlamaAttention))
or module.__class__.__name__ in ['MiniCPMAttention', 'Attention']
or module.__class__.__name__ in ['MiniCPMAttention']
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shall we also update the following check of module.__class__.__name__ in ['MiniCPMMLP', 'MLP']?

@@ -115,8 +124,10 @@ def __init__(
attention_mask = self.create_input_op((self.batch_size, 1, 1, self.max_seq_len + 1),
dtype=np.int64)
else:
attention_mask = self.create_input_op((self.batch_size, 1, self.seq_len, self.seq_len),
dtype=np.int64)
# attention_mask = self.create_input_op((self.batch_size, 1, self.seq_len,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please remove this directly.

@cyita cyita merged commit b2e69a8 into intel-analytics:main Nov 8, 2024
1 check passed
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

Successfully merging this pull request may close these issues.

2 participants