Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

6i8TkDTiIH0

Trying to Calculate AMA

Recommended Posts

Hello,

 

im trying to calculate the AMA but iam not quite sure if i understand the calculation correctly yet. Till now i have calculated SMA, WMA and EMA and wanted to have the AMA too because i think its nice to find out if the market is doing a rallye, crash or is simply movind sidewards..

 

I tried to understand the calculation from here: http://user42.tuxfamily.org/chart/manual/Kaufman-Adaptive-Moving-Average.html#Kaufman-Adaptive-Moving-Average

 

Besides... the JMA was praised here in the forum as the best AMA... while on another site i found that its only calculated over a shorter period of time and therefore its more near at the actual price. Is that correct? So is the JMA only a AMA with less previous prices taken into account so that a smaller AMA will show the same results than the JMA?

 

Anyway... i understand it so that when calculating an EMA for 10 days closing price i would create a AMA for these 10 days too.

 

          abs (close[today] - close[N days ago])
    ER = --------------------------------------
             Sum     abs (close - close[prev])
          past N days

 

So first you have to create the Efficiency ratio. Its the closing price of today minus the closing price before N days, in this case 10. Then take abs from the result which means cutting a possibly negative minus.

Then divide this through the sum of all past 10 days closing prices including the actual one. Multiplied(?) with the abs of actual closeprice minus closeprice of day before.

Then you have the ER.

 

Then calculate alpha with the calculated ER:

alpha = (ER * 0.6015 + 0.0645) ^ 2

 

But i dont see where these numbers are from. Are they hardcoded?

 

The next step is to calc:

 

KAMA = alpha * close + (1-alpha) * KAMA[prev]

 

Which means you need the actual closeprice again and the previous KAMA. If you dont have a previous kama do you use simply the SMA or the mentioned EMA for the actual day and start the next day calculating the KAMA? Similar you do it for an EMA?

 

You see im not quite sure how its calculated. The other MA had better and more explainations. Though they were easier to understand too.

 

Someone can help me here?

 

Thanks!

Share this post


Link to post
Share on other sites

my suggestion is to stay with SMA or XMA.

 

if you don't understand the complications,

it is most likely going to bite you when you are least expected.

 

after all, ma is ma... KISS.

The further you are removed from the raw price,

the further you are from reality.

Share this post


Link to post
Share on other sites

Thanks for your suggestion. But i only want to use the AMA for identifying the kind of direction a price is taking. Its not that i want to use it to specify the price to buy or sell from that. Only to change the trading strategy.

 

But yesterday i found a website that contained a .xls file: Forums - Jurik indicator for Excel

 

I didnt look too far in it but it looks like i shouldnt have trouble creating my own AMA with it. I couldnt mention that yesterday because the admins didnt have put my thread to visible at that point.

 

Thanks!

Share this post


Link to post
Share on other sites

here is the T3 function - maybe somekind usefull adaptive smoothing ...........

call T3Average(value1,Length) in an indicator

 

{ *******************************************************************

 

Function : T3Average

 

Last Edit : 12/14/97 - 05/01/99

 

Provided By : Bob Fulks

Recoded By: : Clyde Lee for speed and really simple function

 

Description : This function is an EasyLanguage version of the

moving average described in the January. 1998 issue of TASC,

p57, "Smoothing Techniques for More Accurate Signals", by Tim

Tillson. It is translated from the MetaStock code presented

in the article. The function was modified by C. Lee to not use

any call to external exponential average function but rather

perform the same operation internally. This saves the

overhead of a bunch of calls to the XAverage function. This

modification increases speed and allows variables as inputs.

 

The variable, "b", is a damping coefficient which is set to

the suggested default value of 0.7. The variable "b" is

substituted for the variable, "a" used in the article since

"a" is a reserved word.

 

The resulting indicator plotting this function appears to

duplicate the results shown in Figure 4 of the article.

 

Damp: A damping factor = any value between +100 and -100:

 

-100 = No damping (with ringing)

0 = Critically damped for a triangle wave.

+100 = Overdamped

 

Lag: The lag in bars is given by:

 

Lag = (Length - 1) * (1 + Damp / 100) / 2

 

The Lag is equal to the lag of an exponential or simple

moving average of the same "Length" when Damp = 0. When

Damp = -100 then Lag = 0 but there is ringing and overshoot

as with a linear regression value.

 

© 2000 Bob Fulks, All rights reserved.

only portion dealing with damp ! ! !

 

********************************************************************}

Inputs: Price(NumericSimple), Period(NumericSimple);

Variables: e1(Price), e2(Price), e3(Price),

e4(Price), e5(Price), e6(Price);

Variables: XAlpha(2/6), XBeta(0), OldPeriod(-999999);

Vars: damp(-70),

b(-0.01 * damp),

aa(b*b), aaa(b*b*b),

c1(-aaa), c2(3*aa+3*aaa),

c3(-6*aa-3*b-3*aaa), c4(1+3*b+aaa+3*aa);

 

If Period<>0 then begin

If Period<>OldPeriod then begin;

XAlpha=(2/(AbsValue(Period)+1));

XBeta=(1-XAlpha);

OldPeriod=Period;

End;

 

e1 = e1*XBeta + Price*Xalpha;

e2 = e2*XBeta + e1 *Xalpha;

e3 = e3*XBeta + e2 *Xalpha;

e4 = e4*XBeta + e3 *Xalpha;

e5 = e5*XBeta + e4 *Xalpha;

e6 = e6*XBeta + e5 *Xalpha;

 

 

T3Average = c1*e6 + c2*e5 + c3*e4 + c4*e3;

End

Else T3Average=Price;

TILLSON'S T3.ELD

Share this post


Link to post
Share on other sites

TkD,

 

Here is some hard easy language that may make it easier for you to find answers to your questions. hth

 

[LegacyColorValue = true]; 

{ Kaufman's Adaptive Moving Average }

inputs:
Price( numericseries ), 
EffRatioLength( numericsimple ), 
FastAvgLength( numericsimple ), { this input assumed to be a constant >= 1 }
SlowAvgLength( numericsimple ) ; { this input assumed to be a constant >= 1 }

{ Eff = Efficiency }

variables:
NetChg( 0 ), 
TotChg( 0 ), 
EffRatio( 0 ), 
ScaledSFSqr( 0 ), 
SlowAvgSF( 2 / ( SlowAvgLength + 1 ) ), 
FastAvgSF( 2 / ( FastAvgLength + 1 ) ), 
SFDiff( FastAvgSF - SlowAvgSF ) ;

{ Eff = Efficiency, SF = Smoothing Factor }

if CurrentBar = 1 then
fKaufmanAMA = Price
else
begin
NetChg = AbsValue( Price - Price[ EffRatioLength ] ) ;
TotChg = Summation( AbsValue( Price - Price[1] ), EffRatioLength ) ;
if TotChg > 0 then
	EffRatio = NetChg / TotChg 
else
	EffRatio = 0 ;
{ note that EffRatio is somewhat similar to RSI }
ScaledSFSqr = Square( SlowAvgSF + EffRatio * SFDiff ) ;
fKaufmanAMA = fKaufmanAMA[1] + ScaledSFSqr * ( Price - fKaufmanAMA[1] ) ;
end ;


{ ** Copyright (c) 1991-2003 TradeStation Technologies, Inc. All rights reserved. ** 
 ** TradeStation reserves the right to modify or overwrite this analysis technique 
    with each release

Share this post


Link to post
Share on other sites

If you'd like a PDF of the original Kaufman paper describing this indicator and its applications, let me know. However, I personally would recommend heeding the advice given by Tams. Keep in mid also that the AMA is an 'old' solution to the problems it addresses, and far more mathematically advanced approaches have subsequently emerged from the fields of signal processing and time series analysis.

 

BlueHorseshoe

Share this post


Link to post
Share on other sites

I managed to create a working version in php now. I tested it with several sets of data and the results matched so im sure i worked correctly.

 

Heres my function in php:

  function bc_kama($average_array, $price_type, $tstf_id, $tsset_id, $tsp_id) {
   global $db;
   $actual_price = $average_array[count($average_array) - 1][$price_type];
   $last_kama = $this->ask_db('trades_stat_average_stats', 'tsset_id_ref = \''. $tsset_id .'\' and tsp_id_ref < \''. $tsp_id .'\'', 'price', 'tsp_id_ref desc', '1');
   if(!isset($last_kama)) return $actual_price;
   $res = '0';
   for($x = 1; $x < count($average_array); $x++) {
     $res = bcadd($res, str_abs(bcsub($average_array[$x][$price_type], $average_array[$x - 1][$price_type])));
   }
   $price_before_average_range_res = $this->ask_db('trades_stat_prices', 'tstf_id_ref = \''. $tstf_id .'\' and tsp_id_ref < \''. $tsp_id .'\'', 'price', 'tsp_id_ref desc', strval(count($average_array)));
   while($row = $db->fetch_array($price_before_average_range_res)){
     $price_before_average_range = $row['price'];
   }
   $res = bcadd($res, str_abs(bcsub($average_array[0][$price_type], $price_before_average_range)));
   return bcadd($last_kama, bcmul(bcpow(bcadd(bcmul(bcdiv(str_abs(bcsub($actual_price, $price_before_average_range)), $res), bcsub('0.6667', '0.0645')), '0.0645'), '2'), bcsub($actual_price, $last_kama)), MONEY_DECIMAL_PLACES);
 }

 

The parameters are: average_array contains a set of the previous prices. Its so many entries long how the range for the average should be.

$price_type is a string giving the type of price for a timeframe because i use more than close price for calculations. For example high or low price too.

The rest are only for database-requests i have to do.

 

First line gives the actual price of that day/timeframe.

Then get the last KAMA-Value from previous timeframe.

If there is not previous KAMA then return the actual (close) price. Thats how kama starts. not like with EMA where you start the first time with SMA-Value.

If there is a previous KAMA then move on by calculating the real kama.

Unfortunately the KAMA needs more than the amount of data the average should be. One entry more. Thats $price_before_average_range_res is needed.

 

Its not the best coding but it works and maybe someone the code helps someone.

 

What MAs are a better solution? I have read here that JMA is better but found on another site that its only a KAMA with less timeframes taken into account.

So what MAs are worth to look into?

I find the website etfhq.com interesting too because of their tests for MAs. They tested the performance of MAs against each other to find out who is performing better for trading.

 

The result in my eyes is that the simple and mostly older MAs have an advantage mostly.

 

Greetings!

Sebastian

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • Date: 18th April 2024. Market News – Stock markets benefit from Dollar correction. Economic Indicators & Central Banks:   Technical buying, bargain hunting, and risk aversion helped Treasuries rally and unwind recent losses. Yields dropped from the recent 2024 highs. Asian stock markets strengthened, as the US Dollar corrected in the wake of comments from Japan’s currency chief Masato Kanda, who said G7 countries continue to stress that excessive swings and disorderly moves in the foreign exchange market were harmful for economies. US Stockpiles expanded to 10-month high. The data overshadowed the impact of geopolitical tensions in the Middle East as traders await Israel’s response to Iran’s unprecedented recent attack. President Joe Biden called for higher tariffs on imports of Chinese steel and aluminum.   Financial Markets Performance:   The USDIndex stumbled, falling to 105.66 at the end of the day from the intraday high of 106.48. It lost ground against most of its G10 peers. There wasn’t much on the calendar to provide new direction. USDJPY lows retesting the 154 bottom! NOT an intervention yet. BoJ/MoF USDJPY intervention happens when there is more than 100+ pip move in seconds, not 50 pips. USOIL slumped by 3% near $82, as US crude inventories rose by 2.7 million barrels last week, hitting the highest level since last June, while gauges of fuel demand declined. Gold strengthened as the dollar weakened and bullion is trading at $2378.44 per ounce. Market Trends:   Wall Street closed in the red after opening with small corrective gains. The NASDAQ underperformed, slumping -1.15%, with the S&P500 -0.58% lower, while the Dow lost -0.12. The Nikkei closed 0.2% higher, the Hang Seng gained more than 1. European and US futures are finding buyers. A gauge of global chip stocks and AI bellwether Nvidia Corp. have both fallen into a technical correction. The TMSC reported its first profit rise in a year, after strong AI demand revived growth at the world’s biggest contract chipmaker. The main chipmaker to Apple Inc. and Nvidia Corp. recorded a 9% rise in net income, beating estimates. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • Date: 17th April 2024. Market News – Appetite for risk-taking remains weak. Economic Indicators & Central Banks:   Stocks, Treasury yields and US Dollar stay firmed. Fed Chair Powell added to the recent sell off. His slightly more hawkish tone further priced out chances for any imminent action and the timing of a cut was pushed out further. He suggested if higher inflation does persist, the Fed will hold rates steady “for as long as needed.” Implied Fed Fund: There remains no real chance for a move on May 1 and at their intraday highs the June implied funds rate future showed only 5 bps, while July reflected only 10 bps. And a full 25 bps was not priced in until November, with 38 bps in cuts seen for 2024. US & EU Economies Diverging: Lagarde says ECB is moving toward rate cuts – if there are no major shocks. UK March CPI inflation falls less than expected. Output price inflation has started to nudge higher, despite another decline in input prices. Together with yesterday’s higher than expected wage numbers, the data will add to the arguments of the hawks at the BoE, which remain very reluctant to contemplate rate cuts. Canada CPI rose 0.6% in March, double the 0.3% February increase BUT core eased. The doors are still open for a possible cut at the next BoC meeting on June 5. IMF revised up its global growth forecast for 2024 with inflation easing, in its new World Economic Outlook. This is consistent with a global soft landing, according to the report. Financial Markets Performance:   USDJPY also inched up to 154.67 on expectations the BoJ will remain accommodative and as the market challenges a perceived 155 red line for MoF intervention. USOIL prices slipped -0.15% to $84.20 per barrel. Gold rose 0.24% to $2389.11 per ounce, a new record closing high as geopolitical risks overshadowed the impacts of rising rates and the stronger dollar. Market Trends:   Wall Street waffled either side of unchanged on the day amid dimming rate cut potential, rising yields, and earnings. The major indexes closed mixed with the Dow up 0.17%, while the S&P500 and NASDAQ lost -0.21% and -0.12%, respectively. Asian stock markets mostly corrected again, with Japanese bourses underperforming and the Nikkei down -1.3%. Mainland China bourses were a notable exception and the CSI 300 rallied 1.4%, but the MSCI Asia Pacific index came close to erasing the gains for this year. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.vvvvvvv
    • Date: 16th April 2024. Market News – Stocks and currencies sell off; USD up. Economic Indicators & Central Banks:   Stocks and currencies sell off, while the US Dollar picks up haven flows. Treasuries yields spiked again to fresh 2024 peaks before paring losses into the close, post, the stronger than expected retail sales eliciting a broad sell off in the markets. Rates surged as the data pushed rate cut bets further into the future with July now less than a 50-50 chance. Wall Street finished with steep declines led by tech. Stocks opened in the green on a relief trade after Israel repulsed the well advertised attack from Iran on Sunday. But equities turned sharply lower and extended last week’s declines amid the rise in yields. Investor concerns were intensified as Israel threatened retaliation. There’s growing anxiety over earnings even after a big beat from Goldman Sachs. UK labor market data was mixed, as the ILO unemployment rate unexpectedly lifted, while wage growth came in higher than anticipated – The data suggests that the labor market is catching up with the recession. Mixed messages then for the BoE. China grew by 5.3% in Q1 however the numbers are causing a lot of doubts over sustainability of this growth. The bounce came in the first 2 months of the year. In March, growth in retail sales slumped and industrial output decelerated below forecasts, suggesting challenges on the horizon. Today: Germany ZEW, US housing starts & industrial production, Fed Vice Chair Philip Jefferson speech, BOE Bailey speech & IMF outlook. Earnings releases: Morgan Stanley and Bank of America. Financial Markets Performance:   The US Dollar rallied to 106.19 after testing 106.25, gaining against JPY and rising to 154.23, despite intervention risk. Yen traders started to see the 160 mark as the next Resistance level. Gold surged 1.76% to $2386 per ounce amid geopolitical risks and Chinese buying, even as the USD firmed and yields climbed. USOIL is flat at $85 per barrel. Market Trends:   Breaks of key technical levels exacerbated the sell off. Tech was the big loser with the NASDAQ plunging -1.79% to 15,885 while the S&P500 dropped -1.20% to 5061, with the Dow sliding -0.65% to 37,735. The S&P had the biggest 2-day sell off since March 2023. Nikkei and ASX lost -1.9% and -1.8% respectively, and the Hang Seng is down -2.1%. European bourses are down more than -1% and US futures are also in the red. CTA selling tsunami: “Just a few points lower CTAs will for the first time this year start selling in size, to add insult to injury, we are breaking major trend-lines in equities and the gamma stabilizer is totally gone.” Short term CTA threshold levels are kicking in big time according to GS. Medium term is 4873 (most important) while the long term level is at 4605. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • Date: 15th April 2024. Market News – Negative Reversion; Safe Havens Rally. Trading Leveraged Products is risky Economic Indicators & Central Banks:   Markets weigh risk of retaliation cycle in Middle East. Initially the retaliatory strike from Iran on Israel fostered a haven bid, into bonds, gold and other haven assets, as it threatens a wider regional conflict. However, this morning, Oil and Asian equity markets were muted as traders shrugged off fears of a war escalation in the Middle East. Iran said “the matter can be deemed concluded”, and President Joe Biden has called on Israel to exercise restraint following Iran’s drone and missile strike, as part of Washington’s efforts to ease tensions in the Middle East and minimize the likelihood of a widespread regional conflict. New US and UK sanctions banned deliveries of Russian supplies, i.e. key industrial metals, produced after midnight on Friday. Aluminum jumped 9.4%, nickel rose 8.8%, suggesting brokers are bracing for major supply chain disruption. Financial Markets Performance:   The USDIndex fell back from highs over 106 to currently 105.70. The Yen dip against USD to 153.85. USOIL settled lower at 84.50 per barrel and Gold is trading below session highs at currently $2357.92 per ounce. Copper, more liquid and driven by the global economy over recent weeks, was more subdued this morning. Currently at $4.3180. Market Trends:   Asian stock markets traded mixed, but European and US futures are slightly higher after a tough session on Friday and yields have picked up. Mainland China bourses outperformed overnight, after Beijing offered renewed regulatory support. The PBOC meanwhile left the 1-year MLF rate unchanged, while once again draining funds from the system. Nikkei slipped 1% to 39,114.19. On Friday, NASDAQ slumped -1.62% to 16,175, unwinding most of Thursday’s 1.68% jump to a new all-time high at 16,442. The S&P500 fell -1.46% and the Dow dropped 1.24%. Declines were broadbased with all 11 sectors of the S&P finishing in the red. JPMorgan Chase sank 6.5% despite reporting stronger profit in Q1. The nation’s largest bank gave a forecast for a key source of income this year that fell below Wall Street’s estimate, calling for only modest growth. Apple shipments drop by 10% in Q1. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • The morning of my last post I happened to glance over to the side and saw “...angst over the FOMC’s rate trajectory triggered a flight to safety, hence boosting the haven demand. “   http://www.traderslaboratory.com/forums/topic/21621-hfmarkets-hfmcom-market-analysis-services/page/17/?tab=comments#comment-228522   I reacted, but didn’t take time to  respond then... will now --- HFBlogNews, I don’t know if you are simply aggregating the chosen narratives for the day or if it’s your own reporting... either way - “flight to safety”????  haven ?????  Re: “safety  - ”Those ‘solid rocks’ are getting so fragile a hit from a dandelion blowball might shatter them... like now nobody wants to buy longer term new issues at these rates...yet the financial media still follows the scripts... The imagery they pound day in and day out makes it look like the Fed knows what they’re doing to help ‘us’... They do know what they’re doing - but it certainly is not to help ‘us’... and it is not to ‘control’ inflation... And at some point in the not too distant future, the interest due will eat a huge portion of the ‘revenue’ Re: “haven” The defaults are coming ...  The US will not be the first to default... but it will certainly not be the very last to default !! ...Enough casual anti-white racism for the day  ... just sayin’
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.