el camino winter 2022 schedule

merge ibes with compustat

There was a problem preparing your codespace, please try again. Then use the link to the IBES CRSP Query Form to try the exercise yourself. Common Identifier Used for Linking - SEDOL. 1 GVKEY-PERMNO link table First, we need to create a GVKEY-PERMNO link table. I linked compustat - crsp and crsp - ibes, but I don't know how to combine all three datasets. for example permno 49322 link to IBES ticker ARB and ARLI, both score are zero. CUSIP Master File as of January 11, 2020. Different datasets in WRDS are collected from different sources, e.g. PERMCO and PERMNO are unique permanent identification numbers assigned by CRSP to all companies listed in CRSP dataset. Dear Kai, The main problem of linking Compustat with IBES is not the fact that Compustat's cusip is 9 character, whereas IBES is 8-character. The script can either perform the merge via the CRSP key or via G_security. Making statements based on opinion; back them up with references or personal experience. My aim is to match the earning forecast and the actual earnings. So the following paragraph in your code is to merge all the restatements related to a specific firm, right? To review, open the file in an editor that reveals hidden Unicode characters. This is basically not a Stata or statistics question. MathJax reference. Did you figer it out how to do this merge? In some rare instances, CRSP must provide a different name from Compustat's in order to maintain uniqueness across the Compustat data groups and Merge CRSP/Compustat data with IBES data This program is intended for calculation of quarterly standardized earnings surprises (SUE) based on time-series (seasonal random walk model) and analyst EPS forecasts. For example, if a company ceases to exist, its ticker may be reassigned to another company; a company may be allotted multiple CUSIPs caused by corporate structural changes. It does not require any input other than valid WRDS login credentials. Also see the Stanford guide. positions are temporary quotes. and Workshops, Ask Us! Here I document several SAS programs for annual, quarterly and monthly data, inspired by and adapted from several examples from the WRDS. Do you have an Internet link for this table? To learn more, see our tips on writing great answers. * STEP THREE: Link GVKEYS to CRSP Identifiers; * Use CCMXPF_LNKHIST table to obtain CRSP identifiers for our subset of companies/dates; *****************************************************************************************/. SAS macro to get analysts EPS consensus for a given fiscal period end (DATADATE) by a selected date (DATE), https://wrds-web.wharton.upenn.edu/wrds/support/Additional%20Support/WRDS%20Knowledge%20Base%20with%20FAQs.cfm?folder_id=658&article_id=2837, A test on Stata running speed on MacBook Pro (M1 Pro chip) and old Macs, My thoughts on Python for accounting research, Use Stata to do propensity score matching (PSM), Export a SAS dataset to Stata with all variable names converted to lowercase, Calculate delta (pay-performance sensitivity), vega (risktaking incentives), and firm-specific wealth (inside equity) for executives on Execucomp, Use Python to download lawsuit data from Stanford Law Schools Securities Class Action Clearinghouse, Stata command to create Fama-French industry classifications based on SIC codes. Doubling the cube, field extensions and minimal polynoms. (most recent), whereas IBES Cusip is hsitorical (as of date). By definition, this may be not a one-to-one match. However now I need analyst forecast data for a paper where all variables are yearly and I am not sure how to perform the merge -- what time variable should I use in the merge? Thanks for contributing an answer to Quantitative Finance Stack Exchange! merge ibes with compustat. Sorry, no, but clearly the thread is visible again. Star 12. Convert 8-digit CUSIPS into 9 and 6-digit CUSIPs. /* Compustat: COMPANY Dataset Vs. NAMES Dataset Has anyone experience which method works better? You do not have permission to delete messages in this group, Either email addresses are anonymous for this group or you need the view member email addresses permission to view the original message. Discrepancies between EPS actuals in IBES and Compustat . Python script to create a mapping table between I/B/E/S and Compustat. I would guess that they produce slightly different results, since my script doesn't account for the date as the SAS script does, Mapping I/B/E/S to Compustat via 6-digit CUSIP, We've added a "Necessary cookies only" option to the cookie consent popup, Quantitative Finance site design and logo Draft, Mapping international firms in I/B/E/S to Compustat, Mapping symbols between tickers, Reuters RICs and Bloomberg tickers. The last digit of CUSIP is only a checksum variable: read here. Most effective way to merge COMPUSTAT annual and CRSP monthly stock return file. Easily Link tables between the most frequently-used databases on the WRDS platform: The Bond CRSP Link requires subscriptions to TRACE/Enhanced TRACE and CRSP databases; the IBES CRSP Link requires subscriptions to IBES and CRSP databases; the OptionMetrics CRSP Link requires subscriptions to OptionMetrics and CRSP databases; both the Daily and the Monthly TAQ CRSP Links require subscriptions to either daily or monthly TAQ and CRSP databases; the BoardEx CRSP Compustat Link requires subscriptions to BoardEx, CRSP, and Compustat; the Refinitiv/Thomson Reuters Insiders to BoardEx link requires subscriptions to Refinitiv/Thomson Reuters Insiders and BoardEx; the Supply Chain with IDs requires subscriptions to Compustat, CRSP and CCM. sample usage: %CCI(dsout=work.a_cci, start=2000, end=2014); Invoke the macro from a filed that is saved in the same directory (this is needed for SAS to figure out. Thanks deeply for your post. Example: COMPUSTAT DATA: gvkey datadate yr indfmt consol popsrc datafmt tic cusip ; Daily TAQ-CRSP Link TAQ symbol root and CRSP PERMNO. Do I need a thermal expansion tank if I already have a pressure tank? It is a 1:1 match. I tried to follow the Codes on the WRDS Website and created a merged dataset using linking tables. /* determine file path (for relative paths) */, /* syslput pushes macro variables to the remote connection */, /* upload iclink.sas (file iclink needs to be in same directory as this file) */, /* execute iclink.sas (creates home.iclink) */, /* Firms in Compustat in fiscal year range*/, /* require fyear to be within start-end range */, /* Match with CCM linktable to get permno */, /* Match with home.iclink to get Ibes ticker */, /*******************************************************************************************/, /* FileName: iclink.sas */, /* Date: Sept 25, 2006 */, /* Author: Rabih Moussawi */, /* Description: Create IBES - CRSP Link Table */, /* FUNCTION: - Creates a link table between IBES TICKER and CRSP PERMNO */, /* - Scores links from 0 (best link) to 6 */, /* */, /* INPUT: */, /* - IBES: IDUSM file */, /* - CRSP: STOCKNAMES file */, /* OUTPUT: ICLINK set stored in home directory */, /* ICLINK has 15,187 unique IBES TICKER - CRSP PERMNO links */, /* ICLINK contains IBES TICKER and the matching CRSP PERMNO and other fields: */, /* - IBES and CRSP Company names */, /* - SCORE variable: lower scores are better and high scores may need further */, /* checking before using them to link CRSP & IBES data. Also ensure you are SSHing the right server (wrds-cloud.wharton.upenn.edu) since WRDS is transitioning to its new Cloud server recently. Shouldnt we keep the ones with highest scores? How to download all stocks from NYSE, AMEX and Nasdaq from CRSP without entering individual company codes? ACMD[MM-dd]R.PIP : Issuer file Why is this sentence from The Great Gatsby grammatical? Follow Up: struct sockaddr storage initialization by network format-string, Is there a solutiuon to add special characters from software and how to do it, Recovering from a blunder I made while emailing a professor, How to handle a hobby that makes income in US, ERROR: CREATE MATERIALIZED VIEW WITH DATA cannot be executed from a function. I wonder if both yield the same result. to GVKEY and one another. data ibeslink; set ibeslink; By using WRDS tools, researches can easily perform the following operations: CRSP> Tools > Translate toPERMCO/PERMNO, https://libguides.stanford.edu/library/wrds. The short and intermediate-term risk-adjusted returns associated with the earnings announcements are also calculated. Work fast with our official CLI. As this website (as well as the wikipedia article) explain, the first 6 digits identify a company, the subsequent 2 digits a specific issue of a security, and the 9th digit is a checksum. why is poverty island closed to the public MSY: 1021 Airline Dr, Kenner, LA 70062 (Free Shuttle) 8:00 - 23:00 24-Hour Drop Off Text / WhatsApp: 504-500-1885 merge ibes with compustat (504) 500-1880. keene, ca haunted hospital; ripley county drug bust; riverside county property tax due dates 2021; delaware county daily times archives; Gelito Coffee Jelly. Further, when two duplicate observations have the same score, why we should keep the first.permno? * Merging IBES and CRSP datasets using ICLINK table; where a.ticker=b.ticker and b.permno=c.permno and. Redoing the align environment with a specific formatting. cva hunter disassembly. Step 2 (optional): Select individual linking options if needed. To use, do the following: Step 1: Apply company codes individually, or as a list, or choose the entire database. You signed in with another tab or window. Stack Exchange network consists of 181 Q&A communities including Stack Overflow, the largest, most trusted online community for developers to learn, share their knowledge, and build their careers. Issue file: ALLCMMASTER_ISSUE.PIP.gz. ; IBES-CRSP Link Historical matching of IBES TICKER with CRSP PERMNO. Please note this program uses the macro ICLINK. The option -m (or --method) can be used to specify the method with which the two tables should be merged (see above). I want to ask two question regarding the merge between the Compstat and IBES dataset. Hi Kai, By clicking Post Your Answer, you agree to our terms of service, privacy policy and cookie policy. Hey,I also want to merge international, so non-US, firms from Compustat Global with analyst data from IBES but I am not able to do it. While there are many people on this forum who do finance analytics, and I hope that one of them will give you the answer you are looking for, you might have better luck if you also cross-post this to a user-forum related specifically to COMPUSTAT, IBES, or finance analytics generally. You signed in with another tab or window. Each Compustat item in the CCM database has a unique mnemonic text name, itm_name, maintained by CRSP. A python script to create a mapping table between I/B/E/S and Compustat. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. The code is available on my GitHub: https://github.com/snauhaus/link_compustat_ibes. How to handle a hobby that makes income in US. I could not find this table in my WRDS account. Is there a proper earth ground point in this switch box? run; Sorted already in the previous PROC step. If you are familiar with Linux-like command line, you can simply access and edit this file via Terminal (or anything equivalent on PC). However, I'm struggling with linking CRSP/Compustat data with Datastream/Worldscope data: I don't find such a linking table. If nothing happens, download GitHub Desktop and try again. Do new devs get fired if they can't solve a certain bug? This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. A place where magic is studied and practiced? The best answers are voted up and rise to the top, Not the answer you're looking for? The most standard identifiers, such as companies tickers and CUSIPs, tend to change over time. This lesson is designed for researchers who wish to link data between the IBES and CRSP databases using WRDS' familiar web query format. Wharton Research Data Services. Is it suspicious or odd to stand by the gate of a GA airport watching the planes? Login or. Your email address will not be published. Nick Cox's -savesome- is helpful here. Collections, Events You are not logged in. A tag already exists with the provided branch name. If trying to match companies in many of the WRDS databases, WRDS has a matching feature. This requires valid login credentials to WRDS. Top of Section WRDS globally-accessed, efficient web-based service gives researchers access to accurate, vetted data and WRDS doctoral-level experts. *, b.gvkey, b.fic, b.sic Macro that creates a dataset with Compustat, CRSP and IBES identifiers (gvkey, permno, Ibes ticker), @compvars: list of variables to get from compustat, default value: at sale ceq ni, @minscore: ibes iclink minimum score (0 [default] is best score, 6 worst, see iclink.sas). The Compustat-CRSP merged (CCM) database itself is a product that already contains all of the CRSP pricing data and all of Compustat's fundamental data merged into one product. I remembered that you mentioned in another blog that we should use the shares outstanding in Compustat. 600+ datasets from more than 50 vendors across multiple disciplines are accessible to support users at all experience levels. MERGING IBES WITH COMPUSTAT 18 Apr 2015, 08:43 I'm trying to merge two databases with each other: IBES with COMPUSTAT. Thank you in advance! *, crspcusip. jhye richardson brothers; bridget kelly daughter of gene kelly; barbara joyce rupard wikipedia; kildonan commons independent living; volusia county drug bust 2021; austin alexander beatie; anairis clemente death; merge ibes with compustat. One potential script that will match it for you in less than a minute: https://gist.github.com/JoostImpink/0e5a8ae738cc8ef14baf. Connect and share knowledge within a single location that is structured and easy to search. I am wondering how to identify the year the restated financial statements were originally issued? If nothing happens, download Xcode and try again. Dealscan records can be linked to Compustat using the Roberts Dealscan-Compustat Linking Database. on not missing(a.company_fkey) and a.company_fkey=b.cik; This paragraph is to link a restating firm to its GVKEY via the common identifier in both datasets. wealth rank calculator australia; merge ibes with compustat. For more information, click here . Minimising the environmental effects of my dyson brain. Common Identifier Used for Linking - CUSIP. * STEP FOUR: Option 2: Alternative way of matching CRSP data; * Match accounting data with fiscal yearends in month 't'. Clone with Git or checkout with SVN using the repositorys web address. SEC 13F Security List has incorrect CUSIP numbers? Therefore matching through Cusips is likely to be correct for many cases but not all. SHARE. Why is there a voltage on my HDMI and coaxial cables? By clicking Post Your Answer, you agree to our terms of service, privacy policy and cookie policy. Are you sure you want to create this branch? But why you only keep the first.permno? MathJax reference. The name penalty is */, /* based upon SPEDIS, which is the spelling distance function in SAS. I am trying to link Thomson Reuter's I/B/E/S dataset with Compustat. Furthermore there is also a IBES ticker but this one is not the same as the ticker from COMPUSTAT. My question is, why wouldn't we just use the 6-digit CUSIP to map the two datasets? By clicking Accept all cookies, you agree Stack Exchange can store cookies on your device and disclose information in accordance with our Cookie Policy. as select a. Is this Security table still available on WRDS? merge ibes with compustat. I tried both now and the main issue with the CUSIP method seems to be that when the ownership of a company changes, the two historic and header CUSIPs track the change differently on occasion. Thank you for posting and sharing your code! Wharton Research Data Services. (If you do, please post here to tell us you have done so.). Asking for help, clarification, or responding to other answers. Code: ssc install savesome savesome if _merge==1 using masternomatch savesome if _merge==2 using usingnomatch clear use masternomatch merge 1:1 ticker yr using usingnomatch Devra Give me a few examples of tie scores. The best answers are voted up and rise to the top, Start here for a quick overview of the site, Detailed answers to any questions you might have, Discuss the workings and policies of this site. . Connect and share knowledge within a single location that is structured and easy to search. script: link_compustat_ibis.py author: Steffen Nauhaus date: Spring 2018 This script creates a mapping table between IBES and Compustat. The script can either perform the merge via the CRSP key or via G_security. Issuer file: ALLCMMASTER_ISSUER.PIP.zip First, Compustat provides a linking, header table between GVKEY and IBES ticker (IBTIC) in its SECURITY table. If a law is new but its interpretation is vague, can the courts directly ask the drafters the intent and official interpretation of their law? by permno ticker; if first.permno; I do not have a good idea now and sorry I cannot give you a more positive reply. CRSP is the default. Email. I need monthly or quarterly data. My code is GPL licensed, can I issue a license to have my code be distributed in a specific MIT licensed project? intnx('month',a.STATPERS,0,'E') = intnx('month',c.date,0,'E'); * STEP SIX: Link IBES, CRSP and Conpustat. I want to ask a question on the mapping between AuditAnalytics and Compustat. Since I don't have SAS, I wrote a python script to create the mapping table between Compustat and IBES via CRSP. Required fields are marked *. I will look up more materials. solar mosaic subordination. Select the Slide Deck for a guided assignment on this topic. For generic linking, WRDS suggests to link based on ISIN (see https://wrds-www.wharton.upenn.edu/pages/support/manuals-and-overviews/thomson-reuters/datastream/refinitiv-datastream-overview/), while others propose as alternative to link based on CUSIP (e.g., https://libguides.princeton.edu/MatchFinancial). I tried to use the CCM linking table, but then I am left with Canadian firms only, so this is no opportunity.I tried to use the ISIN and SEDOL from Compustat to obtain the IBES CUSIP but that does not work either. To ensure that the data from different datasets applies to the same company, researchers need tools to convert permanent identifiers from one to another or to link data from different datasets for the same companies. Therefore matching through Cusips is likely to be correct for many cases but not all. IBES "Split" Dates are Jun 18, 1998 and Jan 14, 1999. Use the Linking Suite to link CRSP stocks to corporate bonds in TRACE, options in Optionmetrics, earnings forecasts in IBES, or intraday data in TAQ. If you want a more comprehensive map between GVKEY and IBES Ticker, check out on of the recent research applications on WRDS (P/E Ratio), which demonstrates how to obtain a linking table between GVKEY and IBES Ticker using CRSP-Compustat Merged product as well as WRDS ICLINK product). It supports the following methods: - Link via CRSP - Link via S_SECURITY Notes: - Output can be specified manually or via argparse - References: /************************************************************************************. I'm trying to merge two databases with each other: IBES with COMPUSTAT. Making statements based on opinion; back them up with references or personal experience. CRISP is maintained by Chicago Booth CRSP, and Compustat by S&P. For US stocks, I want to use CRSP-Compustat linked data (linking can be done using CRSP/Compustat Merged Database - Linking Table ), and for the exUS stocks, I want to use Datastream-Worldscope linked data (linking can be done using Worldscope Datastream Link ). To convert 6 digit CUSIPs to 8 digit CUSIPs and vice versa, see the Cusip FAQ. Since Compustat is firm-specific, it shouldn't matter for most forecasts which security we're looking at. (located in /wrds/comp/sasdata/na/security/). What Is the Difference Between 'Man' And 'Son of Man' in Num 23:19? Your posts are super helpful and I really enjoyed reading them. This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository. The difference between the phonemes /p/ and /b/ in Japanese. It only takes a minute to sign up. Corporate actions (name change, merger, reorganization, chapter 11 or reverse stock split) Wharton Research Data Services. If you want a more comprehensive map between GVKEY and IBES Ticker, check out on of the recent, research applications on WRDS (P/E Ratio), which demonstrates how to obtain a linking table, between GVKEY and IBES Ticker using CRSP-Compustat Merged product as well as WRDS ICLINK product).*/. There are many scripts out there that can do the matching for you. Could we access the autoexec.sas file in home directory via PC SAS Connect? How can we prove that the supernatural or paranormal doesn't exist? Your email address will not be published. * 14,591 IBES TICKERs matched to CRSP PERMNOs; /* Score links using CUSIP date range and company name spelling distance */, /* Idea: date ranges the same cusip was used in CRSP and IBES should intersect */. Site design / logo 2023 Stack Exchange Inc; user contributions licensed under CC BY-SA. MM-dd= 2 digit Month-2 digit day, CUSIP Master file names: Interesting. WRDS has a few research applications intended to demonstrate possible approaches that can, be used in order to merge Compustat GVKEY to IBES ticker. create table IBES2 as select *, min (sdates) as fdate, max (sdates) as ldate from IBES1 group by ticker, cusip order by ticker, cusip, sdates; quit; /* Label date range variables and keep only most recent company name for CUSIP link */ data IBES2; set IBES2; by ticker cusip; if last.cusip; label fdate="First Start date of CUSIP record"; Why are Suriname, Belize, and Guinea-Bissau classified as "Small Island Developing States"? Use the Linking Suite to link CRSP stocks to corporate bonds in TRACE, options in Optionmetrics, earnings forecasts in IBES, or intraday data in TAQ. intck('month',a.endfyr,b.date)between 3 and 14; proc download data=comp_CRSP out=mylocal.ccmfundaex; *download output dataset to local location; * STEP FIVE: CUSIP Method to Link IBES TICKERS and CRSP PERMNOs; * Complete list of the IBES TICKERs for all U.S. companies tracked by IBES, ** Generate a complete list of the IBES TICKERs for US companies along with all associated historical CUSIPs. Data exported from Capital IQ, FactSet, Bloomberg, Compustat, how to treat NA values in Compustat and CRSP, Bloomberg Ticker mapping with Reuters RIC, Old codes for Companies (CUSIP/ISIN/SEDOL). * Possible IBES ID (names) file to use (as of April 2006); * Detail History: ID file : 23808 unique US and Canadian company IBES TICKERs; * Summary History: IDSUM File: 15576 unique US company IBES TICKERs; * Recommendation Summary Statistics: RECDSUM File 12465 unique US company IBES tickers; * It seems that the Summary History Identifier file IDSUM is best. Learn more about Stack Overflow the company, and our products. merge ibes with compustat. * Merge Compusat cusip with CRSP cusip and create table "total"; proc sql; create table total as select compcusip. Thank you very much!! create table aa1 The main issue is that Compustat Cusip is header. WRDS offers just such tools of commonly used link resources. I will test it later. Thanks a lot. Thanks for your response. To merge via G_security, run. which makes use of the WRDS macro iclink to merge CRSP and IBES: https://wrds-web.wharton.upenn.edu/wrds/research/macros/sas_macros/iclink.cfm. For these reasons, identifiers such as tickers or CUSIPs dont work well with historical analysis. Using the CRSP/Compustat Merged Database (CCM) to extract data is one of the fundamental steps in most finance studies. AA collects restatement disclosure. You do not have permission to delete messages in this group, Either email addresses are anonymous for this group or you need the view member email addresses permission to view the original message. Can airtags be tracked from an iMac desktop, with no iPhone? As far as I can see the CRSP/Compustat Merged dataset includes the desired linking variables for merging with CRSP. Please Thanks for contributing an answer to Quantitative Finance Stack Exchange! ** Only observations with non-missing CUSIP are retained; ** rows with duplicate CUSIP information for each IBES TICKER should be deleted, ** SDATES variable for the company identifying information tracks start dates. For historical analysis on securities, researchers use permanent identifiers, such as PERMNO, PERMCO, and GVKEY that never change for the duration of the companys life span regardless of the name changes or other instances and are never being reused. The option -m (or --method) can be used to specify the method with which the two tables should be merged (see above). That said, you can save the observations which did not match by cusip and try a second merge by ticker. To subscribe to this RSS feed, copy and paste this URL into your RSS reader. Supported methods are via CRSP and via G_Security. IBES - IBES ticker. Download link table between various heavily used databases on WRDS platform, such as. The code below is untested. Ticker (problematic since tickers can be reused), CUSIP (6 digit is company level; 8 and 9 digit issue level), https://libguides.princeton.edu/MatchFinancial, Libraries and CRSP is the default. To learn more, see our tips on writing great answers. rev2023.3.3.43278. document.getElementById("ak_js_1").setAttribute("value",(new Date()).getTime()); Promote Code Transparency and Reusability in Accounting Research, /* Compustat: COMPANY Dataset Vs. NAMES Dataset, https://wrds-web.wharton.upenn.edu/wrds/support/Additional%20Support/WRDS%20Knowledge%20Base%20with%20FAQs.cfm?folder_id=658&article_id=2837 */, The main problem of linking Compustat with IBES is not the fact that Compustat's cusip is 9, character, whereas IBES is 8-character. Facebook. *, b.ibtic from aa2 a left join I tried to use the CCM linking table, but then I am left. Correct me if I am wrong. because USFIRM dummy is used to designate only US companies; /* IBES: Get the list of IBES TICKERS for US firms in IBES */, /* Create first and last 'start dates' for CUSIP link */, /* Label date range variables and keep only most recent company name for CUSIP link */, /* CRSP: Get all PERMNO-NCUSIP combinations */, /* Arrange effective dates for CUSIP link */, /* Label date range variables and keep only most recent company name */, /* CUSIP date ranges are only used in scoring as CUSIPs are not reused for. And in case ISIN is better, where do I find it in CRSP/Compustat data? Can the Spiritual Weapon spell be used as cover? But I wonder in this case, should we use the CRSP shares outstanding since it will bypass the stock split if we use the unadjust file of IBES? I was wondering if you're still looking for an answer. ** and constructing an effective date range for each historical CUSIP; proc sort data=CRSP.STOCKNAMES out=CRSP1 (keep=PERMNO NCUSIP comnam namedt nameenddt); min(namedt)as namedt,max(nameenddt) as nameenddt. Instantly share code, notes, and snippets. sign in Type in the name, CUSIP, ticker, or various other identifiers of the company and WRDS will find corresponding elements. We have to use SSH to access the file. Actions. Use MathJax to format equations. Both I obtained via WRDS. I wonder is there any way to adjust that? I want to perform a joint analysis of US stocks and exUS stocks. It is a m:1 match, right? The main issue is that Compustat Cusip is header (most recent), whereas IBES Cusip is historical (as of date).

Benevolent Dragons In Mythology, Ward County Jail Roster, Jetpack Mifi 8800l Default Admin Password, Keemokazi Family House, Articles M

merge ibes with compustat

%d bloggers like this: