//Получение координат центра контура
Point getContourCentre(CONT& vec)
{
    double tempx = 0.0, tempy = 0.0;
    for (int i = 0; i < vec.size(); i++) {
        tempx += vec[i].x;
        tempy += vec[i].y;
    }
    return Point(tempx / (double)vec.size(), tempy / (double)vec.size());
}
//Проверка находится ли один контур в другом
bool isContourInsideContour(CONT& in, CONT& out)
{
	//каждую точку внутреннего контура проверяем на нахождение во внешнем контуре
    for(int i = 0; i < in.size(); i++){
        if(pointPolygonTest(out, in[i], false) <= 0) return false; //проверка, находится ли точка внутри контура
    }
    return true;
}
예제 #3
0
TSeries<TDATE,TDATA,TSDIM,TSDATABACKEND,DatePolicy>
cbind(const CONT<TSeries<TDATE,TDATA,TSDIM,TSDATABACKEND,DatePolicy> >& cont,
      const bool intersection)
{
    size_t sz = cont.size();
    if(sz == 0) {
        return TSeries<TDATE,TDATA,TSDIM,TSDATABACKEND,DatePolicy>();
    }
    if(sz == 1) {
        return *cont.begin();
    }

    std::vector<TDATE> ans_dates;
    if(intersection) {
        date_intersection(cont,std::inserter(ans_dates,ans_dates.begin()));
    } else {
        date_union(cont,std::inserter(ans_dates,ans_dates.begin()));
    }

    if(ans_dates.size() == 0) {
        return TSeries<TDATE,TDATA,TSDIM,TSDATABACKEND,DatePolicy>();
    }

    TSeries<TDATE,TDATA,TSDIM,TSDATABACKEND,DatePolicy> ans(ans_dates.size(),cbind_total_cols(cont));
    std::copy(ans_dates.begin(), ans_dates.end(), ans.getDates());
    // FIXME: set colnames

    // if union, then we must initialize the values of ans to NA
    if(!intersection) {
        for(TSDIM i = 0; i < ans.nrow() * ans.ncol(); i++) {
            ans.getData()[i] = numeric_traits<TDATA>::NA();
        }
    }

    typename CONT<TSeries<TDATE,TDATA,TSDIM,TSDATABACKEND,DatePolicy> >::const_iterator it = cont.begin();

    // walk along iterator and map values into ans
    TSDIM offset = 0;
    while(it != cont.end()) {
        cbind_map_values(ans, *it, offset);
        offset += it->ncol();
        ++it;
    }
    return ans;
}
예제 #4
0
 //empty
 bool empty() {return container.size() == 0;}
예제 #5
0
파일: ivl_io.hpp 프로젝트: iavr/drvq
void write_array(const CONT<T, K>& a, std::ostream& s)
{
	write_size(a.size(), s);
	write(a, s);
}