mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 14:10:34 +05:00
Min/Max of FlatArray, DynamicTable::ChangeSize
This commit is contained in:
parent
73846f23ae
commit
8840c519d3
@ -599,6 +599,22 @@ namespace ngcore
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
FlatArray<T> View (FlatArray<T> fa) { return fa; }
|
FlatArray<T> View (FlatArray<T> fa) { return fa; }
|
||||||
|
|
||||||
|
template <typename T, typename TI>
|
||||||
|
auto Max (FlatArray<T,TI> array, T max = std::numeric_limits<T>::min()) -> T
|
||||||
|
{
|
||||||
|
for (auto & v : array)
|
||||||
|
if (v > max) max = v;
|
||||||
|
return max;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename TI>
|
||||||
|
auto Min (FlatArray<T,TI> array, T min = std::numeric_limits<T>::max()) -> T
|
||||||
|
{
|
||||||
|
for (auto & v : array)
|
||||||
|
if (v < min) min = v;
|
||||||
|
return min;
|
||||||
|
}
|
||||||
|
|
||||||
/// print array
|
/// print array
|
||||||
template <class T, class TIND>
|
template <class T, class TIND>
|
||||||
inline ostream & operator<< (ostream & s, const FlatArray<T, TIND> & a)
|
inline ostream & operator<< (ostream & s, const FlatArray<T, TIND> & a)
|
||||||
|
@ -370,7 +370,7 @@ namespace ngcore
|
|||||||
};
|
};
|
||||||
|
|
||||||
Array<linestruct, IndexType> data;
|
Array<linestruct, IndexType> data;
|
||||||
T * oneblock;
|
T * oneblock = nullptr;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/// Creates table of size size
|
/// Creates table of size size
|
||||||
@ -398,7 +398,7 @@ namespace ngcore
|
|||||||
oneblock = new T[cnt];
|
oneblock = new T[cnt];
|
||||||
|
|
||||||
cnt = 0;
|
cnt = 0;
|
||||||
for (auto i : Range(data))
|
for (auto i : data.Range())
|
||||||
{
|
{
|
||||||
data[i].maxsize = entrysizes[i];
|
data[i].maxsize = entrysizes[i];
|
||||||
data[i].size = 0;
|
data[i].size = 0;
|
||||||
@ -407,6 +407,12 @@ namespace ngcore
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DynamicTable (DynamicTable && tab2)
|
||||||
|
{
|
||||||
|
Swap (data, tab2.data);
|
||||||
|
Swap (oneblock, tab2.oneblock);
|
||||||
|
}
|
||||||
|
|
||||||
~DynamicTable ()
|
~DynamicTable ()
|
||||||
{
|
{
|
||||||
if (oneblock)
|
if (oneblock)
|
||||||
@ -438,6 +444,31 @@ namespace ngcore
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ChangeSize (size_t size)
|
||||||
|
{
|
||||||
|
if (oneblock)
|
||||||
|
throw Exception ("cannot change size of oneblock dynamic table");
|
||||||
|
|
||||||
|
size_t oldsize = data.Size();
|
||||||
|
if (size == oldsize)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (size < oldsize)
|
||||||
|
for (int i = size; i < oldsize; i++)
|
||||||
|
delete [] data[i+BASE].col;
|
||||||
|
|
||||||
|
data.SetSize(size);
|
||||||
|
|
||||||
|
for (int i = oldsize; i < size; i++)
|
||||||
|
{
|
||||||
|
data[i+BASE].maxsize = 0;
|
||||||
|
data[i+BASE].size = 0;
|
||||||
|
data[i+BASE].col = nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
///
|
||||||
void IncSize (IndexType i)
|
void IncSize (IndexType i)
|
||||||
{
|
{
|
||||||
@ -529,6 +560,11 @@ namespace ngcore
|
|||||||
return data.Size();
|
return data.Size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto Range () const
|
||||||
|
{
|
||||||
|
return data.Range();
|
||||||
|
}
|
||||||
|
|
||||||
/// Returns size of the i-th row.
|
/// Returns size of the i-th row.
|
||||||
int EntrySize (IndexType i) const
|
int EntrySize (IndexType i) const
|
||||||
{
|
{
|
||||||
@ -564,7 +600,7 @@ namespace ngcore
|
|||||||
template <class T>
|
template <class T>
|
||||||
inline ostream & operator<< (ostream & s, const DynamicTable<T> & table)
|
inline ostream & operator<< (ostream & s, const DynamicTable<T> & table)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < table.Size(); i++)
|
for (auto i : Range(table))
|
||||||
{
|
{
|
||||||
s << i << ":";
|
s << i << ":";
|
||||||
for (int j = 0; j < table[i].Size(); j++)
|
for (int j = 0; j < table[i].Size(); j++)
|
||||||
|
Loading…
Reference in New Issue
Block a user