亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? epr_dataset.c

?? Insar圖像處理軟件
?? C
字號:
/* * $Id: epr_dataset.c,v 1.2 2003/03/21 16:08:08 norman Exp $ * * Copyright (C) 2002 by Brockmann Consult (info@brockmann-consult.de) * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation. This program is distributed in the hope it will * be useful, but WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. */#include <assert.h>#include <errno.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#include <time.h>#include "epr_api.h"#include "epr_core.h"#include "epr_string.h"#include "epr_ptrarray.h"#include "epr_swap.h"#include "epr_field.h"#include "epr_dataset.h"#include "epr_record.h"#include "epr_param.h"#include "epr_dsd.h"#include "epr_msph.h"#include "epr_band.h"#include "epr_bitmask.h"#include "epr_dddb.h"EPR_SDatasetId* epr_create_dataset_id(EPR_SProductId* product_id,                                       const EPR_SDSD* dsd,                                      const char* dataset_name,                                      const struct RecordDescriptor* record_descriptor,                                      const char* dsd_name,                                      const char* description) {    EPR_SDatasetId* dataset_id = (EPR_SDatasetId*) calloc(1, sizeof (EPR_SDatasetId));    if (dataset_id == NULL) {        epr_set_err(e_err_out_of_memory,                     "epr_create_dataset_id: out of memory");        return NULL;    }    dataset_id->magic = EPR_MAGIC_DATASET_ID;    dataset_id->product_id = product_id;    dataset_id->dsd = dsd;    dataset_id->record_info = NULL;    epr_assign_string(&dataset_id->dataset_name, dataset_name);    dataset_id->record_descriptor = record_descriptor;    epr_assign_string(&dataset_id->dsd_name, dsd_name);    epr_assign_string(&dataset_id->description, description);    return dataset_id;}/** * Release the memory allocated through a dataset ID. *  * @param product_id the file identifier, if <code>NULL</code> the function *        immediately returns zero. * @return zero for success, an error code otherwise */void epr_free_dataset_id(EPR_SDatasetId* dataset_id){    if (dataset_id == NULL)         return;    /* Don't free the product ID, it is NOT owned by a dataset ID */    dataset_id->product_id = NULL;    /* Don't free the record information, it is NOT owned by a dataset ID */    dataset_id->record_info = NULL;    /* Don't free the DSD, it is NOT owned by a dataset ID */    dataset_id->dsd = NULL;    epr_free_and_null_string(&dataset_id->dataset_name);    epr_free_and_null_string(&dataset_id->dsd_name);    epr_free_and_null_string(&dataset_id->description);    free(dataset_id);}/** * Creates an array of dataset_id for the given ENVISAT product * * @param product_id the the product file identifier * @return the instance of the array */EPR_SPtrArray* epr_create_dataset_ids(EPR_SProductId* product_id){    EPR_SPtrArray* dataset_ids = NULL;    EPR_SDatasetId* dataset_id = NULL;    const EPR_SDSD* dsd = NULL;    uint dsd_index;    int i;    const struct DatasetDescriptorTable* p_tables;    int pt_index;    int num_descr;    if (product_id == NULL) {            epr_set_err(e_err_null_pointer,                     "create_dataset_ids: product_id must not be NULL");        return NULL;    }    /* @DDDB */    p_tables = dddb_product_tables;    pt_index = -1;    for (i = 0; i < EPR_NUM_PRODUCT_TABLES; i++) {         const char* id = p_tables[i].name;        if (strncmp(product_id->id_string, id, 10) == 0) {            if (product_id->meris_iodd_version == 5) {                if (strcmp(id, "MER_RR__1P_IODD5") == 0 ||                     strcmp(id, "MER_FR__1P_IODD5") == 0) {                    pt_index = i;                }            } else {                pt_index = i;            }        }         if (pt_index != -1) {            break;        }    }    if (pt_index == -1) {        epr_set_err(e_err_null_pointer,                     "create_dataset_ids: unknown product type");        return NULL;    }	dataset_ids = epr_create_ptr_array(16);    num_descr = p_tables[pt_index].num_descriptors;    for (i = 0; i < num_descr; i++) {        for (dsd_index = 0; dsd_index < product_id->dsd_array->length; dsd_index++) {            dsd = (EPR_SDSD*)epr_get_ptr_array_elem_at(product_id->dsd_array, dsd_index);            if (strncmp(dsd->ds_name, p_tables[pt_index].descriptors[i].ds_name, strlen(epr_strip_string_r(dsd->ds_name))) == 0) {                dataset_id = epr_create_dataset_id(product_id,                                                    dsd,                                                    p_tables[pt_index].descriptors[i].id,                                                    p_tables[pt_index].descriptors[i].rec_descriptor,                                                    p_tables[pt_index].descriptors[i].ds_name,                                                    p_tables[pt_index].descriptors[i].description);                epr_add_ptr_array_elem(dataset_ids, dataset_id);                 break;            }        }	}    return dataset_ids;}const char* epr_get_dataset_name(EPR_SDatasetId* dataset_id){    epr_clear_err();    if (dataset_id == NULL) {            epr_set_err(e_err_null_pointer,                     "epr_get_dataset_name: band_id must not be NULL");        return NULL;    }    return epr_trim_string(dataset_id->dataset_name);}uint epr_get_num_records(const EPR_SDatasetId* dataset_id){    epr_clear_err();    if (dataset_id == NULL) {        epr_set_err(e_err_invalid_dataset_name,                     "epr_get_num_records: invalid dataset name");        return (uint)-1;        }    return dataset_id->dsd->num_dsr;}const EPR_SDSD* epr_get_dsd(const EPR_SDatasetId* dataset_id){    epr_clear_err();    if (dataset_id == NULL) {        epr_set_err(e_err_invalid_dataset_name,                     "epr_get_dsd: invalid dataset name");        return NULL;        }    return dataset_id->dsd;}const char* epr_get_dsd_name(const EPR_SDatasetId* dataset_id){    epr_clear_err();    if (dataset_id == NULL) {        epr_set_err(e_err_invalid_dataset_name,                     "epr_get_dsd_name: invalid dataset name");        return NULL;        }    return epr_trim_string(dataset_id->dsd_name);}uint epr_get_dataset_offset(EPR_SDatasetId* dataset_id){    if (dataset_id == NULL) {            epr_set_err(e_err_null_pointer,                     "epr_get_dataset_offset: dataset_id must not be NULL");        return (uint)0;    }    return dataset_id->dsd->ds_offset;}/*********************************** RECORD ***********************************//*   Function:    epr_create_record   Access:      public API   Changelog:   2002/01/23  mp initial version *//** * Creates a new record for the dataset given by the specified  * dataset identifier. */EPR_SRecord* epr_create_record(EPR_SDatasetId* dataset_id){    EPR_SRecord* record = NULL;    epr_clear_err();    if (dataset_id == NULL) {        epr_set_err(e_err_illegal_arg,                     "epr_create_record: dataset ID must not be NULL");        return NULL;    }    if (dataset_id->record_info == NULL) {        dataset_id->record_info = epr_get_record_info(dataset_id);    }    record = epr_create_record_from_info(dataset_id->record_info);    if (record == NULL) {        epr_set_err(e_err_invalid_record_name,                     "epr_create_record: invalid record name");        return NULL;    }    return record;} /** * Reads a full record from ENVISAT product file.  */EPR_SRecord* epr_read_record(EPR_SDatasetId* dataset_id,                             uint record_index,                             EPR_SRecord* record){    uint field_index;    uint dsd_offset;    uint record_size;    uint data_type_size;    uint elements_to_read;    uint elements_read;    EPR_SField* field = NULL;    epr_clear_err();    if (dataset_id == NULL) {        epr_set_err(e_err_invalid_dataset_name,                     "epr_read_record: invalid dataset name");        return NULL;                }    if ((record_index < 0) || (record_index >= dataset_id->dsd->num_dsr)) {        epr_set_err(e_err_invalid_value,                     "epr_read_record: invalid record_index parameter, must be >=0 and <num_dsr");        return NULL;    }    if (record == NULL) {        record = epr_create_record(dataset_id);    } else if (record->info != dataset_id->record_info) {        epr_set_err(e_err_invalid_record_name,                     "epr_read_record: invalid record name");        return NULL;    }    /*READ FILE with: dataset_id->product_id->istream after the setting it to begin*/    rewind(dataset_id->product_id->istream);    /*GET OFFSET*/    dsd_offset = dataset_id->dsd->ds_offset;    record_size = record->info->tot_size;    if (record_size != dataset_id->dsd->dsr_size) {        epr_set_err(e_err_invalid_data_format,             "epr_read_record: wrong record size");        return NULL;    }    /* Set file pointer to begin of demanded record */    if (fseek(dataset_id->product_id->istream, dsd_offset + record_size * record_index, SEEK_SET) != 0) {        epr_set_err(e_err_file_access_denied,             "epr_read_record: file seek failed");        return NULL;    }    for (field_index = 0; field_index < record->num_fields; field_index++) {        field = record->fields[field_index];        elements_to_read = field->info->num_elems ;        data_type_size = epr_get_data_type_size(field->info->data_type_id);        assert(data_type_size != 0);        assert(field->elems != NULL);        if (elements_to_read * data_type_size != field->info->tot_size) {            /*epr_log(e_log_info, "Spare");*/            data_type_size = field->info->tot_size / elements_to_read;        }        elements_read = fread(field->elems, data_type_size, elements_to_read, dataset_id->product_id->istream);        if (elements_read != elements_to_read) {                epr_set_err(e_err_file_read_error,                 "epr_read_record: file read failed");            return NULL;        }        /*          * SWAP bytes on little endian (LE) order architectures (I368, Pentium Processors).         * ENVISAT products are stored in big endian (BE) order.         */        if (epr_api.little_endian_order) {            epr_swap_endian_order(field);        }    }    return record;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一二三四区在线| 天堂蜜桃91精品| 一区二区三区在线观看视频| 天天免费综合色| 99久久综合国产精品| 欧美一区二区三区公司| 亚洲欧美电影院| 国产激情视频一区二区三区欧美 | 欧美高清精品3d| 国产视频一区二区三区在线观看| 亚洲成av人片在www色猫咪| 99re热视频精品| 国产午夜精品一区二区三区四区| 日本va欧美va瓶| 欧美日韩极品在线观看一区| 亚洲免费av在线| 成人白浆超碰人人人人| 国产日韩欧美精品一区| 精品一区二区三区在线观看国产| 欧美性猛交xxxxxxxx| 亚洲欧美成人一区二区三区| 成人91在线观看| 中文久久乱码一区二区| 国产成人av福利| 精品国产亚洲在线| 日本美女视频一区二区| 欧美日本一区二区| 亚洲午夜视频在线| 在线观看一区二区精品视频| 亚洲同性同志一二三专区| 成人av在线电影| 国产日产欧美精品一区二区三区| 国产美女精品在线| 久久这里只有精品6| 精品一区二区精品| 久久亚洲一区二区三区明星换脸 | 亚洲视频网在线直播| 成人a区在线观看| 国产精品传媒入口麻豆| 成人精品视频一区| 亚洲私人黄色宅男| 日本韩国一区二区三区| 亚洲免费三区一区二区| 欧美在线观看视频在线| 午夜欧美大尺度福利影院在线看 | 在线观看国产91| 亚洲午夜久久久久久久久久久| 欧美三级视频在线| 秋霞电影一区二区| 国产日韩亚洲欧美综合| 91蜜桃免费观看视频| 一区二区三区四区在线| 777午夜精品免费视频| 麻豆高清免费国产一区| 久久网站最新地址| 成人免费高清视频在线观看| 亚洲美女偷拍久久| 欧美日韩一级片在线观看| 美女久久久精品| 国产精品久久三| 在线观看国产91| 国内精品视频一区二区三区八戒| 亚洲国产精品t66y| 欧美三区在线视频| 国产又粗又猛又爽又黄91精品| 中文字幕亚洲区| 7777女厕盗摄久久久| 国产精品亚洲专一区二区三区| 日韩毛片一二三区| 日韩欧美一区二区免费| 9色porny自拍视频一区二区| 视频一区视频二区中文| 久久久久99精品一区| 欧洲中文字幕精品| 国产又黄又大久久| 午夜激情综合网| 国产精品色噜噜| 欧美一区二区精美| 成人av资源网站| 国内精品不卡在线| 一区二区高清免费观看影视大全 | 国产老肥熟一区二区三区| 一区二区三区日韩精品视频| 欧美精品一区二区三区蜜桃| 99re视频这里只有精品| 国产一区二区三区av电影 | 欧美高清在线精品一区| 欧美久久婷婷综合色| 99精品视频免费在线观看| 久久99热这里只有精品| 亚洲午夜三级在线| 中文字幕中文在线不卡住| 日韩美女一区二区三区四区| 欧美性欧美巨大黑白大战| 成人h动漫精品一区二区| 久久精品国产**网站演员| 午夜精品免费在线观看| 亚洲免费色视频| 国产精品久久久久aaaa樱花| 久久久久国产精品厨房| 欧美一区二区久久久| 欧美理论电影在线| 91福利国产精品| 色婷婷亚洲综合| av高清久久久| 成人app网站| 成人午夜在线视频| 成人黄色综合网站| 国产乱人伦偷精品视频不卡 | 性久久久久久久久久久久| 亚洲区小说区图片区qvod| 中文文精品字幕一区二区| 精品国产免费人成在线观看| 宅男在线国产精品| 91麻豆精品国产91久久久久久 | 久久一区二区视频| 精品日本一线二线三线不卡| 欧美一级搡bbbb搡bbbb| 欧美精品亚洲一区二区在线播放| 在线免费观看不卡av| 欧洲中文字幕精品| 欧美日韩激情在线| 欧美一卡二卡在线| 精品久久久三级丝袜| www精品美女久久久tv| 久久久久久久av麻豆果冻| 欧美国产精品一区二区三区| 国产午夜精品美女毛片视频| 国产精品美女久久久久aⅴ国产馆| 久久精品亚洲精品国产欧美| 国产欧美一区二区精品仙草咪| 中文字幕av免费专区久久| 国产精品久久久久久久久久免费看 | 捆绑调教一区二区三区| 韩国在线一区二区| 成人国产亚洲欧美成人综合网| 91美女在线看| 91精品国产福利在线观看| 精品sm在线观看| 国产精品免费视频一区| 亚洲福利一区二区| 老司机精品视频导航| 成人免费看片app下载| 欧美性色综合网| 日韩欧美国产系列| 中文字幕五月欧美| 亚洲 欧美综合在线网络| 国内一区二区在线| 色综合夜色一区| 欧美一区二区成人6969| 国产精品理伦片| 日本sm残虐另类| 99精品黄色片免费大全| 91麻豆精品91久久久久久清纯 | 成人av第一页| 欧美精品在线观看一区二区| 国产日韩欧美激情| 午夜激情一区二区| 不卡的电影网站| 日韩欧美的一区二区| 亚洲乱码中文字幕| 精彩视频一区二区| 日本韩国欧美一区| 久久久精品中文字幕麻豆发布| 亚洲国产精品久久久久秋霞影院| 国产成人午夜99999| 欧美美女网站色| 亚洲免费成人av| 国产精品99久久久久久有的能看 | 毛片一区二区三区| 91麻豆成人久久精品二区三区| 精品电影一区二区三区| 亚洲韩国一区二区三区| 成人免费视频网站在线观看| 日韩一区二区影院| 亚洲成a人在线观看| 91麻豆视频网站| 久久久青草青青国产亚洲免观| 日韩精品视频网| 欧美三级韩国三级日本一级| 国产精品欧美久久久久一区二区| 蜜臀av在线播放一区二区三区 | 依依成人综合视频| 成人免费av网站| 国产午夜一区二区三区| 麻豆成人综合网| 欧美一区二区人人喊爽| 日韩在线a电影| 欧美日韩国产综合久久| 一区二区欧美视频| 色狠狠色狠狠综合| 亚洲欧美经典视频| 91在线视频在线| 日本一区二区在线不卡| 国产99久久久国产精品免费看| 国产亚洲污的网站| 国产精品夜夜嗨| 国产精品午夜在线观看| 成人白浆超碰人人人人| 亚洲欧美综合色|