Vectors Library
mikroC PRO for dsPIC30/33 and PIC24 includes a library for working and using vectors. All routines work with fractional Q15 format.
Library Routines
- Vector_Set
- Vector_Power
- Vector_Subtract
- Vector_Scale
- Vector_Negate
- Vector_Multiply
- Vector_Min
- Vector_Max
- Vector_Dot
- Vector_Correlate
- Vector_Convolve
- Vector_Add
Vector_Set
Prototype |
void Vector_Set(unsigned *input, unsigned size, unsigned value); |
---|---|
Description |
Sets |
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vec2[3] = {1,1,1}; Vector_Set(vec2, 3, 0x4000); |
Notes |
|
Vector_Power
Prototype |
unsigned Vector_Power(unsigned numElems, unsigned *srcV); |
---|---|
Description |
Function returns result of power value (powVal) in radix point 1.15 |
Parameters |
|
Returns |
|
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; Vector_Power(3, vec1); |
Notes |
|
Vector_Subtract
Prototype |
void Vector_Subtract(unsigned *dest, unsigned *v1, unsigned *v2, unsigned numElems); |
---|---|
Description |
This function does subtraction of two vectors. dstV[n] = v1[n] - v2[n], n Î [0, numElems-1] |
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; unsigned vec2[3] = {1,1,1}; unsigned vecDest[3]; Vector_Subtract(vecDest, vec1, vec2, 3); |
Notes |
|
Vector_Scale
Prototype |
void Vector_Scale(unsigned N, int ScaleValue, unsigned *SrcVector, unsigned *DestVector); |
---|---|
Description |
This function does vector scaling with scale value. dstV[n] = sclVal * srcV[n], n Î [0, numElems-1] |
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; unsigned vecDest[3]; Vector_Scale(3, 2, vec1, vecDest); |
Notes |
|
Vector_Negate
Prototype |
void Vector_Negate(unsigned *srcVector, unsigned *DestVector, unsigned numElems); |
---|---|
Description |
This function does negation of vector. dstV[n] = (-1)*srcV1[n] + 0, n Î [0, numElems) |
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vecDest[3]; unsigned vec1[3] = {1,2,3}; Vector_Negate(vec1, vecDest, 3); |
Notes |
|
Vector_Multiply
Prototype |
void Vector_Multiply(unsigned *v1, unsigned *v2, unsigned *dest, unsigned numElems); |
---|---|
Description |
This function does multiplication of two vectors. dstV[n] = srcV1[n] * srcV2[n], n Î [0, numElems-1] |
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; unsigned vec2[3] = {1,1,1}; unsigned vConDest[10]; Vector_Multiply(vec1, vConDest, vec2, 3); |
Notes |
|
Vector_Min
Prototype |
unsigned Vector_Min(unsigned *Vector, unsigned numElems, unsigned *MinIndex); |
---|---|
Description |
This function finds minimal value in vector. minVal = min (srcV[n]), n Î [0, numElems-1] |
Parameters |
|
Returns |
Minimum value ( |
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; unsigned index; unsigned rslt; rslt = Vector_Min(vec1, 3, &index); |
Notes | [W0..W5] used, not restored |
Vector_Max
Prototype |
unsigned Vector_Max(unsigned *srcV, unsigned numElems, unsigned *MaxIndex); |
---|---|
Description |
This function find maximal value in vector. maxVal = max (srcV[n]), n Î [0, numElems-1] |
Parameters |
|
Returns |
Maximum value ( |
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; unsigned index; unsigned rslt; rslt = Vector_Max(vec1, 3, &index); |
Notes | [W0..W5] used, not restored |
Vector_Dot
Prototype |
unsigned Vector_Dot(unsigned *v1, unsigned *v2, unsigned numElems); |
---|---|
Description |
Function calculates vector dot product. |
Parameters |
|
Returns |
Dot product value :
|
Requires |
Nothing. |
Example |
unsigned vec2[3] = {1,1,1}; unsigned rslt; rslt = Vector_Dot(vec2,vec2,3); |
Notes |
|
Vector_Correlate
Prototype |
void Vector_Correlate(unsigned *v1, unsigned *v2, unsigned *dest, unsigned numElemsV1, unsigned numElemsV2); |
---|---|
Description |
Function calculates Vector correlation (using convolution).
|
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vConDest[10]; unsigned vec2[3] = {1,1,1}; Vector_Correlate(vec2,vec2,vConDest,3,3); |
Notes | [W0..W7] used, not restored |
Vector_Convolve
Prototype |
void Vector_Convolve(unsigned *v1, unsigned *v2, unsigned *dest, unsigned numElemsV1, unsigned numElemsV2); |
---|---|
Description |
Function calculates Vector using convolution.
|
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vec2[3] = {1,1,1}; unsigned vConDest2[10]; Vector_Convolve(vec2,vec2,vConDest2,3,3); |
Notes |
|
Vector_Add
Prototype |
void Vector_Add(unsigned *dest, unsigned *v1, unsigned *v2, unsigned numElems); |
---|---|
Description |
Function calculates vector addition. dstV[n] = srcV1[n] + srcV2[n], n Î [0, numElems-1] |
Parameters |
|
Returns |
Nothing. |
Requires |
Nothing. |
Example |
unsigned vec1[3] = {1,2,3}; unsigned vec2[3] = {1,1,1}; unsigned vecDest[3]; Vector_Add(vecDest, vec1, vec2, 3); |
Notes |
|
What do you think about this topic ? Send us feedback!