SDC C-Project CF Review 프로그램
LYW
2021-07-23 55615eba335d4cbc1f83330dc5078fe073034b7d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
 
 
#include "stdafx.h"
#include "vec1d.h"
 
 
vec1D::vec1D(unsigned int size, int offset, const float* data) : m_size(size), m_offset(offset), m_data(0)
{
    m_last = (m_size + m_offset) - 1;
    m_data = (float *)_aligned_malloc(m_size * sizeof(float), 16);     //MMX alignement
    
    for (unsigned int i = 0; i < m_size; i++) 
    {
        if (data != 0)
            m_data[i] = data[i];
        else
            m_data[i] = 0.0f;
    }
 
    m_data -= m_offset;
}
 
vec1D::vec1D(const vec1D& v) : m_data(0)
{
    init(v);
}
 
vec1D::~vec1D()
{
    close();
}
 
void vec1D::init(const vec1D& v)
{
    close();
 
    m_size = v.size();
    m_offset = v.first();
    const float* data = v.data();
   
    m_last = (m_size + m_offset) - 1;
    m_data = (float *)_aligned_malloc(m_size * sizeof(float), 16);     //MMX alignement    
 
    for (unsigned int i = 0; i < m_size; i++)
        m_data[i] = data[i];  
 
    m_data -= m_offset;
}
 
void vec1D::close()
{
    if (m_data != 0) 
    {
        m_data +=  m_offset;
        _aligned_free(m_data);
    }
}