:orphan:
# MatPtAP
Creates the matrix product C = P^T * A * P
## Synopsis
```
#include "petscmat.h"
PetscErrorCode MatPtAP(Mat A, Mat P, MatReuse scall, PetscReal fill, Mat *C)
```
Neighbor-wise Collective
## Input Parameters
- ***A -*** the matrix
- ***P -*** the projection matrix
- ***scall -*** either `MAT_INITIAL_MATRIX` or `MAT_REUSE_MATRIX`
- ***fill -*** expected fill as ratio of nnz(C)/(nnz(A) + nnz(P)), use `PETSC_DEFAULT` if you do not have a good estimate
if the result is a dense matrix this is irrelevant
## Output Parameter
- ***C -*** the product matrix
## Notes
C will be created and must be destroyed by the user with `MatDestroy()`.
An alternative approach to this function is to use `MatProductCreate()` and set the desired options before the computation is done
## Developer Note
For matrix types without special implementation the function fallbacks to `MatMatMult()` followed by `MatTransposeMatMult()`.
## See Also
[](ch_matrices), `Mat`, `MatProductCreate()`, `MatMatMult()`, `MatRARt()`
## Level
intermediate
## Location
src/mat/interface/matrix.c
## Examples
src/ksp/ksp/tutorials/ex76.c
src/tao/pde_constrained/tutorials/elliptic.c
---
[Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/mat/interface/matrix.c)
[Index of all Mat routines](index.md)
[Table of Contents for all manual pages](/manualpages/index.md)
[Index of all manual pages](/manualpages/singleindex.md)