% TIMEFORMAT='%3R'; { time (exec 2>&1; /home/martin/bin/satallax -E /home/martin/.isabelle/contrib/e-2.5-1/x86_64-linux/eprover -p tstp -t 5 /home/martin/judgement-day/tptp-thf/tptp/TypeSafe/prob_58__5333140_1 ) ; }
% This file was generated by Isabelle (most likely Sledgehammer)
% 2020-12-16 14:19:02.041

% Could-be-implicit typings (19)
thf(ty_n_t__List__Olist_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__Product____Type__Oprod_It__List__Olist_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__Type__Oty_J_J_Mt__List__Olist_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__Product____Type__Oprod_It__List__Olist_It__Type__Oty_J_Mt__Product____Type__Oprod_It__Type__Oty_Mt__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J_J_J_J_J_J_J_J_J, type,
    list_P1234162913t_char : $tType).
thf(ty_n_t__Set__Oset_It__Product____Type__Oprod_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_Mt__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J_J, type,
    set_Pr2110063281on_val : $tType).
thf(ty_n_t__Product____Type__Oprod_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_Mt__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    produc1085126737on_val : $tType).
thf(ty_n_t__Set__Oset_It__Product____Type__Oprod_I_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    set_Pr227219079on_val : $tType).
thf(ty_n_t__Product____Type__Oprod_I_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    produc1731226791on_val : $tType).
thf(ty_n_t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    option2118145160on_val : $tType).
thf(ty_n_t__Set__Oset_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    set_Pr2075231726on_val : $tType).
thf(ty_n_t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    produc266837688on_val : $tType).
thf(ty_n_t__List__Olist_It__Product____Type__Oprod_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Type__Oty_J_J, type,
    list_P1991792281har_ty : $tType).
thf(ty_n_t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J, type,
    produc1257910179t_char : $tType).
thf(ty_n_t__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J, type,
    exp_list_char : $tType).
thf(ty_n_t__Option__Ooption_It__Value__Oval_J, type,
    option_val : $tType).
thf(ty_n_t__Option__Ooption_It__Type__Oty_J, type,
    option_ty : $tType).
thf(ty_n_t__Option__Ooption_It__Nat__Onat_J, type,
    option_nat : $tType).
thf(ty_n_t__List__Olist_It__String__Ochar_J, type,
    list_char : $tType).
thf(ty_n_t__Code____Numeral__Onatural, type,
    code_natural : $tType).
thf(ty_n_t__Value__Oval, type,
    val : $tType).
thf(ty_n_t__Type__Oty, type,
    ty : $tType).
thf(ty_n_t__Nat__Onat, type,
    nat : $tType).

% Explicit typings (61)
thf(sy_c_Code__Numeral_OSuc, type,
    code_Suc : code_natural > code_natural).
thf(sy_c_Conform_Oconf_001t__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J, type,
    conf_P93989998t_char : list_P1234162913t_char > (nat > option2118145160on_val) > val > ty > $o).
thf(sy_c_Conform_Olconf_001t__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J, type,
    lconf_485928294t_char : list_P1234162913t_char > (nat > option2118145160on_val) > (list_char > option_val) > (list_char > option_ty) > $o).
thf(sy_c_Conform_Ooconf_001t__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J, type,
    oconf_454120169t_char : list_P1234162913t_char > (nat > option2118145160on_val) > produc266837688on_val > $o).
thf(sy_c_Exceptions_Opreallocated, type,
    preallocated : (nat > option2118145160on_val) > $o).
thf(sy_c_Expr_Oexp_Onew_001t__List__Olist_It__String__Ochar_J, type,
    new_list_char : list_char > exp_list_char).
thf(sy_c_Fun_Ofun__upd_001t__List__Olist_It__String__Ochar_J_001t__Option__Ooption_It__Type__Oty_J, type,
    fun_up9191ion_ty : (list_char > option_ty) > list_char > option_ty > list_char > option_ty).
thf(sy_c_Fun_Ofun__upd_001t__List__Olist_It__String__Ochar_J_001t__Option__Ooption_It__Value__Oval_J, type,
    fun_up1252458416on_val : (list_char > option_val) > list_char > option_val > list_char > option_val).
thf(sy_c_Fun_Ofun__upd_001t__Nat__Onat_001t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    fun_up262443479on_val : (nat > option2118145160on_val) > nat > option2118145160on_val > nat > option2118145160on_val).
thf(sy_c_HOL_OThe_001t__List__Olist_It__Product____Type__Oprod_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Type__Oty_J_J, type,
    the_li2019826130har_ty : (list_P1991792281har_ty > $o) > list_P1991792281har_ty).
thf(sy_c_If_001t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    if_opt451925058on_val : $o > option2118145160on_val > option2118145160on_val > option2118145160on_val).
thf(sy_c_Map_Omap__le_001t__List__Olist_It__String__Ochar_J_001t__Type__Oty, type,
    map_le_list_char_ty : (list_char > option_ty) > (list_char > option_ty) > $o).
thf(sy_c_Map_Omap__le_001t__Nat__Onat_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    map_le931214383on_val : (nat > option2118145160on_val) > (nat > option2118145160on_val) > $o).
thf(sy_c_Map_Omap__of_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_001t__Type__Oty, type,
    map_of2035691063har_ty : list_P1991792281har_ty > produc1257910179t_char > option_ty).
thf(sy_c_Objects_Ohext, type,
    hext : (nat > option2118145160on_val) > (nat > option2118145160on_val) > $o).
thf(sy_c_Objects_Oinit__fields, type,
    init_fields : list_P1991792281har_ty > produc1257910179t_char > option_val).
thf(sy_c_Objects_Onew__Addr, type,
    new_Addr : (nat > option2118145160on_val) > option_nat).
thf(sy_c_Objects_Otypeof__h, type,
    typeof_h : (nat > option2118145160on_val) > val > option_ty).
thf(sy_c_Option_Ocombine__options_001t__Nat__Onat, type,
    combine_options_nat : (nat > nat > nat) > option_nat > option_nat > option_nat).
thf(sy_c_Option_Ocombine__options_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    combin1801280889on_val : (produc266837688on_val > produc266837688on_val > produc266837688on_val) > option2118145160on_val > option2118145160on_val > option2118145160on_val).
thf(sy_c_Option_Ocombine__options_001t__Type__Oty, type,
    combine_options_ty : (ty > ty > ty) > option_ty > option_ty > option_ty).
thf(sy_c_Option_Ocombine__options_001t__Value__Oval, type,
    combine_options_val : (val > val > val) > option_val > option_val > option_val).
thf(sy_c_Option_Ooption_ONone_001t__Nat__Onat, type,
    none_nat : option_nat).
thf(sy_c_Option_Ooption_ONone_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    none_P1535574167on_val : option2118145160on_val).
thf(sy_c_Option_Ooption_ONone_001t__Type__Oty, type,
    none_ty : option_ty).
thf(sy_c_Option_Ooption_ONone_001t__Value__Oval, type,
    none_val : option_val).
thf(sy_c_Option_Ooption_OSome_001t__Nat__Onat, type,
    some_nat : nat > option_nat).
thf(sy_c_Option_Ooption_OSome_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    some_P1299442195on_val : produc266837688on_val > option2118145160on_val).
thf(sy_c_Option_Ooption_OSome_001t__Type__Oty, type,
    some_ty : ty > option_ty).
thf(sy_c_Option_Ooption_OSome_001t__Value__Oval, type,
    some_val : val > option_val).
thf(sy_c_Option_Ooption_Ocase__option_001_Eo_001t__Nat__Onat, type,
    case_option_o_nat : $o > (nat > $o) > option_nat > $o).
thf(sy_c_Option_Ooption_Ocase__option_001_Eo_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    case_o1187854213on_val : $o > (produc266837688on_val > $o) > option2118145160on_val > $o).
thf(sy_c_Option_Ooption_Ocase__option_001_Eo_001t__Type__Oty, type,
    case_option_o_ty : $o > (ty > $o) > option_ty > $o).
thf(sy_c_Option_Ooption_Ocase__option_001_Eo_001t__Value__Oval, type,
    case_option_o_val : $o > (val > $o) > option_val > $o).
thf(sy_c_Option_Ooption_Ocase__option_001t__Option__Ooption_It__Nat__Onat_J_001t__Nat__Onat, type,
    case_o1104735357at_nat : option_nat > (nat > option_nat) > option_nat > option_nat).
thf(sy_c_Option_Ooption_Ocase__option_001t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    case_o815592781on_val : option2118145160on_val > (produc266837688on_val > option2118145160on_val) > option2118145160on_val > option2118145160on_val).
thf(sy_c_Option_Ooption_Ocase__option_001t__Option__Ooption_It__Type__Oty_J_001t__Type__Oty, type,
    case_o105137099_ty_ty : option_ty > (ty > option_ty) > option_ty > option_ty).
thf(sy_c_Product__Type_OPair_001_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_001_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J, type,
    produc797901719on_val : (produc1257910179t_char > option_val) > (produc1257910179t_char > option_val) > produc1731226791on_val).
thf(sy_c_Product__Type_OPair_001t__List__Olist_It__String__Ochar_J_001_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J, type,
    produc904988266on_val : list_char > (produc1257910179t_char > option_val) > produc266837688on_val).
thf(sy_c_Product__Type_OPair_001t__List__Olist_It__String__Ochar_J_001t__List__Olist_It__String__Ochar_J, type,
    produc1304532571t_char : list_char > list_char > produc1257910179t_char).
thf(sy_c_Product__Type_OPair_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    produc881885833on_val : produc266837688on_val > produc266837688on_val > produc1085126737on_val).
thf(sy_c_Product__Type_OPair__Rep_001t__List__Olist_It__String__Ochar_J_001_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J, type,
    produc1747120315on_val : list_char > (produc1257910179t_char > option_val) > list_char > (produc1257910179t_char > option_val) > $o).
thf(sy_c_Product__Type_Oprod_OAbs__prod_001t__List__Olist_It__String__Ochar_J_001_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J, type,
    produc1757249884on_val : (list_char > (produc1257910179t_char > option_val) > $o) > produc266837688on_val).
thf(sy_c_Set_OCollect_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    collec1229699853on_val : (produc266837688on_val > $o) > set_Pr2075231726on_val).
thf(sy_c_TypeRel_OFields_001t__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J, type,
    fields1441617180t_char : list_P1234162913t_char > list_char > list_P1991792281har_ty > $o).
thf(sy_c_TypeRel_Ofields_001t__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J, type,
    fields1811926268t_char : list_P1234162913t_char > list_char > list_P1991792281har_ty).
thf(sy_c_TypeRel_Ohas__field_001t__Product____Type__Oprod_It__List__Olist_It__List__Olist_It__String__Ochar_J_J_Mt__Expr__Oexp_It__List__Olist_It__String__Ochar_J_J_J, type,
    has_fi599584195t_char : list_P1234162913t_char > list_char > list_char > ty > list_char > $o).
thf(sy_c_WellTypeRT_OWTrt, type,
    wTrt : list_P1234162913t_char > (nat > option2118145160on_val) > (list_char > option_ty) > exp_list_char > ty > $o).
thf(sy_c_Wfrec_Osame__fst_001t__List__Olist_It__String__Ochar_J_001_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J, type,
    same_f2003279573on_val : (list_char > $o) > (list_char > set_Pr227219079on_val) > set_Pr2110063281on_val).
thf(sy_c_member_001t__Product____Type__Oprod_I_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    member548035792on_val : produc1731226791on_val > set_Pr227219079on_val > $o).
thf(sy_c_member_001t__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J, type,
    member1296415951on_val : produc266837688on_val > set_Pr2075231726on_val > $o).
thf(sy_c_member_001t__Product____Type__Oprod_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_Mt__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J, type,
    member197592058on_val : produc1085126737on_val > set_Pr2110063281on_val > $o).
thf(sy_v_C______, type,
    c : list_char).
thf(sy_v_E____, type,
    e : list_char > option_ty).
thf(sy_v_FDTs______, type,
    fDTs : list_P1991792281har_ty).
thf(sy_v_P, type,
    p : list_P1234162913t_char).
thf(sy_v_T____, type,
    t : ty).
thf(sy_v_a______, type,
    a : nat).
thf(sy_v_h_Ha______, type,
    h_a : nat > option2118145160on_val).
thf(sy_v_ha______, type,
    ha : nat > option2118145160on_val).
thf(sy_v_la______, type,
    la : list_char > option_val).

% Relevant facts (133)
thf(fact_0_RedNew_Ohyps_I2_J, axiom,
    ((fields1441617180t_char @ p @ c @ fDTs))). % RedNew.hyps(2)
thf(fact_1_RedNew_Oprems_I1_J, axiom,
    ((wTrt @ p @ ha @ e @ (new_list_char @ c) @ t))). % RedNew.prems(1)
thf(fact_2_RedNew_Oprems_I2_J, axiom,
    ((lconf_485928294t_char @ p @ ha @ la @ e))). % RedNew.prems(2)
thf(fact_3_RedNew_Ohyps_I3_J, axiom,
    ((h_a = (fun_up262443479on_val @ ha @ a @ (some_P1299442195on_val @ (produc904988266on_val @ c @ (init_fields @ fDTs))))))). % RedNew.hyps(3)
thf(fact_4_lconf__empty, axiom,
    ((![P : list_P1234162913t_char, H : nat > option2118145160on_val, E : list_char > option_ty]: (lconf_485928294t_char @ P @ H @ (^[X : list_char]: none_val) @ E)))). % lconf_empty
thf(fact_5_lconf__hext, axiom,
    ((![P : list_P1234162913t_char, H : nat > option2118145160on_val, L : list_char > option_val, E : list_char > option_ty, H2 : nat > option2118145160on_val]: ((lconf_485928294t_char @ P @ H @ L @ E) => ((hext @ H @ H2) => (lconf_485928294t_char @ P @ H2 @ L @ E)))))). % lconf_hext
thf(fact_6_pred__equals__eq2, axiom,
    ((![R : set_Pr2075231726on_val, S : set_Pr2075231726on_val]: (((^[X : list_char]: (^[Y : produc1257910179t_char > option_val]: (member1296415951on_val @ (produc904988266on_val @ X @ Y) @ R))) = (^[X : list_char]: (^[Y : produc1257910179t_char > option_val]: (member1296415951on_val @ (produc904988266on_val @ X @ Y) @ S)))) = (R = S))))). % pred_equals_eq2
thf(fact_7_RedNew_Ohyps_I1_J, axiom,
    (((new_Addr @ ha) = (some_nat @ a)))). % RedNew.hyps(1)
thf(fact_8_prod_Oinject, axiom,
    ((![X1 : list_char, X2 : produc1257910179t_char > option_val, Y1 : list_char, Y2 : produc1257910179t_char > option_val]: (((produc904988266on_val @ X1 @ X2) = (produc904988266on_val @ Y1 @ Y2)) = (((X1 = Y1)) & ((X2 = Y2))))))). % prod.inject
thf(fact_9_old_Oprod_Oinject, axiom,
    ((![A : list_char, B : produc1257910179t_char > option_val, A2 : list_char, B2 : produc1257910179t_char > option_val]: (((produc904988266on_val @ A @ B) = (produc904988266on_val @ A2 @ B2)) = (((A = A2)) & ((B = B2))))))). % old.prod.inject
thf(fact_10_surj__pair, axiom,
    ((![P2 : produc266837688on_val]: (?[X3 : list_char, Y3 : produc1257910179t_char > option_val]: (P2 = (produc904988266on_val @ X3 @ Y3)))))). % surj_pair
thf(fact_11_prod__cases, axiom,
    ((![P : produc266837688on_val > $o, P2 : produc266837688on_val]: ((![A3 : list_char, B3 : produc1257910179t_char > option_val]: (P @ (produc904988266on_val @ A3 @ B3))) => (P @ P2))))). % prod_cases
thf(fact_12_Pair__inject, axiom,
    ((![A : list_char, B : produc1257910179t_char > option_val, A2 : list_char, B2 : produc1257910179t_char > option_val]: (((produc904988266on_val @ A @ B) = (produc904988266on_val @ A2 @ B2)) => (~ (((A = A2) => (~ ((B = B2)))))))))). % Pair_inject
thf(fact_13_old_Oprod_Oexhaust, axiom,
    ((![Y4 : produc266837688on_val]: (~ ((![A3 : list_char, B3 : produc1257910179t_char > option_val]: (~ ((Y4 = (produc904988266on_val @ A3 @ B3)))))))))). % old.prod.exhaust
thf(fact_14_old_Oprod_Oinducts, axiom,
    ((![P : produc266837688on_val > $o, Prod : produc266837688on_val]: ((![A3 : list_char, B3 : produc1257910179t_char > option_val]: (P @ (produc904988266on_val @ A3 @ B3))) => (P @ Prod))))). % old.prod.inducts
thf(fact_15_empty__upd__none, axiom,
    ((![X4 : nat]: ((fun_up262443479on_val @ (^[X : nat]: none_P1535574167on_val) @ X4 @ none_P1535574167on_val) = (^[X : nat]: none_P1535574167on_val))))). % empty_upd_none
thf(fact_16_not__None__eq, axiom,
    ((![X4 : option_val]: ((~ ((X4 = none_val))) = (?[Y : val]: (X4 = (some_val @ Y))))))). % not_None_eq
thf(fact_17_not__None__eq, axiom,
    ((![X4 : option2118145160on_val]: ((~ ((X4 = none_P1535574167on_val))) = (?[Y : produc266837688on_val]: (X4 = (some_P1299442195on_val @ Y))))))). % not_None_eq
thf(fact_18_not__None__eq, axiom,
    ((![X4 : option_nat]: ((~ ((X4 = none_nat))) = (?[Y : nat]: (X4 = (some_nat @ Y))))))). % not_None_eq
thf(fact_19_not__None__eq, axiom,
    ((![X4 : option_ty]: ((~ ((X4 = none_ty))) = (?[Y : ty]: (X4 = (some_ty @ Y))))))). % not_None_eq
thf(fact_20_not__Some__eq, axiom,
    ((![X4 : option_val]: ((![Y : val]: (~ ((X4 = (some_val @ Y))))) = (X4 = none_val))))). % not_Some_eq
thf(fact_21_not__Some__eq, axiom,
    ((![X4 : option2118145160on_val]: ((![Y : produc266837688on_val]: (~ ((X4 = (some_P1299442195on_val @ Y))))) = (X4 = none_P1535574167on_val))))). % not_Some_eq
thf(fact_22_not__Some__eq, axiom,
    ((![X4 : option_nat]: ((![Y : nat]: (~ ((X4 = (some_nat @ Y))))) = (X4 = none_nat))))). % not_Some_eq
thf(fact_23_not__Some__eq, axiom,
    ((![X4 : option_ty]: ((![Y : ty]: (~ ((X4 = (some_ty @ Y))))) = (X4 = none_ty))))). % not_Some_eq
thf(fact_24_hext__upd__obj, axiom,
    ((![H : nat > option2118145160on_val, A : nat, C : list_char, Fs : produc1257910179t_char > option_val, Fs2 : produc1257910179t_char > option_val]: (((H @ A) = (some_P1299442195on_val @ (produc904988266on_val @ C @ Fs))) => (hext @ H @ (fun_up262443479on_val @ H @ A @ (some_P1299442195on_val @ (produc904988266on_val @ C @ Fs2)))))))). % hext_upd_obj
thf(fact_25_hextI, axiom,
    ((![H : nat > option2118145160on_val, H2 : nat > option2118145160on_val]: ((![A3 : nat, C2 : list_char, Fs3 : produc1257910179t_char > option_val]: (((H @ A3) = (some_P1299442195on_val @ (produc904988266on_val @ C2 @ Fs3))) => (?[Fs4 : produc1257910179t_char > option_val]: ((H2 @ A3) = (some_P1299442195on_val @ (produc904988266on_val @ C2 @ Fs4)))))) => (hext @ H @ H2))))). % hextI
thf(fact_26_hext__def, axiom,
    ((hext = (^[H3 : nat > option2118145160on_val]: (^[H4 : nat > option2118145160on_val]: (![A4 : nat]: (![C3 : list_char]: (![Fs5 : produc1257910179t_char > option_val]: ((((H3 @ A4) = (some_P1299442195on_val @ (produc904988266on_val @ C3 @ Fs5)))) => ((?[Fs6 : produc1257910179t_char > option_val]: ((H4 @ A4) = (some_P1299442195on_val @ (produc904988266on_val @ C3 @ Fs6)))))))))))))). % hext_def
thf(fact_27_hext__objD, axiom,
    ((![H : nat > option2118145160on_val, H2 : nat > option2118145160on_val, A : nat, C : list_char, Fs : produc1257910179t_char > option_val]: ((hext @ H @ H2) => (((H @ A) = (some_P1299442195on_val @ (produc904988266on_val @ C @ Fs))) => (?[Fs7 : produc1257910179t_char > option_val]: ((H2 @ A) = (some_P1299442195on_val @ (produc904988266on_val @ C @ Fs7))))))))). % hext_objD
thf(fact_28_hext__refl, axiom,
    ((![H : nat > option2118145160on_val]: (hext @ H @ H)))). % hext_refl
thf(fact_29_map__upd__nonempty, axiom,
    ((![T : nat > option2118145160on_val, K : nat, X4 : produc266837688on_val]: (~ (((fun_up262443479on_val @ T @ K @ (some_P1299442195on_val @ X4)) = (^[X : nat]: none_P1535574167on_val))))))). % map_upd_nonempty
thf(fact_30_mem__Collect__eq, axiom,
    ((![A : produc266837688on_val, P : produc266837688on_val > $o]: ((member1296415951on_val @ A @ (collec1229699853on_val @ P)) = (P @ A))))). % mem_Collect_eq
thf(fact_31_Collect__mem__eq, axiom,
    ((![A5 : set_Pr2075231726on_val]: ((collec1229699853on_val @ (^[X : produc266837688on_val]: (member1296415951on_val @ X @ A5))) = A5)))). % Collect_mem_eq
thf(fact_32_option_Oinject, axiom,
    ((![X2 : produc266837688on_val, Y2 : produc266837688on_val]: (((some_P1299442195on_val @ X2) = (some_P1299442195on_val @ Y2)) = (X2 = Y2))))). % option.inject
thf(fact_33_option_Oinject, axiom,
    ((![X2 : nat, Y2 : nat]: (((some_nat @ X2) = (some_nat @ Y2)) = (X2 = Y2))))). % option.inject
thf(fact_34_option_Oinject, axiom,
    ((![X2 : ty, Y2 : ty]: (((some_ty @ X2) = (some_ty @ Y2)) = (X2 = Y2))))). % option.inject
thf(fact_35_new__Addr__SomeD, axiom,
    ((![H : nat > option2118145160on_val, A : nat]: (((new_Addr @ H) = (some_nat @ A)) => ((H @ A) = none_P1535574167on_val))))). % new_Addr_SomeD
thf(fact_36_hext__new, axiom,
    ((![H : nat > option2118145160on_val, A : nat, X4 : produc266837688on_val]: (((H @ A) = none_P1535574167on_val) => (hext @ H @ (fun_up262443479on_val @ H @ A @ (some_P1299442195on_val @ X4))))))). % hext_new
thf(fact_37_hext__trans, axiom,
    ((![H : nat > option2118145160on_val, H2 : nat > option2118145160on_val, H5 : nat > option2118145160on_val]: ((hext @ H @ H2) => ((hext @ H2 @ H5) => (hext @ H @ H5)))))). % hext_trans
thf(fact_38_combine__options__cases, axiom,
    ((![X4 : option_val, P : option_val > option_val > $o, Y4 : option_val]: (((X4 = none_val) => (P @ X4 @ Y4)) => (((Y4 = none_val) => (P @ X4 @ Y4)) => ((![A3 : val, B3 : val]: ((X4 = (some_val @ A3)) => ((Y4 = (some_val @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_39_combine__options__cases, axiom,
    ((![X4 : option_val, P : option_val > option_nat > $o, Y4 : option_nat]: (((X4 = none_val) => (P @ X4 @ Y4)) => (((Y4 = none_nat) => (P @ X4 @ Y4)) => ((![A3 : val, B3 : nat]: ((X4 = (some_val @ A3)) => ((Y4 = (some_nat @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_40_combine__options__cases, axiom,
    ((![X4 : option_val, P : option_val > option_ty > $o, Y4 : option_ty]: (((X4 = none_val) => (P @ X4 @ Y4)) => (((Y4 = none_ty) => (P @ X4 @ Y4)) => ((![A3 : val, B3 : ty]: ((X4 = (some_val @ A3)) => ((Y4 = (some_ty @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_41_combine__options__cases, axiom,
    ((![X4 : option_nat, P : option_nat > option_val > $o, Y4 : option_val]: (((X4 = none_nat) => (P @ X4 @ Y4)) => (((Y4 = none_val) => (P @ X4 @ Y4)) => ((![A3 : nat, B3 : val]: ((X4 = (some_nat @ A3)) => ((Y4 = (some_val @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_42_combine__options__cases, axiom,
    ((![X4 : option_nat, P : option_nat > option_nat > $o, Y4 : option_nat]: (((X4 = none_nat) => (P @ X4 @ Y4)) => (((Y4 = none_nat) => (P @ X4 @ Y4)) => ((![A3 : nat, B3 : nat]: ((X4 = (some_nat @ A3)) => ((Y4 = (some_nat @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_43_combine__options__cases, axiom,
    ((![X4 : option_nat, P : option_nat > option_ty > $o, Y4 : option_ty]: (((X4 = none_nat) => (P @ X4 @ Y4)) => (((Y4 = none_ty) => (P @ X4 @ Y4)) => ((![A3 : nat, B3 : ty]: ((X4 = (some_nat @ A3)) => ((Y4 = (some_ty @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_44_combine__options__cases, axiom,
    ((![X4 : option_ty, P : option_ty > option_val > $o, Y4 : option_val]: (((X4 = none_ty) => (P @ X4 @ Y4)) => (((Y4 = none_val) => (P @ X4 @ Y4)) => ((![A3 : ty, B3 : val]: ((X4 = (some_ty @ A3)) => ((Y4 = (some_val @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_45_combine__options__cases, axiom,
    ((![X4 : option_ty, P : option_ty > option_nat > $o, Y4 : option_nat]: (((X4 = none_ty) => (P @ X4 @ Y4)) => (((Y4 = none_nat) => (P @ X4 @ Y4)) => ((![A3 : ty, B3 : nat]: ((X4 = (some_ty @ A3)) => ((Y4 = (some_nat @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_46_combine__options__cases, axiom,
    ((![X4 : option_ty, P : option_ty > option_ty > $o, Y4 : option_ty]: (((X4 = none_ty) => (P @ X4 @ Y4)) => (((Y4 = none_ty) => (P @ X4 @ Y4)) => ((![A3 : ty, B3 : ty]: ((X4 = (some_ty @ A3)) => ((Y4 = (some_ty @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_47_combine__options__cases, axiom,
    ((![X4 : option_val, P : option_val > option2118145160on_val > $o, Y4 : option2118145160on_val]: (((X4 = none_val) => (P @ X4 @ Y4)) => (((Y4 = none_P1535574167on_val) => (P @ X4 @ Y4)) => ((![A3 : val, B3 : produc266837688on_val]: ((X4 = (some_val @ A3)) => ((Y4 = (some_P1299442195on_val @ B3)) => (P @ X4 @ Y4)))) => (P @ X4 @ Y4))))))). % combine_options_cases
thf(fact_48_split__option__all, axiom,
    (((^[P3 : option_val > $o]: (![X5 : option_val]: (P3 @ X5))) = (^[P4 : option_val > $o]: (((P4 @ none_val)) & ((![X : val]: (P4 @ (some_val @ X))))))))). % split_option_all
thf(fact_49_split__option__all, axiom,
    (((^[P3 : option2118145160on_val > $o]: (![X5 : option2118145160on_val]: (P3 @ X5))) = (^[P4 : option2118145160on_val > $o]: (((P4 @ none_P1535574167on_val)) & ((![X : produc266837688on_val]: (P4 @ (some_P1299442195on_val @ X))))))))). % split_option_all
thf(fact_50_split__option__all, axiom,
    (((^[P3 : option_nat > $o]: (![X5 : option_nat]: (P3 @ X5))) = (^[P4 : option_nat > $o]: (((P4 @ none_nat)) & ((![X : nat]: (P4 @ (some_nat @ X))))))))). % split_option_all
thf(fact_51_split__option__all, axiom,
    (((^[P3 : option_ty > $o]: (![X5 : option_ty]: (P3 @ X5))) = (^[P4 : option_ty > $o]: (((P4 @ none_ty)) & ((![X : ty]: (P4 @ (some_ty @ X))))))))). % split_option_all
thf(fact_52_split__option__ex, axiom,
    (((^[P3 : option_val > $o]: (?[X5 : option_val]: (P3 @ X5))) = (^[P4 : option_val > $o]: (((P4 @ none_val)) | ((?[X : val]: (P4 @ (some_val @ X))))))))). % split_option_ex
thf(fact_53_split__option__ex, axiom,
    (((^[P3 : option2118145160on_val > $o]: (?[X5 : option2118145160on_val]: (P3 @ X5))) = (^[P4 : option2118145160on_val > $o]: (((P4 @ none_P1535574167on_val)) | ((?[X : produc266837688on_val]: (P4 @ (some_P1299442195on_val @ X))))))))). % split_option_ex
thf(fact_54_split__option__ex, axiom,
    (((^[P3 : option_nat > $o]: (?[X5 : option_nat]: (P3 @ X5))) = (^[P4 : option_nat > $o]: (((P4 @ none_nat)) | ((?[X : nat]: (P4 @ (some_nat @ X))))))))). % split_option_ex
thf(fact_55_split__option__ex, axiom,
    (((^[P3 : option_ty > $o]: (?[X5 : option_ty]: (P3 @ X5))) = (^[P4 : option_ty > $o]: (((P4 @ none_ty)) | ((?[X : ty]: (P4 @ (some_ty @ X))))))))). % split_option_ex
thf(fact_56_option_Oinducts, axiom,
    ((![P : option_val > $o, Option : option_val]: ((P @ none_val) => ((![X3 : val]: (P @ (some_val @ X3))) => (P @ Option)))))). % option.inducts
thf(fact_57_option_Oinducts, axiom,
    ((![P : option2118145160on_val > $o, Option : option2118145160on_val]: ((P @ none_P1535574167on_val) => ((![X3 : produc266837688on_val]: (P @ (some_P1299442195on_val @ X3))) => (P @ Option)))))). % option.inducts
thf(fact_58_option_Oinducts, axiom,
    ((![P : option_nat > $o, Option : option_nat]: ((P @ none_nat) => ((![X3 : nat]: (P @ (some_nat @ X3))) => (P @ Option)))))). % option.inducts
thf(fact_59_option_Oinducts, axiom,
    ((![P : option_ty > $o, Option : option_ty]: ((P @ none_ty) => ((![X3 : ty]: (P @ (some_ty @ X3))) => (P @ Option)))))). % option.inducts
thf(fact_60_option_Oexhaust, axiom,
    ((![Y4 : option_val]: ((~ ((Y4 = none_val))) => (~ ((![X22 : val]: (~ ((Y4 = (some_val @ X22))))))))))). % option.exhaust
thf(fact_61_option_Oexhaust, axiom,
    ((![Y4 : option2118145160on_val]: ((~ ((Y4 = none_P1535574167on_val))) => (~ ((![X22 : produc266837688on_val]: (~ ((Y4 = (some_P1299442195on_val @ X22))))))))))). % option.exhaust
thf(fact_62_option_Oexhaust, axiom,
    ((![Y4 : option_nat]: ((~ ((Y4 = none_nat))) => (~ ((![X22 : nat]: (~ ((Y4 = (some_nat @ X22))))))))))). % option.exhaust
thf(fact_63_option_Oexhaust, axiom,
    ((![Y4 : option_ty]: ((~ ((Y4 = none_ty))) => (~ ((![X22 : ty]: (~ ((Y4 = (some_ty @ X22))))))))))). % option.exhaust
thf(fact_64_option_OdiscI, axiom,
    ((![Option : option_val, X2 : val]: ((Option = (some_val @ X2)) => (~ ((Option = none_val))))))). % option.discI
thf(fact_65_option_OdiscI, axiom,
    ((![Option : option2118145160on_val, X2 : produc266837688on_val]: ((Option = (some_P1299442195on_val @ X2)) => (~ ((Option = none_P1535574167on_val))))))). % option.discI
thf(fact_66_option_OdiscI, axiom,
    ((![Option : option_nat, X2 : nat]: ((Option = (some_nat @ X2)) => (~ ((Option = none_nat))))))). % option.discI
thf(fact_67_option_OdiscI, axiom,
    ((![Option : option_ty, X2 : ty]: ((Option = (some_ty @ X2)) => (~ ((Option = none_ty))))))). % option.discI
thf(fact_68_option_Odistinct_I1_J, axiom,
    ((![X2 : val]: (~ ((none_val = (some_val @ X2))))))). % option.distinct(1)
thf(fact_69_option_Odistinct_I1_J, axiom,
    ((![X2 : produc266837688on_val]: (~ ((none_P1535574167on_val = (some_P1299442195on_val @ X2))))))). % option.distinct(1)
thf(fact_70_option_Odistinct_I1_J, axiom,
    ((![X2 : nat]: (~ ((none_nat = (some_nat @ X2))))))). % option.distinct(1)
thf(fact_71_option_Odistinct_I1_J, axiom,
    ((![X2 : ty]: (~ ((none_ty = (some_ty @ X2))))))). % option.distinct(1)
thf(fact_72_map__upd__Some__unfold, axiom,
    ((![M : nat > option2118145160on_val, A : nat, B : produc266837688on_val, X4 : nat, Y4 : produc266837688on_val]: (((fun_up262443479on_val @ M @ A @ (some_P1299442195on_val @ B) @ X4) = (some_P1299442195on_val @ Y4)) = (((((X4 = A)) & ((B = Y4)))) | ((((~ ((X4 = A)))) & (((M @ X4) = (some_P1299442195on_val @ Y4)))))))))). % map_upd_Some_unfold
thf(fact_73_map__upd__triv, axiom,
    ((![T : nat > option2118145160on_val, K : nat, X4 : produc266837688on_val]: (((T @ K) = (some_P1299442195on_val @ X4)) => ((fun_up262443479on_val @ T @ K @ (some_P1299442195on_val @ X4)) = T))))). % map_upd_triv
thf(fact_74_map__upd__eqD1, axiom,
    ((![M : nat > option2118145160on_val, A : nat, X4 : produc266837688on_val, N : nat > option2118145160on_val, Y4 : produc266837688on_val]: (((fun_up262443479on_val @ M @ A @ (some_P1299442195on_val @ X4)) = (fun_up262443479on_val @ N @ A @ (some_P1299442195on_val @ Y4))) => (X4 = Y4))))). % map_upd_eqD1
thf(fact_75_exp_Oinject_I1_J, axiom,
    ((![X1 : list_char, Y1 : list_char]: (((new_list_char @ X1) = (new_list_char @ Y1)) = (X1 = Y1))))). % exp.inject(1)
thf(fact_76_fun__upd__apply, axiom,
    ((fun_up262443479on_val = (^[F : nat > option2118145160on_val]: (^[X : nat]: (^[Y : option2118145160on_val]: (^[Z : nat]: (if_opt451925058on_val @ (Z = X) @ Y @ (F @ Z))))))))). % fun_upd_apply
thf(fact_77_fun__upd__triv, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat]: ((fun_up262443479on_val @ F2 @ X4 @ (F2 @ X4)) = F2)))). % fun_upd_triv
thf(fact_78_fun__upd__upd, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat, Y4 : option2118145160on_val, Z2 : option2118145160on_val]: ((fun_up262443479on_val @ (fun_up262443479on_val @ F2 @ X4 @ Y4) @ X4 @ Z2) = (fun_up262443479on_val @ F2 @ X4 @ Z2))))). % fun_upd_upd
thf(fact_79_WTrt__hext__mono, axiom,
    ((![P : list_P1234162913t_char, H : nat > option2118145160on_val, E : list_char > option_ty, E2 : exp_list_char, T2 : ty, H2 : nat > option2118145160on_val]: ((wTrt @ P @ H @ E @ E2 @ T2) => ((hext @ H @ H2) => (wTrt @ P @ H2 @ E @ E2 @ T2)))))). % WTrt_hext_mono
thf(fact_80_same__fstI, axiom,
    ((![P : list_char > $o, X4 : list_char, Y5 : produc1257910179t_char > option_val, Y4 : produc1257910179t_char > option_val, R : list_char > set_Pr227219079on_val]: ((P @ X4) => ((member548035792on_val @ (produc797901719on_val @ Y5 @ Y4) @ (R @ X4)) => (member197592058on_val @ (produc881885833on_val @ (produc904988266on_val @ X4 @ Y5) @ (produc904988266on_val @ X4 @ Y4)) @ (same_f2003279573on_val @ P @ R))))))). % same_fstI
thf(fact_81_fun__upd__def, axiom,
    ((fun_up262443479on_val = (^[F : nat > option2118145160on_val]: (^[A4 : nat]: (^[B4 : option2118145160on_val]: (^[X : nat]: (if_opt451925058on_val @ (X = A4) @ B4 @ (F @ X))))))))). % fun_upd_def
thf(fact_82_fun__upd__eqD, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat, Y4 : option2118145160on_val, G : nat > option2118145160on_val, Z2 : option2118145160on_val]: (((fun_up262443479on_val @ F2 @ X4 @ Y4) = (fun_up262443479on_val @ G @ X4 @ Z2)) => (Y4 = Z2))))). % fun_upd_eqD
thf(fact_83_fun__upd__idem, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat, Y4 : option2118145160on_val]: (((F2 @ X4) = Y4) => ((fun_up262443479on_val @ F2 @ X4 @ Y4) = F2))))). % fun_upd_idem
thf(fact_84_fun__upd__same, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat, Y4 : option2118145160on_val]: ((fun_up262443479on_val @ F2 @ X4 @ Y4 @ X4) = Y4)))). % fun_upd_same
thf(fact_85_fun__upd__other, axiom,
    ((![Z2 : nat, X4 : nat, F2 : nat > option2118145160on_val, Y4 : option2118145160on_val]: ((~ ((Z2 = X4))) => ((fun_up262443479on_val @ F2 @ X4 @ Y4 @ Z2) = (F2 @ Z2)))))). % fun_upd_other
thf(fact_86_fun__upd__twist, axiom,
    ((![A : nat, C4 : nat, M : nat > option2118145160on_val, B : option2118145160on_val, D : option2118145160on_val]: ((~ ((A = C4))) => ((fun_up262443479on_val @ (fun_up262443479on_val @ M @ A @ B) @ C4 @ D) = (fun_up262443479on_val @ (fun_up262443479on_val @ M @ C4 @ D) @ A @ B)))))). % fun_upd_twist
thf(fact_87_fun__upd__idem__iff, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat, Y4 : option2118145160on_val]: (((fun_up262443479on_val @ F2 @ X4 @ Y4) = F2) = ((F2 @ X4) = Y4))))). % fun_upd_idem_iff
thf(fact_88_oconf__init__fields, axiom,
    ((![P : list_P1234162913t_char, C : list_char, FDTs : list_P1991792281har_ty, H : nat > option2118145160on_val]: ((fields1441617180t_char @ P @ C @ FDTs) => (oconf_454120169t_char @ P @ H @ (produc904988266on_val @ C @ (init_fields @ FDTs))))))). % oconf_init_fields
thf(fact_89_Pair__def, axiom,
    ((produc904988266on_val = (^[A4 : list_char]: (^[B4 : produc1257910179t_char > option_val]: (produc1757249884on_val @ (produc1747120315on_val @ A4 @ B4))))))). % Pair_def
thf(fact_90_has__fields__fun, axiom,
    ((![P : list_P1234162913t_char, C : list_char, FDTs : list_P1991792281har_ty, FDTs2 : list_P1991792281har_ty]: ((fields1441617180t_char @ P @ C @ FDTs) => ((fields1441617180t_char @ P @ C @ FDTs2) => (FDTs2 = FDTs)))))). % has_fields_fun
thf(fact_91_lconf__def, axiom,
    ((lconf_485928294t_char = (^[P4 : list_P1234162913t_char]: (^[H3 : nat > option2118145160on_val]: (^[L2 : list_char > option_val]: (^[E3 : list_char > option_ty]: (![V : list_char]: (![V2 : val]: ((((L2 @ V) = (some_val @ V2))) => ((?[T3 : ty]: ((((E3 @ V) = (some_ty @ T3))) & ((conf_P93989998t_char @ P4 @ H3 @ V2 @ T3))))))))))))))). % lconf_def
thf(fact_92_lconf__upd, axiom,
    ((![P : list_P1234162913t_char, H : nat > option2118145160on_val, L : list_char > option_val, E : list_char > option_ty, V3 : val, T2 : ty, V4 : list_char]: ((lconf_485928294t_char @ P @ H @ L @ E) => ((conf_P93989998t_char @ P @ H @ V3 @ T2) => (((E @ V4) = (some_ty @ T2)) => (lconf_485928294t_char @ P @ H @ (fun_up1252458416on_val @ L @ V4 @ (some_val @ V3)) @ E))))))). % lconf_upd
thf(fact_93_lconf__upd2, axiom,
    ((![P : list_P1234162913t_char, H : nat > option2118145160on_val, L : list_char > option_val, E : list_char > option_ty, V3 : val, T2 : ty, V4 : list_char]: ((lconf_485928294t_char @ P @ H @ L @ E) => ((conf_P93989998t_char @ P @ H @ V3 @ T2) => (lconf_485928294t_char @ P @ H @ (fun_up1252458416on_val @ L @ V4 @ (some_val @ V3)) @ (fun_up9191ion_ty @ E @ V4 @ (some_ty @ T2)))))))). % lconf_upd2
thf(fact_94_preallocated__new, axiom,
    ((![H : nat > option2118145160on_val, A : nat, X4 : produc266837688on_val]: ((preallocated @ H) => (((H @ A) = none_P1535574167on_val) => (preallocated @ (fun_up262443479on_val @ H @ A @ (some_P1299442195on_val @ X4)))))))). % preallocated_new
thf(fact_95_preallocated__upd__obj, axiom,
    ((![H : nat > option2118145160on_val, A : nat, C : list_char, Fs : produc1257910179t_char > option_val, Fs2 : produc1257910179t_char > option_val]: ((preallocated @ H) => (((H @ A) = (some_P1299442195on_val @ (produc904988266on_val @ C @ Fs))) => (preallocated @ (fun_up262443479on_val @ H @ A @ (some_P1299442195on_val @ (produc904988266on_val @ C @ Fs2))))))))). % preallocated_upd_obj
thf(fact_96_preallocated__hext, axiom,
    ((![H : nat > option2118145160on_val, H2 : nat > option2118145160on_val]: ((preallocated @ H) => ((hext @ H @ H2) => (preallocated @ H2)))))). % preallocated_hext
thf(fact_97_fields__def2, axiom,
    ((![P : list_P1234162913t_char, C : list_char, FDTs : list_P1991792281har_ty]: ((fields1441617180t_char @ P @ C @ FDTs) => ((fields1811926268t_char @ P @ C) = FDTs))))). % fields_def2
thf(fact_98_hext__typeof__mono, axiom,
    ((![H : nat > option2118145160on_val, H2 : nat > option2118145160on_val, V3 : val, T2 : ty]: ((hext @ H @ H2) => (((typeof_h @ H @ V3) = (some_ty @ T2)) => ((typeof_h @ H2 @ V3) = (some_ty @ T2))))))). % hext_typeof_mono
thf(fact_99_typeof__lit__typeof, axiom,
    ((![V3 : val, T2 : ty, H : nat > option2118145160on_val]: (((typeof_h @ (^[X : nat]: none_P1535574167on_val) @ V3) = (some_ty @ T2)) => ((typeof_h @ H @ V3) = (some_ty @ T2)))))). % typeof_lit_typeof
thf(fact_100_has__field__code, axiom,
    ((![P : list_P1234162913t_char, C : list_char, FDTs : list_P1991792281har_ty, F3 : list_char, D2 : list_char, T2 : ty]: ((fields1441617180t_char @ P @ C @ FDTs) => (((map_of2035691063har_ty @ FDTs @ (produc1304532571t_char @ F3 @ D2)) = (some_ty @ T2)) => (has_fi599584195t_char @ P @ C @ F3 @ T2 @ D2)))))). % has_field_code
thf(fact_101_has__field__def, axiom,
    ((has_fi599584195t_char = (^[P4 : list_P1234162913t_char]: (^[C3 : list_char]: (^[F4 : list_char]: (^[T3 : ty]: (^[D3 : list_char]: (?[FDTs3 : list_P1991792281har_ty]: (((fields1441617180t_char @ P4 @ C3 @ FDTs3)) & (((map_of2035691063har_ty @ FDTs3 @ (produc1304532571t_char @ F4 @ D3)) = (some_ty @ T3))))))))))))). % has_field_def
thf(fact_102_map__le__imp__upd__le, axiom,
    ((![M1 : nat > option2118145160on_val, M2 : nat > option2118145160on_val, X4 : nat, Y4 : produc266837688on_val]: ((map_le931214383on_val @ M1 @ M2) => (map_le931214383on_val @ (fun_up262443479on_val @ M1 @ X4 @ none_P1535574167on_val) @ (fun_up262443479on_val @ M2 @ X4 @ (some_P1299442195on_val @ Y4))))))). % map_le_imp_upd_le
thf(fact_103_map__le__imp__upd__le, axiom,
    ((![M1 : list_char > option_ty, M2 : list_char > option_ty, X4 : list_char, Y4 : ty]: ((map_le_list_char_ty @ M1 @ M2) => (map_le_list_char_ty @ (fun_up9191ion_ty @ M1 @ X4 @ none_ty) @ (fun_up9191ion_ty @ M2 @ X4 @ (some_ty @ Y4))))))). % map_le_imp_upd_le
thf(fact_104_natural_Oinject, axiom,
    ((![Natural : code_natural, Natural2 : code_natural]: (((code_Suc @ Natural) = (code_Suc @ Natural2)) = (Natural = Natural2))))). % natural.inject
thf(fact_105_map__le__empty, axiom,
    ((![G : list_char > option_ty]: (map_le_list_char_ty @ (^[X : list_char]: none_ty) @ G)))). % map_le_empty
thf(fact_106_WTrt__env__mono, axiom,
    ((![P : list_P1234162913t_char, H : nat > option2118145160on_val, E : list_char > option_ty, E2 : exp_list_char, T2 : ty, E4 : list_char > option_ty]: ((wTrt @ P @ H @ E @ E2 @ T2) => ((map_le_list_char_ty @ E @ E4) => (wTrt @ P @ H @ E4 @ E2 @ T2)))))). % WTrt_env_mono
thf(fact_107_map__le__refl, axiom,
    ((![F2 : list_char > option_ty]: (map_le_list_char_ty @ F2 @ F2)))). % map_le_refl
thf(fact_108_map__le__trans, axiom,
    ((![M1 : list_char > option_ty, M2 : list_char > option_ty, M3 : list_char > option_ty]: ((map_le_list_char_ty @ M1 @ M2) => ((map_le_list_char_ty @ M2 @ M3) => (map_le_list_char_ty @ M1 @ M3)))))). % map_le_trans
thf(fact_109_map__le__antisym, axiom,
    ((![F2 : list_char > option_ty, G : list_char > option_ty]: ((map_le_list_char_ty @ F2 @ G) => ((map_le_list_char_ty @ G @ F2) => (F2 = G)))))). % map_le_antisym
thf(fact_110_map__le__upd, axiom,
    ((![F2 : list_char > option_ty, G : list_char > option_ty, A : list_char, B : option_ty]: ((map_le_list_char_ty @ F2 @ G) => (map_le_list_char_ty @ (fun_up9191ion_ty @ F2 @ A @ B) @ (fun_up9191ion_ty @ G @ A @ B)))))). % map_le_upd
thf(fact_111_map__le__upd, axiom,
    ((![F2 : nat > option2118145160on_val, G : nat > option2118145160on_val, A : nat, B : option2118145160on_val]: ((map_le931214383on_val @ F2 @ G) => (map_le931214383on_val @ (fun_up262443479on_val @ F2 @ A @ B) @ (fun_up262443479on_val @ G @ A @ B)))))). % map_le_upd
thf(fact_112_upd__None__map__le, axiom,
    ((![F2 : list_char > option_ty, X4 : list_char]: (map_le_list_char_ty @ (fun_up9191ion_ty @ F2 @ X4 @ none_ty) @ F2)))). % upd_None_map_le
thf(fact_113_upd__None__map__le, axiom,
    ((![F2 : nat > option2118145160on_val, X4 : nat]: (map_le931214383on_val @ (fun_up262443479on_val @ F2 @ X4 @ none_P1535574167on_val) @ F2)))). % upd_None_map_le
thf(fact_114_fields__def, axiom,
    ((fields1811926268t_char = (^[P4 : list_P1234162913t_char]: (^[C3 : list_char]: (the_li2019826130har_ty @ (fields1441617180t_char @ P4 @ C3))))))). % fields_def
thf(fact_115_option_Odisc__eq__case_I1_J, axiom,
    ((![Option : option2118145160on_val]: ((Option = none_P1535574167on_val) = (case_o1187854213on_val @ $true @ (^[Uu : produc266837688on_val]: $false) @ Option))))). % option.disc_eq_case(1)
thf(fact_116_option_Odisc__eq__case_I1_J, axiom,
    ((![Option : option_val]: ((Option = none_val) = (case_option_o_val @ $true @ (^[Uu : val]: $false) @ Option))))). % option.disc_eq_case(1)
thf(fact_117_option_Odisc__eq__case_I2_J, axiom,
    ((![Option : option2118145160on_val]: ((~ ((Option = none_P1535574167on_val))) = (case_o1187854213on_val @ $false @ (^[Uu : produc266837688on_val]: $true) @ Option))))). % option.disc_eq_case(2)
thf(fact_118_option_Odisc__eq__case_I2_J, axiom,
    ((![Option : option_val]: ((~ ((Option = none_val))) = (case_option_o_val @ $false @ (^[Uu : val]: $true) @ Option))))). % option.disc_eq_case(2)
thf(fact_119_case__optionE, axiom,
    ((![P : $o, Q : val > $o, X4 : option_val]: ((case_option_o_val @ P @ Q @ X4) => (((X4 = none_val) => (~ (P))) => (~ ((![Y3 : val]: ((X4 = (some_val @ Y3)) => (~ ((Q @ Y3)))))))))))). % case_optionE
thf(fact_120_case__optionE, axiom,
    ((![P : $o, Q : produc266837688on_val > $o, X4 : option2118145160on_val]: ((case_o1187854213on_val @ P @ Q @ X4) => (((X4 = none_P1535574167on_val) => (~ (P))) => (~ ((![Y3 : produc266837688on_val]: ((X4 = (some_P1299442195on_val @ Y3)) => (~ ((Q @ Y3)))))))))))). % case_optionE
thf(fact_121_case__optionE, axiom,
    ((![P : $o, Q : nat > $o, X4 : option_nat]: ((case_option_o_nat @ P @ Q @ X4) => (((X4 = none_nat) => (~ (P))) => (~ ((![Y3 : nat]: ((X4 = (some_nat @ Y3)) => (~ ((Q @ Y3)))))))))))). % case_optionE
thf(fact_122_case__optionE, axiom,
    ((![P : $o, Q : ty > $o, X4 : option_ty]: ((case_option_o_ty @ P @ Q @ X4) => (((X4 = none_ty) => (~ (P))) => (~ ((![Y3 : ty]: ((X4 = (some_ty @ Y3)) => (~ ((Q @ Y3)))))))))))). % case_optionE
thf(fact_123_combine__options__def, axiom,
    ((combin1801280889on_val = (^[F : produc266837688on_val > produc266837688on_val > produc266837688on_val]: (^[X : option2118145160on_val]: (^[Y : option2118145160on_val]: (case_o815592781on_val @ Y @ (^[Z : produc266837688on_val]: (case_o815592781on_val @ (some_P1299442195on_val @ Z) @ (^[Aa : produc266837688on_val]: (some_P1299442195on_val @ (F @ Z @ Aa))) @ Y)) @ X))))))). % combine_options_def
thf(fact_124_combine__options__def, axiom,
    ((combine_options_nat = (^[F : nat > nat > nat]: (^[X : option_nat]: (^[Y : option_nat]: (case_o1104735357at_nat @ Y @ (^[Z : nat]: (case_o1104735357at_nat @ (some_nat @ Z) @ (^[Aa : nat]: (some_nat @ (F @ Z @ Aa))) @ Y)) @ X))))))). % combine_options_def
thf(fact_125_combine__options__def, axiom,
    ((combine_options_ty = (^[F : ty > ty > ty]: (^[X : option_ty]: (^[Y : option_ty]: (case_o105137099_ty_ty @ Y @ (^[Z : ty]: (case_o105137099_ty_ty @ (some_ty @ Z) @ (^[Aa : ty]: (some_ty @ (F @ Z @ Aa))) @ Y)) @ X))))))). % combine_options_def
thf(fact_126_combine__options__simps_I3_J, axiom,
    ((![F2 : produc266837688on_val > produc266837688on_val > produc266837688on_val, A : produc266837688on_val, B : produc266837688on_val]: ((combin1801280889on_val @ F2 @ (some_P1299442195on_val @ A) @ (some_P1299442195on_val @ B)) = (some_P1299442195on_val @ (F2 @ A @ B)))))). % combine_options_simps(3)
thf(fact_127_combine__options__simps_I3_J, axiom,
    ((![F2 : nat > nat > nat, A : nat, B : nat]: ((combine_options_nat @ F2 @ (some_nat @ A) @ (some_nat @ B)) = (some_nat @ (F2 @ A @ B)))))). % combine_options_simps(3)
thf(fact_128_combine__options__simps_I3_J, axiom,
    ((![F2 : ty > ty > ty, A : ty, B : ty]: ((combine_options_ty @ F2 @ (some_ty @ A) @ (some_ty @ B)) = (some_ty @ (F2 @ A @ B)))))). % combine_options_simps(3)
thf(fact_129_combine__options__simps_I2_J, axiom,
    ((![F2 : produc266837688on_val > produc266837688on_val > produc266837688on_val, X4 : option2118145160on_val]: ((combin1801280889on_val @ F2 @ X4 @ none_P1535574167on_val) = X4)))). % combine_options_simps(2)
thf(fact_130_combine__options__simps_I2_J, axiom,
    ((![F2 : val > val > val, X4 : option_val]: ((combine_options_val @ F2 @ X4 @ none_val) = X4)))). % combine_options_simps(2)
thf(fact_131_combine__options__simps_I1_J, axiom,
    ((![F2 : produc266837688on_val > produc266837688on_val > produc266837688on_val, Y4 : option2118145160on_val]: ((combin1801280889on_val @ F2 @ none_P1535574167on_val @ Y4) = Y4)))). % combine_options_simps(1)
thf(fact_132_combine__options__simps_I1_J, axiom,
    ((![F2 : val > val > val, Y4 : option_val]: ((combine_options_val @ F2 @ none_val @ Y4) = Y4)))). % combine_options_simps(1)

% Helper facts (3)
thf(help_If_3_1_If_001t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J_T, axiom,
    ((![P : $o]: ((P = $true) | (P = $false))))).
thf(help_If_2_1_If_001t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J_T, axiom,
    ((![X4 : option2118145160on_val, Y4 : option2118145160on_val]: ((if_opt451925058on_val @ $false @ X4 @ Y4) = Y4)))).
thf(help_If_1_1_If_001t__Option__Ooption_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_M_062_It__Product____Type__Oprod_It__List__Olist_It__String__Ochar_J_Mt__List__Olist_It__String__Ochar_J_J_Mt__Option__Ooption_It__Value__Oval_J_J_J_J_T, axiom,
    ((![X4 : option2118145160on_val, Y4 : option2118145160on_val]: ((if_opt451925058on_val @ $true @ X4 @ Y4) = X4)))).

% Conjectures (1)
thf(conj_0, conjecture,
    ((lconf_485928294t_char @ p @ h_a @ la @ e))).
