Bases: FusedMoE
 A FusedMoE operation that also computes the results of shared experts. If an all2all communicator is being used the shared expert computation can be interleaved with the fused all2all dispatch communication step.
  Source code in vllm/model_executor/layers/shared_fused_moe/shared_fused_moe.py
 |  | class SharedFusedMoE(FusedMoE):
    """
    A FusedMoE operation that also computes the results of shared experts.
    If an all2all communicator is being used the shared expert computation
    can be interleaved with the fused all2all dispatch communication step.
    """
    def __init__(
        self,
        shared_experts: torch.nn.Module,
        use_overlapped: bool = True,
        **kwargs,
    ):
        super().__init__(**kwargs)
        self._shared_experts = shared_experts
        self.use_overlapped = use_overlapped
    @property
    def shared_experts(self) -> Optional[torch.nn.Module]:
        return self._shared_experts if self.use_overlapped else None
    def forward(
        self,
        hidden_states: torch.Tensor,
        router_logits: torch.Tensor,
    ) -> tuple[torch.Tensor, torch.Tensor]:
        if not self.use_overlapped:
            shared_out = self._shared_experts(hidden_states)
            # Reduce outputs if necessary, since the MLP should
            # have been created with reduce_results=False.
            if (self.reduce_results and self.tp_size > 1
                    and self.must_reduce_shared_expert_outputs()):
                shared_out = tensor_model_parallel_all_reduce(shared_out)
            fused_out = super().forward(
                hidden_states=hidden_states,
                router_logits=router_logits,
            )
        else:
            shared_out, fused_out = super().forward(
                hidden_states=hidden_states,
                router_logits=router_logits,
            )
        return shared_out, fused_out
 | 
     instance-attribute  
 _shared_experts = shared_experts
 
      instance-attribute  
 use_overlapped = use_overlapped
 
     
 __init__(
    shared_experts: Module,
    use_overlapped: bool = True,
    **kwargs,
)
  Source code in vllm/model_executor/layers/shared_fused_moe/shared_fused_moe.py
 |  | def __init__(
    self,
    shared_experts: torch.nn.Module,
    use_overlapped: bool = True,
    **kwargs,
):
    super().__init__(**kwargs)
    self._shared_experts = shared_experts
    self.use_overlapped = use_overlapped
 | 
        
    Source code in vllm/model_executor/layers/shared_fused_moe/shared_fused_moe.py
 |  | def forward(
    self,
    hidden_states: torch.Tensor,
    router_logits: torch.Tensor,
) -> tuple[torch.Tensor, torch.Tensor]:
    if not self.use_overlapped:
        shared_out = self._shared_experts(hidden_states)
        # Reduce outputs if necessary, since the MLP should
        # have been created with reduce_results=False.
        if (self.reduce_results and self.tp_size > 1
                and self.must_reduce_shared_expert_outputs()):
            shared_out = tensor_model_parallel_all_reduce(shared_out)
        fused_out = super().forward(
            hidden_states=hidden_states,
            router_logits=router_logits,
        )
    else:
        shared_out, fused_out = super().forward(
            hidden_states=hidden_states,
            router_logits=router_logits,
        )
    return shared_out, fused_out
 |