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

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

?? hdr_coordinateframe.m

?? toolbox of BVQX, This is the access between BV and matlab. It will help you to analysis data from BV
?? M
字號:
function cfr = hdr_CoordinateFrame(hfile)
% HDR::CoordinateFrame  - get coordinate frame from Analyze image
%
% FORMAT:       cframe = hdr.CoordinateFrame
%
% No input fields
%
% Output fields:
%
%       cframe      struct with fields
%        .DimX/Y/Z  spatial dimension of image
%        .DimT      number of volumes for multi-volume image, default 1
%        .Dimensions combined list
%        .ResX/Y/Z  spatial resolution (in TAL/MNI/real world mm)
%        .Resolution combined list
%        .Slice1Center  center coordinate of first slice
%        .SliceNCenter  center coordinate of last slice
%        .SystemOrigin  voxel around (0;0;0)
%        .RowDir    equivalent to AffineTransX(1:3)
%        .ColDir    equivalent to AffineTransY(1:3)
%        .SlcDir    equivalent to AffineTransZ(1:3)
%        .IsRadiological  flag whether coordinate system is left-handed
%        .Trf       4x4 quaternion matrix, so that
%                   cframe.Trf * voxel := mm
%          - and -  inv(cframe.Trf) * mm := voxel

% Version:  v0.7b
% Build:    7090508
% Date:     Sep-05 2007, 8:06 AM CEST
% Author:   Jochen Weber, Brain Innovation, B.V., Maastricht, NL
% URL/Info: http://wiki.brainvoyager.com/BVQXtools

% global config needed
global bvqxfile_config;

% argument check
if nargin < 1 || ...
    numel(hfile) ~= 1 || ...
   ~isBVQXfile(hfile, 'hdr')
    error( ...
        'BVQXfile:BadArgument', ...
        'Invalid call to ''%s''.', ...
        mfilename ...
    );
end
sc = bvqxfile_getscont(hfile.L);
bc = sc.C;
cfr = struct;

% check for additional MAT file
afile = sc.F;
exten = afile(end-2:end);
if any(exten == upper(exten))
    mfile = [afile(1:end-4) '.MAT'];
else
    mfile = [afile(1:end-4) '.mat'];
end
mfilec = [];
mfilel = false;
if exist(mfile, 'file') == 2
    try
        mfilem = load(mfile);
        mfilec = mfilem.mat;
        mfilel = true;
    catch
        % do nothing
    end
end

% get dimensions
cfr.DimX = bc.ImgDim.Dim(2);
cfr.DimY = bc.ImgDim.Dim(3);
if bc.ImgDim.Dim(1) > 2
    cfr.DimZ = bc.ImgDim.Dim(4);
    resz = bc.ImgDim.PixSpacing(4);
else
    cfr.DimZ = 1;
    resz = 1;
end
if bc.ImgDim.Dim(1) > 3
    cfr.DimT = bc.ImgDim.Dim(5);
else
    cfr.DimT = 1;
end
cfr.Dimensions = [cfr.DimX, cfr.DimY, cfr.DimZ, cfr.DimT];

% get resolution
cfr.ResX = bc.ImgDim.PixSpacing(2);
cfr.ResY = bc.ImgDim.PixSpacing(3);
cfr.ResZ = resz;

% set full resolution element
cfr.Resolution = [cfr.ResX, cfr.ResY, cfr.ResZ];

% compute 1-based transformation matrix (as used in SPM)
if ~isempty(mfilec)
    % not needed if mat file was loaded 
elseif ~all( ...
    [bc.DataHist.NIftI1.AffineTransX(end), ...
     bc.DataHist.NIftI1.AffineTransY(end), ...
     bc.DataHist.NIftI1.AffineTransZ(end)] == 0)
    mfilec = [ ...
        bc.DataHist.NIftI1.AffineTransX; ...
        bc.DataHist.NIftI1.AffineTransY; ...
        bc.DataHist.NIftI1.AffineTransZ; ...
        0, 0, 0, 1];
    mfilec(1:3, 4) = mfilec(1:3, 4) - mfilec(1:3, 1:3) * [1; 1; 1];
    mfilel = true;
elseif ~all(bc.DataHist.OriginSPM(1:3) == 0)
    mfilec = [ ...
        cfr.ResX,     0   ,     0   , -cfr.ResX * bc.DataHist.OriginSPM(1); ...
            0   , cfr.ResY,     0   , -cfr.ResY * bc.DataHist.OriginSPM(2); ...
            0   ,     0   , cfr.ResZ, -cfr.ResZ * bc.DataHist.OriginSPM(3); ...
            0   ,     0   ,     0   ,     1];
elseif bc.NIIFileType == 0
    switch (double(bc.DataHist.Orientation))
        case {0}
            mfilec = [ ...
                cfr.ResX,     0   ,     0   , -cfr.ResX * cfr.DimX / 2; ...
                    0   , cfr.ResY,     0   , -cfr.ResY * cfr.DimY / 2; ...
                    0   ,     0   , cfr.ResZ, -cfr.ResZ * cfr.DimZ / 2; ...
                    0   ,     0   ,     0   ,      1];
        case {1}
            mfilec = [ ...
                cfr.ResX,     0   ,     0   , -cfr.ResX * cfr.DimX / 2; ...
                    0   ,     0   , cfr.ResZ, -cfr.ResZ * cfr.DimZ / 2; ...
                    0   , cfr.ResY,     0   , -cfr.ResY * cfr.DimY / 2; ...
                    0   ,     0   ,     0   ,      1];
        case {2}
            mfilec = [ ...
                    0   , cfr.ResY,     0   , -cfr.ResY * cfr.DimY / 2; ...
                    0   ,     0   , cfr.ResZ, -cfr.ResY * cfr.DimZ / 2; ...
                cfr.ResX,     0   ,     0   , -cfr.ResX * cfr.DimX / 2; ...
                    0   ,     0   ,     0   ,      1];
        case {3}
            mfilec = [ ...
                cfr.ResX,     0   ,     0   , -cfr.ResX * cfr.DimX / 2; ...
                    0   ,-cfr.ResY,     0   ,  cfr.ResY * cfr.DimY / 2; ...
                    0   ,     0   , cfr.ResZ, -cfr.ResZ * cfr.DimZ / 2; ...
                    0   ,     0   ,     0   ,      1];
        case {4}
            mfilec = [ ...
                cfr.ResX,     0   ,     0   , -cfr.ResX * cfr.DimX / 2; ...
                    0   ,     0   ,-cfr.ResZ,  cfr.ResZ * cfr.DimZ / 2; ...
                    0   , cfr.ResY,     0   , -cfr.ResY * cfr.DimY / 2; ...
                    0   ,     0   ,     0   ,      1];
        case {5}
            mfilec = [ ...
                    0   , cfr.ResY,     0   , -cfr.ResY * cfr.DimY / 2; ...
                    0   ,     0   ,-cfr.ResZ,  cfr.ResZ * cfr.DimZ / 2; ...
                cfr.ResX,     0   ,     0   , -cfr.ResX * cfr.DimX / 2; ...
                    0   ,     0   ,     0   ,      1];
        otherwise
            warning( ...
                'BVQXfile:InvalidObject', ...
                'Unknown DataHist.Orientation value: %d.', ...
                double(bc.DataHist.Orientation) ...
            );
    end
end

% last resort
if isempty(mfilec)
    mfilec = [ ...
        cfr.ResX,     0   ,     0   , -cfr.DimX / 2; ...
            0   , cfr.ResY,     0   , -cfr.DimY / 2; ...
            0   ,     0   , cfr.ResZ, -cfr.DimZ / 2; ...
            0   ,     0   ,     0   ,      1];
end

% convention guessing needed ?
if ~mfilel && ...
   (bc.ImgDim.PixSpacing(1) < 0 || ...
    (bc.ImgDim.PixSpacing(1) == 0 && ...
     bc.NIIFileType < 1 && ...
     bc.DataHist.Orientation == 0 && ...
     bvqxfile_config.type.hdr.assumeflipped))
    if cfr.ResX < 0
        cfr.ResX = -cfr.ResX;
    end
    
    % perform x-flip to get to TAL
    mfilec(1, :) = -mfilec(1, :);
end

% compute slice 1 and N center coordinates (Trf is one-based!)
sl1c = mfilec * [0.5 + cfr.DimX / 2; 0.5 + cfr.DimY / 2; 0.5; 1];
slnc = mfilec * [0.5 + cfr.DimX / 2; 0.5 + cfr.DimY / 2; 0.5 + cfr.DimZ; 1];

% get direction components
dcp = -mfilec(1:3, 1:3);
dcp = dcp ./ repmat(sqrt(sum(dcp .* dcp, 2)), [1, 3]);
dcp(4, :) = -cross(dcp(1, :), dcp(2, :));

% make settings
cfr.Slice1Center = sl1c(1:3)';
cfr.SliceNCenter = slnc(1:3)';
cfr.SystemOrigin = -mfilec(1:3, 4)';
cfr.RowDir = dcp(1, :);
cfr.ColDir = dcp(2, :);
cfr.SlcDir = dcp(3, :);
cfr.IsRadiological = (sum(dcp(3, :) .* dcp(4, :)) > 0);
cfr.Trf = mfilec;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久这里只有精品视频网| 亚洲国产日韩一区二区| 亚洲成人一区二区在线观看| 国产在线观看免费一区| 91精品办公室少妇高潮对白| 日韩精品专区在线影院观看| 亚洲自拍与偷拍| 成人激情动漫在线观看| 精品国产一区二区在线观看| 亚洲成人自拍网| 99在线精品一区二区三区| 精品国产91九色蝌蚪| 免费在线看一区| 欧美挠脚心视频网站| 亚洲综合一区二区三区| 91视频xxxx| 中文字幕佐山爱一区二区免费| 狠狠色丁香婷综合久久| 欧美日韩精品欧美日韩精品一| 亚洲精品欧美激情| 99精品视频一区二区三区| 中文字幕乱码一区二区免费| 国产一区二区三区久久久 | 久久久久久久久久久久电影| 日韩av不卡在线观看| 欧美三级一区二区| 亚洲国产裸拍裸体视频在线观看乱了 | 成人免费av资源| 国产拍欧美日韩视频二区| 国产高清视频一区| 久久精品日产第一区二区三区高清版| 久久99精品久久久久久久久久久久| 日韩一区二区三区视频在线观看| 青草国产精品久久久久久| 91精品国产麻豆| 国内外成人在线| 国产欧美一区二区精品婷婷| 成人免费不卡视频| 亚洲免费观看高清| 欧美军同video69gay| 日本亚洲天堂网| 久久久www成人免费无遮挡大片| 国产剧情一区二区三区| 国产清纯在线一区二区www| 99久久综合精品| 亚洲一区二区3| 日韩欧美国产电影| 国产a视频精品免费观看| 最新欧美精品一区二区三区| 日本精品视频一区二区| 日本不卡视频在线| 久久久久国产一区二区三区四区| 国产成人av电影在线观看| 日韩一区中文字幕| 欧美三级三级三级爽爽爽| 精品中文字幕一区二区| 中文字幕国产精品一区二区| 色视频欧美一区二区三区| 偷偷要91色婷婷| 国产午夜亚洲精品羞羞网站| 日本韩国精品在线| 麻豆成人91精品二区三区| 中文无字幕一区二区三区| 在线观看视频一区| 国产专区欧美精品| 亚洲综合色婷婷| 久久久精品国产免大香伊| 精品视频在线免费观看| 国产尤物一区二区在线| 亚洲综合久久久久| 国产欧美综合在线| 欧洲国内综合视频| 成人三级在线视频| 久久精品国产亚洲5555| 亚洲欧美视频在线观看视频| 欧美不卡123| 91豆麻精品91久久久久久| 黄色精品一二区| 石原莉奈在线亚洲二区| 亚洲人成影院在线观看| 精品av久久707| 欧美日韩在线直播| 99re成人在线| 国产精品资源站在线| 亚洲第一在线综合网站| 国产精品久久久久久久岛一牛影视| 日韩亚洲欧美在线观看| 欧美中文字幕一区二区三区 | 丝袜亚洲精品中文字幕一区| 国产精品动漫网站| 国产亚洲欧美激情| 精品少妇一区二区三区在线播放| 欧美色男人天堂| 色综合色综合色综合色综合色综合 | 欧美在线一二三| 本田岬高潮一区二区三区| 精品亚洲porn| 免费在线看一区| 日韩av一区二区三区| 丝瓜av网站精品一区二区 | 亚洲免费高清视频在线| 日本一区二区三区四区在线视频 | 最新欧美精品一区二区三区| 国产亚洲一区二区三区在线观看| 日韩精品一区二区三区老鸭窝| 欧美精品xxxxbbbb| 欧美高清激情brazzers| 欧美二区三区91| 69堂成人精品免费视频| 欧美夫妻性生活| 在线不卡中文字幕| 欧美一区二区三区的| 日韩视频在线你懂得| 日韩欧美电影一二三| 欧美一级高清片在线观看| 日韩一二在线观看| 精品精品国产高清a毛片牛牛| 欧美精品一区二区精品网| 亚洲精品在线观看网站| 久久久三级国产网站| 国产色91在线| 中文字幕日韩av资源站| 一区二区三区久久| 舔着乳尖日韩一区| 久久精品国产色蜜蜜麻豆| 激情成人综合网| 99这里都是精品| 欧美日韩一区二区三区不卡| 777奇米四色成人影色区| 日韩免费福利电影在线观看| 精品久久久久久久久久久久久久久| 欧美精品一区二区三区蜜桃| 国产精品亲子伦对白| 一区二区三区美女视频| 日本视频一区二区| 国产精品系列在线播放| 成人免费看视频| 欧美日韩一区三区四区| 精品福利av导航| 亚洲色图清纯唯美| 日韩成人免费在线| 国产精品一区二区三区四区| 91一区二区在线| 欧美一区二区三区四区高清 | 亚洲午夜激情av| 精品亚洲aⅴ乱码一区二区三区| 成人黄页在线观看| 欧美另类高清zo欧美| 国产午夜精品一区二区| 亚洲免费观看高清完整版在线观看熊| 日韩av午夜在线观看| 成人99免费视频| 欧美一区二区三区喷汁尤物| 中文字幕一区二区视频| 日本中文一区二区三区| 本田岬高潮一区二区三区| 日韩欧美一二区| 一区二区三区在线不卡| 国产精品一卡二卡| 欧美日韩一区成人| 亚洲天堂精品视频| 久久99最新地址| 欧美日韩在线精品一区二区三区激情| 国产亚洲综合在线| 蜜桃久久精品一区二区| 91激情在线视频| 国产三级精品在线| 蜜臀av亚洲一区中文字幕| 91美女在线观看| 中文字幕+乱码+中文字幕一区| 亚洲成人av一区二区| av中文字幕一区| 久久这里只有精品6| 午夜精品久久久久久久久久 | 欧美电视剧免费观看| 亚洲精品国产无套在线观| 国产69精品久久99不卡| 91精品国产欧美一区二区成人| 亚洲免费大片在线观看| 成人开心网精品视频| 精品国产一区二区在线观看| 日韩中文字幕av电影| 欧美日韩国产不卡| 亚洲线精品一区二区三区| 色爱区综合激月婷婷| 亚洲欧美日韩国产成人精品影院 | 国产精品久久久久影院| 国产成人综合在线播放| 亚洲精品一线二线三线| 美女视频一区二区三区| 在线播放中文字幕一区| 亚洲h动漫在线| 69久久夜色精品国产69蝌蚪网| 亚洲一区二区三区视频在线 | 91同城在线观看| 亚洲人成精品久久久久久| 成人天堂资源www在线| 中文字幕日本不卡| 色综合亚洲欧洲| 亚洲va欧美va人人爽|