Haplo Prediction
predict haplogroups
haplo_groups.h
Go to the documentation of this file.
00001 /*
00002  * This work is licensed under a Creative Commons 
00003  * Attribution-Noncommercial-Share Alike 3.0 United States License.
00004  * 
00005  *    http://creativecommons.org/licenses/by-nc-sa/3.0/us/
00006  * 
00007  * You are free:
00008  * 
00009  *    to Share - to copy, distribute, display, and perform the work
00010  *    to Remix - to make derivative works
00011  * 
00012  * Under the following conditions:
00013  * 
00014  *    Attribution. You must attribute the work in the manner specified by the
00015  *    author or licensor (but not in any way that suggests that they endorse you
00016  *    or your use of the work).
00017  * 
00018  *    Noncommercial. You may not use this work for commercial purposes.
00019  * 
00020  *    Share Alike. If you alter, transform, or build upon this work, you may
00021  *    distribute the resulting work only under the same or similar license to
00022  *    this one.
00023  * 
00024  * For any reuse or distribution, you must make clear to others the license
00025  * terms of this work. The best way to do this is by including this header.
00026  * 
00027  * Any of the above conditions can be waived if you get permission from the
00028  * copyright holder.
00029  * 
00030  * Apart from the remix rights granted under this license, nothing in this
00031  * license impairs or restricts the author's moral rights.
00032  */
00033 
00034 
00046 #ifndef HAPLO_GROUPS_H
00047 #define HAPLO_GROUPS_H
00048 
00049 
00050 #include <config.h>
00051 
00052 #include <stdlib.h>
00053 #include <inttypes.h>
00054 
00055 #include <jwsc/base/error.h>
00056 #include <jwsc/vector/vector.h>
00057 
00058 
00060 typedef enum 
00061 {
00062     HAPLO_ANCESTOR_NONE=0,
00063     HAPLO_ANCESTOR_DIRECT,
00064     HAPLO_ANCESTOR_INDIRECT
00065 }
00066 Haplo_ancestor_type;
00067 
00068 
00070 Error* read_haplo_groups(const char* fname);
00071 
00072 
00074 Error* lookup_haplo_group_index_from_label
00075 (
00076     uint32_t*   index_out, 
00077     const char* label
00078 );
00079 
00080 
00082 Error* lookup_haplo_group_label_from_index
00083 (
00084     const char** label_out, 
00085     uint32_t     index
00086 );
00087 
00088 
00091 Error* lookup_haplo_group_ancestor_index_from_haplo_group_index
00092 (
00093     uint32_t*   index_out, 
00094     uint32_t     index
00095 );
00096 
00098 uint32_t get_num_haplo_groups();
00099 
00100 
00102 uint8_t is_ancestor(uint32_t index_1, uint32_t index_2);
00103 
00104 
00106 Haplo_ancestor_type find_ancestor_index_of_pair
00107 (
00108     uint32_t* index_out, 
00109     uint32_t  index_1, 
00110     uint32_t  index_2
00111 );
00112 
00113 
00117 Haplo_ancestor_type find_ancestor_index_of_set
00118 (
00119     uint32_t*         index_out, 
00120     const Vector_u32* indices
00121 );
00122 
00123 #endif