2022-11-28 19:21:26 +08:00
<!DOCTYPE html>
< html class = "writer-html5" lang = "en" >
< head >
< meta charset = "utf-8" / >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" / >
< title > dna_viewer.util.conversion — DNA Calibration documentation< / title >
< link rel = "stylesheet" href = "../../../_static/pygments.css" type = "text/css" / >
< link rel = "stylesheet" href = "../../../_static/css/theme.css" type = "text/css" / >
< link rel = "stylesheet" href = "../../../_static/graphviz.css" type = "text/css" / >
<!-- [if lt IE 9]>
< script src = "../../../_static/js/html5shiv.min.js" > < / script >
<![endif]-->
< script data-url_root = "../../../" id = "documentation_options" src = "../../../_static/documentation_options.js" > < / script >
< script src = "../../../_static/jquery.js" > < / script >
< script src = "../../../_static/underscore.js" > < / script >
< script src = "../../../_static/doctools.js" > < / script >
< script src = "../../../_static/js/theme.js" > < / script >
< link rel = "index" title = "Index" href = "../../../genindex.html" / >
< link rel = "search" title = "Search" href = "../../../search.html" / >
< / head >
< body class = "wy-body-for-nav" >
< div class = "wy-grid-for-nav" >
< nav data-toggle = "wy-nav-shift" class = "wy-nav-side" >
< div class = "wy-side-scroll" >
< div class = "wy-side-nav-search" >
< a href = "../../../index.html" class = "icon icon-home" > DNA Calibration
< / a >
< div role = "search" >
< form id = "rtd-search-form" class = "wy-form" action = "../../../search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search docs" / >
< input type = "hidden" name = "check_keywords" value = "yes" / >
< input type = "hidden" name = "area" value = "default" / >
< / form >
< / div >
< / div > < div class = "wy-menu wy-menu-vertical" data-spy = "affix" role = "navigation" aria-label = "Navigation menu" >
< p class = "caption" role = "heading" > < span class = "caption-text" > Contents< / span > < / p >
< ul >
2022-12-02 21:35:01 +08:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../index_.html" > MetaHuman DNA Calibration< / a > < / li >
2022-11-28 19:21:26 +08:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../index_.html#overview" > Overview< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../index_.html#examples" > Examples< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../index_.html#notes" > Notes< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../index_.html#license" > License< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../index_.html#indices-and-tables" > Indices and tables< / a > < / li >
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > Repository Organization< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../repository_organization_md.html" > Repository Organization< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../repository_organization_md.html#folder-structure" > Folder structure< / a > < / li >
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > DNACalib< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../dnacalib_md.html" > DNACalib< / a > < / li >
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > DNAViewer< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../dna_viewer_md.html" > DNAViewer< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../dna_viewer_maya_md.html" > Usage in Maya< / a > < / li >
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > DNAViewer API< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../dna_viewer_api_md.html" > Environment Setup< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../dna_viewer_api_md.html#dna" > DNA< / a > < / li >
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > Technical documentation< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../dnacalib.html" > dnacalib< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../modules.html" > dna_viewer< / a > < / li >
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > FAQ< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../../faq_md.html" > Frequently Asked Questions (FAQ)< / a > < / li >
< / ul >
< / div >
< / div >
< / nav >
< section data-toggle = "wy-nav-shift" class = "wy-nav-content-wrap" > < nav class = "wy-nav-top" aria-label = "Mobile navigation menu" >
< i data-toggle = "wy-nav-top" class = "fa fa-bars" > < / i >
< a href = "../../../index.html" > DNA Calibration< / a >
< / nav >
< div class = "wy-nav-content" >
< div class = "rst-content" >
< div role = "navigation" aria-label = "Page navigation" >
< ul class = "wy-breadcrumbs" >
< li > < a href = "../../../index.html" class = "icon icon-home" > < / a > » < / li >
< li > < a href = "../../index.html" > Module code< / a > » < / li >
< li > dna_viewer.util.conversion< / li >
< li class = "wy-breadcrumbs-aside" >
< / li >
< / ul >
< hr / >
< / div >
< div role = "main" class = "document" itemscope = "itemscope" itemtype = "http://schema.org/Article" >
< div itemprop = "articleBody" >
< h1 > Source code for dna_viewer.util.conversion< / h1 > < div class = "highlight" > < pre >
< span > < / span > < span class = "kn" > from< / span > < span class = "nn" > math< / span > < span class = "kn" > import< / span > < span class = "n" > pi< / span >
< span class = "kn" > from< / span > < span class = "nn" > ..config.units< / span > < span class = "kn" > import< / span > < span class = "n" > AngleUnit< / span > < span class = "p" > ,< / span > < span class = "n" > LinearUnit< / span >
< span class = "kn" > from< / span > < span class = "nn" > ..util.error< / span > < span class = "kn" > import< / span > < span class = "n" > DNAViewerError< / span >
< div class = "viewcode-block" id = "Conversion" > < a class = "viewcode-back" href = "../../../dna_viewer.util.html#dna_viewer.util.conversion.Conversion" > [docs]< / a > < span class = "k" > class< / span > < span class = "nc" > Conversion< / span > < span class = "p" > :< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > A utility class containing methods for converting and calculating units< / span >
< span class = "sd" > " " " < / span >
< div class = "viewcode-block" id = "Conversion.calculate_linear_modifier" > < a class = "viewcode-back" href = "../../../dna_viewer.util.html#dna_viewer.util.conversion.Conversion.calculate_linear_modifier" > [docs]< / a > < span class = "nd" > @staticmethod< / span >
< span class = "k" > def< / span > < span class = "nf" > calculate_linear_modifier< / span > < span class = "p" > (< / span >
< span class = "n" > unit< / span > < span class = "p" > :< / span > < span class = "n" > LinearUnit< / span > < span class = "p" > ,< / span > < span class = "n" > dna_unit< / span > < span class = "p" > :< / span > < span class = "n" > LinearUnit< / span > < span class = "o" > =< / span > < span class = "kc" > None< / span >
< span class = "p" > )< / span > < span class = "o" > -> < / span > < span class = "nb" > float< / span > < span class = "p" > :< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > A method used for calculating the value (linear modifier) which the transforms will be multiplied with.< / span >
< span class = "sd" > If the chosen unit is not the same as the one from the DNA file a multiplier will be calculated. Otherwise it returns 1.< / span >
< span class = "sd" > @type unit: LinearUnit< / span >
< span class = "sd" > @param unit: Can be m (meter) and cm (centimeter).< / span >
< span class = "sd" > @type dna_unit: LinearUnit< / span >
< span class = "sd" > @param dna_unit: The linear unit specified in the DNA file (default value is None).< / span >
< span class = "sd" > @rtype: float< / span >
< span class = "sd" > @returns: A multiplier needed for conversion between different units.< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > if< / span > < span class = "n" > dna_unit< / span > < span class = "ow" > is< / span > < span class = "kc" > None< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "mi" > 1< / span >
< span class = "k" > if< / span > < span class = "n" > unit< / span > < span class = "o" > !=< / span > < span class = "n" > dna_unit< / span > < span class = "p" > :< / span >
< span class = "k" > if< / span > < span class = "n" > unit< / span > < span class = "o" > ==< / span > < span class = "n" > LinearUnit< / span > < span class = "o" > .< / span > < span class = "n" > m< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "mf" > 0.01< / span >
< span class = "k" > if< / span > < span class = "n" > unit< / span > < span class = "o" > ==< / span > < span class = "n" > LinearUnit< / span > < span class = "o" > .< / span > < span class = "n" > cm< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "mi" > 100< / span >
< span class = "k" > return< / span > < span class = "mi" > 1< / span > < / div >
< div class = "viewcode-block" id = "Conversion.calculate_angle_modifier" > < a class = "viewcode-back" href = "../../../dna_viewer.util.html#dna_viewer.util.conversion.Conversion.calculate_angle_modifier" > [docs]< / a > < span class = "nd" > @staticmethod< / span >
< span class = "k" > def< / span > < span class = "nf" > calculate_angle_modifier< / span > < span class = "p" > (< / span > < span class = "n" > unit< / span > < span class = "p" > :< / span > < span class = "n" > AngleUnit< / span > < span class = "p" > ,< / span > < span class = "n" > dna_unit< / span > < span class = "p" > :< / span > < span class = "n" > AngleUnit< / span > < span class = "o" > =< / span > < span class = "kc" > None< / span > < span class = "p" > )< / span > < span class = "o" > -> < / span > < span class = "nb" > float< / span > < span class = "p" > :< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > A method used for calculating the value (angle modifier) which the angles will be multiplied with. If the< / span >
< span class = "sd" > chosen unit is not the same as the one from the DNA file a multiplier will be calculated. Otherwise,< / span >
< span class = "sd" > it returns 1.< / span >
< span class = "sd" > @type unit: AngleUnit< / span >
< span class = "sd" > @param unit: Can be degree and radian.< / span >
< span class = "sd" > @type dna_unit: AngleUnit< / span >
< span class = "sd" > @param dna_unit: The angle unit specified in the DNA file (default value is None).< / span >
< span class = "sd" > @rtype: float< / span >
< span class = "sd" > @returns: A multiplier needed for conversion between different units.< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > if< / span > < span class = "n" > dna_unit< / span > < span class = "ow" > is< / span > < span class = "kc" > None< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "mi" > 1< / span >
< span class = "k" > if< / span > < span class = "n" > unit< / span > < span class = "o" > !=< / span > < span class = "n" > dna_unit< / span > < span class = "p" > :< / span >
< span class = "k" > if< / span > < span class = "n" > unit< / span > < span class = "o" > ==< / span > < span class = "n" > AngleUnit< / span > < span class = "o" > .< / span > < span class = "n" > degree< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "mi" > 180< / span > < span class = "o" > /< / span > < span class = "n" > pi< / span >
< span class = "k" > if< / span > < span class = "n" > unit< / span > < span class = "o" > ==< / span > < span class = "n" > AngleUnit< / span > < span class = "o" > .< / span > < span class = "n" > radian< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "n" > pi< / span > < span class = "o" > /< / span > < span class = "mi" > 180< / span >
< span class = "k" > return< / span > < span class = "mi" > 1< / span > < / div >
< div class = "viewcode-block" id = "Conversion.get_linear_unit_from_int" > < a class = "viewcode-back" href = "../../../dna_viewer.util.html#dna_viewer.util.conversion.Conversion.get_linear_unit_from_int" > [docs]< / a > < span class = "nd" > @staticmethod< / span >
< span class = "k" > def< / span > < span class = "nf" > get_linear_unit_from_int< / span > < span class = "p" > (< / span > < span class = "n" > value< / span > < span class = "p" > :< / span > < span class = "nb" > int< / span > < span class = "p" > )< / span > < span class = "o" > -> < / span > < span class = "n" > LinearUnit< / span > < span class = "p" > :< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Returns an enum from an int value.< / span >
< span class = "sd" > 0 -> cm< / span >
< span class = "sd" > 1 -> m< / span >
< span class = "sd" > @type value: int< / span >
< span class = "sd" > @param value: The value that the enum is mapped to.< / span >
< span class = "sd" > @rtype: LinearUnit< / span >
< span class = "sd" > @returns: LinearUnit.cm or LinearUnit.m< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > if< / span > < span class = "n" > value< / span > < span class = "o" > ==< / span > < span class = "mi" > 0< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "n" > LinearUnit< / span > < span class = "o" > .< / span > < span class = "n" > cm< / span >
< span class = "k" > if< / span > < span class = "n" > value< / span > < span class = "o" > ==< / span > < span class = "mi" > 1< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "n" > LinearUnit< / span > < span class = "o" > .< / span > < span class = "n" > m< / span >
< span class = "k" > raise< / span > < span class = "n" > DNAViewerError< / span > < span class = "p" > (< / span > < span class = "sa" > f< / span > < span class = "s2" > " Unknown linear unit set in DNA file! value < / span > < span class = "si" > {< / span > < span class = "n" > value< / span > < span class = "si" > }< / span > < span class = "s2" > " < / span > < span class = "p" > )< / span > < / div >
< div class = "viewcode-block" id = "Conversion.get_angle_unit_from_int" > < a class = "viewcode-back" href = "../../../dna_viewer.util.html#dna_viewer.util.conversion.Conversion.get_angle_unit_from_int" > [docs]< / a > < span class = "nd" > @staticmethod< / span >
< span class = "k" > def< / span > < span class = "nf" > get_angle_unit_from_int< / span > < span class = "p" > (< / span > < span class = "n" > value< / span > < span class = "p" > :< / span > < span class = "nb" > int< / span > < span class = "p" > )< / span > < span class = "o" > -> < / span > < span class = "n" > AngleUnit< / span > < span class = "p" > :< / span >
< span class = "sd" > " " " < / span >
< span class = "sd" > Returns an enum from an int value.< / span >
< span class = "sd" > 0 -> degree< / span >
< span class = "sd" > 1 -> radian< / span >
< span class = "sd" > @type value: int< / span >
< span class = "sd" > @param value: The value that the enum is mapped to.< / span >
< span class = "sd" > @rtype: AngleUnit< / span >
< span class = "sd" > @returns: AngleUnit.degree or AngleUnit.radian< / span >
< span class = "sd" > " " " < / span >
< span class = "k" > if< / span > < span class = "n" > value< / span > < span class = "o" > ==< / span > < span class = "mi" > 0< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "n" > AngleUnit< / span > < span class = "o" > .< / span > < span class = "n" > degree< / span >
< span class = "k" > if< / span > < span class = "n" > value< / span > < span class = "o" > ==< / span > < span class = "mi" > 1< / span > < span class = "p" > :< / span >
< span class = "k" > return< / span > < span class = "n" > AngleUnit< / span > < span class = "o" > .< / span > < span class = "n" > radian< / span >
< span class = "k" > raise< / span > < span class = "n" > DNAViewerError< / span > < span class = "p" > (< / span > < span class = "sa" > f< / span > < span class = "s2" > " Unknown angle unit set in DNA file! value < / span > < span class = "si" > {< / span > < span class = "n" > value< / span > < span class = "si" > }< / span > < span class = "s2" > " < / span > < span class = "p" > )< / span > < / div > < / div >
< / pre > < / div >
< / div >
< / div >
< footer >
< hr / >
< div role = "contentinfo" >
< p > © Copyright 2022, Epic Games.< / p >
< / div >
Built with < a href = "https://www.sphinx-doc.org/" > Sphinx< / a > using a
< a href = "https://github.com/readthedocs/sphinx_rtd_theme" > theme< / a >
provided by < a href = "https://readthedocs.org" > Read the Docs< / a > .
< / footer >
< / div >
< / div >
< / section >
< / div >
< script >
jQuery(function () {
SphinxRtdTheme.Navigation.enable(true);
});
< / script >
< / body >
< / html >